zoukankan      html  css  js  c++  java
  • django--auth模块

    auth模块是对登录认证方法的一种封装,之前咱们获取用户输入的用户名和密码后需要自己从相应的用户信息表里查询有没有用户名和密码符合的对象,而有了auth模块之后就可以很轻松的去验证用户的登录信息是否存在于数据库中。

    除此之外,auth还对session做了一些封装,方便我们校验用户是否已登录

    咱们可以依赖auth模块来实现注册、登录、注销、修改密码这些操作。

    注册操作

    需要要从auth模块导入user方法
    User 对象属性:username, password(必填项)password用哈希算法保存到数据库
    is_staff : 用户是否拥有网站的管理权限.
    is_active : 是否允许用户登录, 设置为``False``,可以不用删除用户来禁止 用户登录

    auth模块默认使用auth_user这张表

    create_user用来创建普通用户
    from django.contrib.auth.models import User
    首先要从auth模块导入user方法
    def register(request): if request.method == 'GET': return render(request, 'register.html') else: username = request.POST.get('username') pwd = request.POST.get('pwd') # User.objects.create(username=username, password=pwd) User.objects.create_superuser(username=username, password=pwd, email='111@qq.com')
                
    create_superuser是生成超级用户(管理员)
                User.objects.create_user(username=username, password=pwd)
                
                return HttpResponse('successs')

    登陆操作

    登陆操作会用到 authenticate() 和 login(HttpRequest, user)两个方法

    authenticate()

    提供了用户认证,即验证用户名以及密码是否正确,一般需要username password两个关键字参数

    如果认证信息有效,会返回一个 User 对象。authenticate()会在User 对象上设置一个属性标识那种认证后端认证了该用户,且该信息在后面的登录过程中是需要的。当我们试图登陆一个从数据库中直接取出来不经过authenticate()的User对象会报错的!!

    login(HttpRequest, user)

    login接受一个HttpRequest对象,以及一个认证了的User对象

    此函数使用django的session框架给某个已认证的用户附加上session id等信息

    from django.contrib import auth
                
                user_obj =  auth.authenticate(request, username=username, password=pwd)
                ## authenticate: 主要是从auth——user这张表中查询比较 数据, 返回一个user_obj对象
                
                if user_obj:
                    ####设置session
                    auth.login(request, user=user_obj)
                    作用:
                        1. 设置cookie, session
                        2. 生成request.user的对象, 这个对象可以再视图函数中使用 
                        3. request.user这个对象  相当于 request.session

     注销(安全退出)

    logout(request) 

    该函数接受一个HttpRequest对象,无返回值。当调用该函数时,当前请求的session信息会全部清除。该用户即使没有登录,使用该函数也不会报错。

    def logout(request):
    
                    auth.logout(request)
                    return HttpResponse('安全退出')

    登录状态认证

    正常的项目中用户登陆后才能访问某些页面,如果用户没有登录就访问该页面的话直接跳到登录页面,用户在跳转的登陆界面中完成登陆后,自动访问跳转到之前访问的地址

    基于这些需求咱们可以使用user对象的 is_authenticated()

    def my_view(request):
    
       if not request.user.is_authenticated():
    
          return redirect('%s?next=%s' % (settings.LOGIN_URL, request.path))
    LOGIN_URL是设置在settings文件中的参数

    方法二

    根据request.user.username来验证,如果为空,则说明没有登录

    def my_view(request):
    
       if not request.user.username:
    
          return redirect('%s?next=%s' % (settings.LOGIN_URL, request.path))

    方法三

    django已经为我们设计好了一个用于此种情况的装饰器:login_requierd()

    from django.contrib.auth.decorators import login_required
    
        
    
    @login_required
    
    def my_view(request):
    
     ...

    若用户没有登录,则会跳转到django默认的 登录URL '/accounts/login/ ' (这个值可以在settings文件中通过LOGIN_URL进行修改)。并传递 当前访问url的绝对路径 ( 登陆成功后,会重定向到该路径 )。

  • 相关阅读:
    微信开发:微信js_sdk分享,使用场景,网页在微信app内部分享时的标题与描述,包括logo设置(一)
    云服务最开始的初始密码与远程连接密码?
    阿里云域名的ssl证书申请与腾讯服务器域名的证书安装
    关于 https的SNI问题
    关于网页授权access_token和普通access_token的区别
    转载:敏捷开发框架的优势
    select自定义下拉三角符号,css样式小细节
    关于ffmpeg /iis 8.5 服务器下,视频截取第一帧参数配置
    C# WebAPI中使用Swagger
    面向对象编程思想(OOP)
  • 原文地址:https://www.cnblogs.com/duGD/p/11222008.html
Copyright © 2011-2022 走看看