Django 用户名支持30个以上字符。 (Monkeypatch版)

本文介绍了如何通过Monkeypatch解决Django Auth系统中用户名最大长度为30个字符的问题,避免修改Django核心代码,详细阐述了尝试1和2的不足,并提供了使用Monkeypatch的方法,包括编写patch函数、在特定APP中执行以及在settings.py中配置,同时提醒在应用更改后需要执行数据库迁移。
摘要由CSDN通过智能技术生成

众所周知, Django自带的Auth backend username最大只支持30个字符, 对应的Django admin也是这么校验的。 最近项目换了Oauth, 想把Oauth id直接存到username上方便登陆和管理。问题来了。。 auth模块是随Django一起安装的, 我想没人会有想法去改site-packages吧? 考虑到项目的部署方便, 因此只能在项目代码中想办法把这个可恶的限制去掉。

尝试1: 找Django提供的接口:

很遗憾,这个长度是Django直接hard code的:

class AbstractUser(AbstractBaseUser, PermissionsMixin):                             
    """                                                                             
    An abstract base class implementing a fully featured User model with            
    admin-compliant permissions.                                                    
                                                                                    
    Username, password and email are required. Other fields are optional.           
    """                                                                             
    username = models.CharField(_('username'), max_length=30, unique=True,          
        help_text=_('Required. 30 characters or fewer. Letters, numbers and '       
                    '@/./+/-/_ characters'),                                        
        validators=[                                                                
            validators.RegexValidator(re.compile('^[\w.@+-]+$'), _('Enter a valid username.'), 'invalid')
        ])                                                          
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值