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


Posted in Python onMarch 19, 2018

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

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

1、用户登录:

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

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

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

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用户注册、登录、注销和用户扩展的示例

用户名、密码、邮箱是基本的注册信息,这是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的表

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

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)

这是我学习django时的一些经验,也许不全对,仅供参考,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
跟老齐学Python之眼花缭乱的运算符
Sep 14 Python
Python简单检测文本类型的2种方法【基于文件头及cchardet库】
Sep 18 Python
Python最火、R极具潜力 2017机器学习调查报告
Dec 11 Python
基于anaconda下强大的conda命令介绍
Jun 11 Python
Python将list中的string批量转化成int/float的方法
Jun 26 Python
解决python2 绘图title,xlabel,ylabel出现中文乱码的问题
Jan 29 Python
Opencv+Python实现图像运动模糊和高斯模糊的示例
Apr 11 Python
python打印9宫格、25宫格等奇数格 满足横竖斜相加和相等
Jul 19 Python
Python如何在DataFrame增加数值
Feb 14 Python
使用 Python 遍历目录树的方法
Feb 29 Python
python+selenium+Chrome options参数的使用
Mar 18 Python
python 实现定时任务的四种方式
Apr 01 Python
Python cookbook(数据结构与算法)根据字段将记录分组操作示例
Mar 19 #Python
遗传算法python版
Mar 19 #Python
python实现简单遗传算法
Mar 19 #Python
python psutil库安装教程
Mar 19 #Python
Python递归实现汉诺塔算法示例
Mar 19 #Python
Python实现替换文件中指定内容的方法
Mar 19 #Python
python书籍信息爬虫实例
Mar 19 #Python
You might like
关于尾递归的使用详解
2013/05/02 PHP
php中mkdir函数用法实例分析
2014/11/15 PHP
PHP实现WebService的简单示例和实现步骤
2015/03/27 PHP
php+mysql实现简单登录注册修改密码网页
2016/11/30 PHP
PHP运用foreach神奇的转换数组(实例讲解)
2018/02/01 PHP
javascript操作cookie
2017/01/17 Javascript
详解JS中遍历语法的比较
2017/04/07 Javascript
bootstrap动态添加面包屑(breadcrumb)及其响应事件的方法
2017/05/25 Javascript
vue组件生命周期详解
2017/11/07 Javascript
详解webpack运行Babel教程
2018/06/13 Javascript
微信小程序实现留言板
2018/10/31 Javascript
Vue利用History记录上一页面的数据方法实例
2018/11/02 Javascript
JavaScript实现图片放大镜效果
2019/06/27 Javascript
Vue.js递归组件实现组织架构树和选人功能
2019/07/04 Javascript
Vue.js计算机属性computed和methods方法详解
2019/10/12 Javascript
[41:12]Liquid vs Secret 2019国际邀请赛淘汰赛 败者组 BO3 第一场 8.24
2019/09/10 DOTA
python使用wxPython打开并播放wav文件的方法
2015/04/24 Python
python追加元素到列表的方法
2015/07/28 Python
批量将ppt转换为pdf的Python代码 只要27行!
2018/02/26 Python
python删除某个字符
2018/03/19 Python
完美解决安装完tensorflow后pip无法使用的问题
2018/06/11 Python
对numpy数据写入文件的方法讲解
2018/07/09 Python
Python 新建文件夹与复制文件夹内所有内容的方法
2018/10/27 Python
Python中的类与类型示例详解
2019/07/10 Python
python函数局部变量、全局变量、递归知识点总结
2019/11/15 Python
python/golang 删除链表中的元素
2020/09/14 Python
python 发送get请求接口详解
2020/11/17 Python
Baracuta官方网站:Harrington夹克,G9,G4,G10等
2018/03/06 全球购物
Interhome丹麦:在线预订度假屋和公寓
2019/07/18 全球购物
《有趣的发现》教学反思
2014/04/15 职场文书
实习介绍信范文
2015/05/05 职场文书
保留意见审计报告
2015/06/05 职场文书
农村婚礼司仪主持词
2015/06/29 职场文书
运动会100米广播稿
2015/08/19 职场文书
企业管理制度设计时要注意的几种“常见病”!
2019/04/19 职场文书
Ubuntu安装Mysql+启用远程连接的完整过程
2022/06/21 Servers