django auth用户截断电子邮件字段

时间:2009-05-27 14:06:34

标签: python mysql django authentication

我的django.contrib.auth用户模型存在问题,其中电子邮件max_length为75.

我从facebook api收到超过75个字符的电子邮件地址,我需要(非常愿意)将它们存储在用户中,以确保来自facebook connect和其他用户的用户之间的连续性。

我能够通过手动编辑mySql数据库中的字段来解决“Data truncated for column 'email' at row 1”的问题,但有更好的解决方法吗?最好是< strong>不涉及我手动编辑数据库每次我重置它以进行架构更改?

我可以编辑数据库,只要我可以将它添加到重置脚本或initial_data.json文件中。

2 个答案:

答案 0 :(得分:12)

电子邮件地址75字符长度在django中是硬编码的。你可以这样解决这个问题:

from django.db.models.fields import EmailField
def email_field_init(self, *args, **kwargs):
  kwargs['max_length'] = kwargs.get('max_length', 200)
  CharField.__init__(self, *args, **kwargs)
EmailField.__init__ = email_field_init

但这会更改所有EmailField字段的长度,因此您也可以尝试:

from django.contrib.auth.models import User
from django.utils.translation import ugettext as _
from django.db import models
User.email = models.EmailField(_('e-mail address'), blank=True, max_length=200)

两种方式最好将此代码放在INSTALLED_APPS中的django.contrib.auth的任何模块的init中

答案 1 :(得分:2)

现在有一张增加Django电子邮件字段长度的票证:http://code.djangoproject.com/ticket/11579