脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服务器之家 - 脚本之家 - Python - django用户注册、登录、注销和用户扩展的示例

django用户注册、登录、注销和用户扩展的示例

2021-01-22 00:57cclehui Python

本篇文章主要介绍了django用户注册、登录、注销和用户扩展的示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

用户部分是一个网站的基本功能,django对这部分进行了很好的封装,我们只需要在django的基础上做些简单的修改就可以达到我们想要的效果

首先我假设你对django的session、cookie和数据库、admin部分都有一定的了解,不了解的可以参考这个教程:http://djangobook.py3k.cn/2.0/

1、用户登录

首先假设有这样的登录界面:

django用户注册、登录、注销和用户扩展的示例

处理登录的视图代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
def userLogin(request):
  curtime=time.strftime("%Y-%m-%d %H:%M:%S",time.localtime());
     
  if request.method=='POST':
    print("POST")
    username=request.POST.get('name','')
    password=request.POST.get('password','')
    user= auth.authenticate(username=username,password=password)#a***********
    if user and user.is_active:
      auth.login(request, user)#b************
      return HttpResponseRedirect("/user")
        
  return render_to_response("blog/userlogin.html",RequestContext(request,{'curtime':curtime})) 

注:a、这里是用django自己的auth框架验证用户名和密码,有人会说,这样太不灵活了,我想用邮箱登录呢?后面我们会说直接用django.contrib.auth.models.User 模型来直接操作用户数据,这样就可以做自己想要的验证了。
b、用户信息被验证无误后需要把用户登录的信息写入session中

2、用户注销

注销比较简单,只需要在session中删除对应的user信息就ok了

?
1
2
3
def userLogout(request):
  auth.logout(request)
  return HttpResponseRedirect('/user')

3、用户注册

注册的界面如下:

django用户注册、登录、注销和用户扩展的示例

用户名、密码、邮箱是基本的注册信息,这是django自带的,下面的电话是扩展的用户信息,至于这么扩展用户信息,一会会讲,先透露下我采用的是profile的扩展方式(个人喜好吧,我觉得这种方式简单明了)

注册的视图view代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
def userRegister(request):
  curtime=time.strftime("%Y-%m-%d %H:%M:%S",time.localtime());
   
  if request.user.is_authenticated():#a*******************
    return HttpResponseRedirect("/user")
  try:
    if request.method=='POST':
      username=request.POST.get('name','')
      password1=request.POST.get('password1','')
      password2=request.POST.get('password2','')
      email=request.POST.get('email','')
      phone=request.POST.get('phone','')
      errors=[]
       
      registerForm=RegisterForm({'username':username,'password1':password1,'password2':password2,'email':email})#b********
      if not registerForm.is_valid():
        errors.extend(registerForm.errors.values())
        return render_to_response("blog/userregister.html",RequestContext(request,{'curtime':curtime,'username':username,'email':email,'errors':errors}))
      if password1!=password2:
        errors.append("两次输入的密码不一致!")
        return render_to_response("blog/userregister.html",RequestContext(request,{'curtime':curtime,'username':username,'email':email,'errors':errors}))
         
      filterResult=User.objects.filter(username=username)#c************
      if len(filterResult)>0:
        errors.append("用户名已存在")
        return render_to_response("blog/userregister.html",RequestContext(request,{'curtime':curtime,'username':username,'email':email,'errors':errors}))
       
      user=User()#d************************
      user.username=username
      user.set_password(password1)
      user.email=email
      user.save()
      #用户扩展信息 profile
      profile=UserProfile()#e*************************
      profile.user_id=user.id
      profile.phone=phone
      profile.save()
      #登录前需要先验证
      newUser=auth.authenticate(username=username,password=password1)#f***************
      if newUser is not None:
        auth.login(request, newUser)#g*******************
        return HttpResponseRedirect("/user")
  except Exception,e:
    errors.append(str(e))
    return render_to_response("blog/userregister.html",RequestContext(request,{'curtime':curtime,'username':username,'email':email,'errors':errors}))
   
  return render_to_response("blog/userregister.html",RequestContext(request,{'curtime':curtime}))

注:

a、验证用户是否登录了,已经登录就没必要注册了(当然这只是练习使用,实际生产情况可能不一样)

b、注册表单传过来的数据需要一些基本的验证,怎么验证表单数据可以参考这个教程:http://djangobook.py3k.cn/2.0/chapter07/

c、用User模型查找要注册的用户名是否存在,如果用户已经存在就需要提示注册的客户更换用户名

d、直接利用User模型把通过验证的用户数据存入数据库,需要注意的是,保存密码信息时需要使用set_password方法(因为这里有个加密的过程)

e、存储用户的扩展信息(这里是用户的电话号码),这里用到自定义的用户扩展模型UserProfile,具体怎么扩展用户后面会讲

f、用户登录前需要先进行验证,要不然会出错

g、用户登录

4、用户扩展

网上关于django的用户扩展方式有好几种,个人比较倾向于Profile的方式,主要是这种方式简单清楚,扩展步骤如下:

A、在你App的models中新建一个UserProfile模型

?
1
2
3
4
5
from django.contrib.auth.models import User
     
class UserProfile(models.Model):
  user=models.OneToOneField(User,unique=True,verbose_name=('用户'))#a******
  phone=models.CharField(max_length=20)#b******

注:a、UserProfile其实就是一个普通的model,然后通过这一句与django的User模型建立联系

     b、扩展的用户信息

B、python manage.py syncdb 在数据库内创建userprofile的表

django用户注册、登录、注销和用户扩展的示例

C、如何调用user的扩展信息呢?很简单,先得到user,然后通过user提供的get_profile()来得到profile对象,比如

?
1
user.get_profile().phone

D、如何更新和存储user的profile信息呢,其实在之前的用户注册部分我们已经使用了这样的功能,userprofile其实也是一个model,我们只要通过user模型得到user的id,就可以通过UserProfile模型来操作对应的profile信息:

?
1
2
3
4
5
6
7
8
9
10
user=User()
user.username=username
user.set_password(password1)
user.email=email
user.save()
#用户扩展信息 profile
profile=UserProfile()
profile.user_id=user.id
profile.phone=phone
profile.save()

E、我们能在程序中操作用户扩展信息了,那我想在admin后台中编辑扩展信息要怎么做呢:

很简单,只要在你的APP的admin.py中添加下面的语句就行了

?
1
2
3
4
5
6
7
8
9
10
class UserProfileInline(admin.StackedInline):
  model=UserProfile
  fk_name='user'
  max_num=1
   
class UserProfileAdmin(UserAdmin):
  inlines = [UserProfileInline, ]
   
admin.site.unregister(User)
admin.site.register(User,UserProfileAdmin)

这是我学习django时的一些经验,也许不全对,仅供参考,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:http://blog.csdn.net/clh604/article/details/9269449

延伸 · 阅读

精彩推荐