当我以自定义登录形式对用户进行注册时,出现以下错误:
AttributeError:管理器不可用; “ auth.User”已交换为“ App.MyUser”
Views.py
def signup(request):
if request.method == 'POST':
form = UserRegistrationForm(request.POST)
if form.is_valid():
userObj = form.cleaned_data
username = userObj['username']
password = userObj['password']
fname = userObj['fname']
lname = userObj['lname']
print (username,password,fname,lname)
if(len(password)<8):
messages.error(request,"This password length should be minimum 8 characters")
#raise ValidationError("This password length should be minimum 8 characters ")
validate_password_strength(password)
if not (User.objects.filter(username=username).exists()):
p = Event(fname=fname, lname=lname, username=username)
p.set_password(password)
p.save()
# return HttpResponseRedirect('Login.html')
return redirect('/Login/')
else:
raise forms.ValidationError('Looks like a username with that username or password already exists')
else:
form = UserRegistrationForm()
return render(request, 'signup.html', {'form':form})
settings.py :
AUTHENTICATION_BACKENDS = ("django.contrib.auth.backends.ModelBackend",
'django.contrib.auth.backends.RemoteUserBackend',)
AUTH_USER_MODEL = 'App.Event'
urls.py
urlpatterns = [
url('admin/', admin.site.urls),
url('Appname/', include('django.contrib.auth.urls')),
url(r'^signup/', views.signup,name='signup'),
url(r'^Login/', views.Login,name='Login'),
url(r'^Logout/', views.Logout,name='Logout'),
]
models.py
class MyUserManager(BaseUserManager):
def create_user(self, fname, lname, username, password):
"""
Creates and saves a User with the given username, date of
birth and password.
"""
if not username:
raise ValueError('Users must have an username')
user = self.model(username=username, fname=fname, lname=lname)
user.set_password(password)
user.is_active = True
user.save(using=self._db)
print(user)
return user
def create_superuser(self, fname, lname, username, password, email=None):
"""
Creates and saves a superuser with the given username and password.
"""
user = self.create_user(
fname=fname,
lname=lname,
username=username,
password=password,
)
user.is_admin = True
user.is_superuser = True
user.save(using=self._db)
return user
class Event(AbstractBaseUser):
fname = models.CharField('fname', max_length=120)
lname = models.CharField('lname', max_length=120)
username = models.CharField('username', max_length=60, unique=True)
password = models.CharField('password', max_length=120, default='xxxxxx@2789')
USERNAME_FIELD = 'username'
REQUIRED_FIELDS = ['fname', 'lname']
objects = MyUserManager()
def __unicode__(self):
return self.username
class Meta:
# managed = False
db_table = "user"
当我将App.MyUser
更改为auth.User
时,即使返回了用户名和密码,登录也没有发生,但是当我将auth.User
更改为App.MyUser
时登录未发生,并且正在引发错误。那么如何使两者都使用相同的AUTH_USER_MODEL
。
答案 0 :(得分:1)
由于您的自定义用户模型为 Event
,因此应该为
AUTH_USER_MODEL = 'your_app_name.Event'
your_app_name
是Django应用程序 Event
模型所属的名称
答案 1 :(得分:0)
You've swapped out the user model, but you still do a query explicitly against User in the line:
if not (User.objects.filter(username=username).exists()):
That should be Event, not User. But note that you should not be doing this at all; the UserRegistrationForm already checks for uniqueness. That whole condition should be deleted.