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使用cookielib库示例分享
Mar 03 Python
Python中返回字典键的值的values()方法使用
May 22 Python
Python使用pymysql小技巧
Jun 04 Python
Python时间的精准正则匹配方法分析
Aug 17 Python
python数据类型判断type与isinstance的区别实例解析
Oct 31 Python
通过Pandas读取大文件的实例
Jun 07 Python
利用python在excel里面直接使用sql函数的方法
Feb 08 Python
Python基础学习之基本数据结构详解【数字、字符串、列表、元组、集合、字典】
Jun 18 Python
Python调用graphviz绘制结构化图形网络示例
Nov 22 Python
浅谈tensorflow 中tf.concat()的使用
Feb 07 Python
浅谈如何使用python抓取网页中的动态数据实现
Aug 17 Python
python实现猜拳游戏项目
Nov 30 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
Mysql的Root密码忘记,查看或修改的解决方法(图文介绍)
2013/06/14 PHP
PHP连接MySQL的2种方法小结以及防止乱码
2014/03/11 PHP
php短网址和数字之间相互转换的方法
2015/03/13 PHP
php使用PDO下exec()函数查询执行后受影响行数的方法
2017/03/28 PHP
php格式文件打开的四种方法
2018/02/24 PHP
一个多次搜索+多次传值的解决方案
2007/01/20 Javascript
javascript cookie的简单应用
2016/02/24 Javascript
基于JavaScript实现回到页面顶部动画代码
2016/05/24 Javascript
jQuery中的select操作详解
2016/11/29 Javascript
JavaScrpt判断一个数是否是质数的实例代码
2017/06/11 Javascript
js获取css的各种样式并且设置他们的方法
2017/08/22 Javascript
基于express中路由规则及获取请求参数的方法
2018/03/12 Javascript
Vue结合Video.js播放m3u8视频流的方法示例
2018/05/04 Javascript
node.js 模块和其下载资源的镜像设置的方法
2018/09/06 Javascript
JS正则表达式封装与使用操作示例
2019/05/15 Javascript
vue eslint简要配置教程详解
2019/07/26 Javascript
[02:12]DOTA2英雄基础教程 变体精灵
2013/12/16 DOTA
使用Python编写一个最基础的代码解释器的要点解析
2016/07/12 Python
Python进程间通信Queue实例解析
2018/01/25 Python
解决python3 网络请求路径包含中文的问题
2018/05/10 Python
Python使用Pickle库实现读写序列操作示例
2018/06/15 Python
Python unittest单元测试框架总结
2018/09/08 Python
详解Python并发编程之创建多线程的几种方法
2019/08/23 Python
python 正则表达式参数替换实例详解
2020/01/17 Python
使用Django xadmin 实现修改时间选择器为不可输入状态
2020/03/30 Python
python 如何使用find和find_all爬虫、找文本的实现
2020/10/16 Python
CSS3之多背景background使用示例
2013/10/18 HTML / CSS
德国游戏机商店:Konsolenkost
2019/12/08 全球购物
教育学专业毕业生的自我鉴定
2013/11/26 职场文书
蔬菜基地的创业计划书
2014/01/06 职场文书
物流仓管员工作职责
2014/01/06 职场文书
2014年超市工作总结
2014/11/19 职场文书
经典搞笑版检讨书
2015/02/19 职场文书
工厂采购员岗位职责
2015/04/07 职场文书
聘任书范文大全
2015/09/21 职场文书
MySQL 角色(role)功能介绍
2021/04/24 MySQL