转载django用户注册、登录、注销和用户扩展

1、用户登录:

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

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

  • 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了

  • def userLogout(request):
  • auth.logout(request)
  • return HttpResponseRedirect(‘/user‘)

3、用户注册

注册的界面如下:

用户名、密码、邮箱是基本的注册信息,这是django自带的,下面的电话是扩展的用户信息,至于怎么扩展用户信息,一会会讲profile的扩展方式。

注册的视图view代码:

  • 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模型

  • 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的表

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

user.get_profile().phone

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

  • 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中添加下面的语句就行了

  • 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)
时间: 2024-11-03 09:35:50

转载django用户注册、登录、注销和用户扩展的相关文章

django学习日志之自定义用户扩展

django 为我们提供了强大的用户认证系统,并且提供了基于该系统的User模型,所以,很多时候,我们有必要对自己的user进行业务扩展,得到满足我们自己业务需求的user.借此,写下自己的感悟. user内置属性如下: username 用户名,必需字段.30个字符或更少,包含 _, @, +, . 和 - 字符. first_name可选. <=30字符. last_name可选. <=30字符r. email邮箱,可选. Email地址. password密码,必需.Django不是以明

JavaWeb-SpringBoot_使用H2数据库实现用户注册登录

使用Gradle编译项目 传送门 H2:SpringBoot内置持久化数据库  使用H2数据库实现用户注册登录 用户可以在index.html点击"注册"按钮将信息存储到h2数据库中,当点击"登录"按钮时,如果用户输入的是正确的账号密码,跳转到welcome.html页面,用户输入账号密码与和h2数据库中的不匹配时,重定向到index.html页面 <!DOCTYPE html> <html xmlns:th="http://www.th

2.4.2、Django处理登录和注销

在上一节的基础上,我们已经引入了django.contrib.auth应用,我们就可以在view函数中判断用户是否已经登录以及获取用户信息: if request.user.is_authenticated():     #判断用户是否已登录 user = request.user;            #获取已登录的用户 else: user = request.user;            #非登录用户将返回AnonymousUser对象 Django的User对象提供了一系列的属性和

Django之入门 CMDB系统 (三) 登录注销

Django之入门 CMDB系统 (三) 登录注销 前言 作者: 何全,github地址: https://github.com/hequan2017 QQ交流群: 620176501 通过此教程完成从零入门,能够独立编写一个简单的CMDB系统. 目前主流的方法开发方式,分为2种:mvc 和 mvvc方式.本教程为 mvc 方式,即 django负责渲染html.后面会推出 mvvc(前后端分离)的入门教程. 教程项目地址: https://github.com/hequan2017/husky

xp中 “控制面板”-&gt;“用户帐户”-&gt;“更改用户登录注销方式” 出现 一个最近安装的程序已停用欢迎界面和快速用户切换

xp中 "控制面板"->"用户帐户"->"更改用户登录注销方式" 弹出提示框:出现 一个最近安装的程序已停用欢迎界面和快速用户切换.您必须卸载该程序以恢复这些功能.下列文件名可以帮您识别该程序所作的修改:xxx.dll 如图: 出现这个现象,首先打开注册表 \HKEY_LOCAL_MACHINE\Software\Microsoft\Windows NT\CurrentVersion\Winlogon  看是否有 Ginadll项,有

银行管理系统 实现用户注册 登录 存、取款 交易记录查询和修改用户信息等功能

========= 项    目   介   绍======== 银行账户管理系统 本项目主要实现用户注册 登录 存.取钱和修改用户信息功能. 用户信息的存储和获取通过集合和IO输入输出流实现. 存钱 取钱功能通过修改用户信息中的余额实现 修改用户信息 要先获取用户信息 ,再把修改后的信息保存到List中,同时必须删除原有的用户信息. ========项目功能需求============= 该银行管理系统可以实现 以下主要几个功能 用户注册   注册成功才能进行用户登录 用户登录  登录成功后

django实现登录时候输入密码错误5次锁定用户十分钟

django实现登录时候输入密码错误5次锁定用户十分钟 在学习django的时候,想要实现登录失败后,进行用户锁定,切记录锁定时间,在网上找了很多资料,但是都感觉不是那么靠谱,于是乎,我开始了我的设计,其实我一开始想要借助redis呢,但是想要先开发一个简单的,后续在拆分后,然后在去进行拆分, 这样也是很接近我们在真实的开发中所遇到问题. 我的思路是: 输入账号密码>是否已经登录>提示已经登录 输入账号密码>错误次数少于6次>校验密码>登录成功,记录登录时间,错误次数清空,记

Lumen实现用户注册登录认证

Lumen实现用户注册登录认证 前言 Lumen是一个基于Laravel的微框架,号称是以速度为生.截用Lumen官网的一段,号称是比silex和slim还要快. 本文将用Lumen来实现一个完整的用户注册.登录及获取用户信息的API. Lumen官方网站:https://lumen.laravel.com/Lumen中文网站:http://lumen.laravel-china.org/ 安装 composer create-project --prefer-dist laravel/lume

redis实践:用户注册登录功能

本节将使用PHP和Redis实现用户注册登录功能,下面分模块来介绍具体实现方法. 1.注册 需求描述:用户注册时需要提交邮箱.登录密码和昵称.其中邮箱是用户的唯一标识,每个用户的邮箱不能重复,但允许用户修改自己的邮箱. 我们使用散列类型来存储用户的资料,键名为user:用户ID.其中用户ID是一个自增的数字,之所以使用 ID 而不是邮箱作为用户的标识是因为考虑到在其他键中可能会通过用户的标识与用户对象相关联,如果使用邮箱作为用户的标识的话在用户修改邮箱时就不得不同时需要修改大量的键名或键值.为了