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

Jia*_*aro 9 python mysql authentication django

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

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

我能够Data truncated for column 'email' at row 1通过手动编辑mySql数据库中的字段来解决" " 的问题,但有没有更好的方法来解决这个问题?最好是每次重置模式更改时都不涉及我手动编辑数据库的那个?

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

rom*_*rcz 12

EmailField 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
Run Code Online (Sandbox Code Playgroud)

但这会改变所有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)
Run Code Online (Sandbox Code Playgroud)

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