zoukankan      html  css  js  c++  java
  • django中的认证登陆与用户的创建

    ---恢复内容开始---

    from django.contrib import auth

    django.contrib.auth中提供了许多方法,这里主要介绍其中的三个:

    1  authenticate()  

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

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

    user = authenticate(username='someone',password='somepassword')
    

     

    这里的user是一个有django从数据库转化过来的对象

    2  login(HttpRequest, user)  

    该函数接受一个HttpRequest对象,以及一个认证了的User对象

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

     1 from django.contrib.auth import authenticate, login
     2   
     3 def my_view(request):
     4   username = request.POST['username']
     5   password = request.POST['password']
     6   user = authenticate(username=username, password=password)
     7   if user is not None:
     8     login(request, user)
     9     # Redirect to a success page.
    10     ...
    11   else:
    12     # Return an 'invalid login' error message.
    13     ...

    3  logout(request) 注销用户  

    from django.contrib.auth import logout
      
    def logout_view(request):
      logout(request)
      # Redirect to a success page.

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

    4 user对象的 is_authenticated()

    要求:

    1  用户登陆后才能访问某些页面,

    2  如果用户没有登录就访问该页面的话直接跳到登录页面

    3  用户在跳转的登陆界面中完成登陆后,自动访问跳转到之前访问的地址

    方法1:

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

    方法2:login_required函数

    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的绝对路径 (登陆成功后,会重定向到该路径)。

     settings文件加入:LOGIN_URL = '/login/' 
     
    上面是我们登陆用额
     下面我们要使用的是怎么去创建一个用户,当然我们所用到的一切都是在django当中再带的auth数据表进行的操作

    User对象

    User 对象属性:username, password(必填项)password用哈希算法保存到数据库

    is_staff : 用户是否拥有网站的管理权限.

    is_active : 是否允许用户登录, 设置为``False``,可以不用删除用户来禁止 用户登录

    User 对象方法 

     

    2.1  is_authenticated()

    如果是真正的 User 对象,返回值恒为 True 。 用于检查用户是否已经通过了认证。
    通过认证并不意味着用户拥有任何权限,甚至也不检查该用户是否处于激活状态,这只是表明用户成功的通过了认证。 这个方法很重要, 在后台用request.user.is_authenticated()判断用户是否已经登录,如果true则可以向前台展示request.user.name

    request.user.name通常用来返回用户的名字,通常是输入的名字,当然也可以修改

    2.2  创建用户

    使用 create_user 辅助函数创建用户(这个方法是引入的USER专属的一个方法,对其他orm表不适用,也最好不要起相同的名字):

    from django.contrib.auth.models import User
    user = User.objects.create_user(username='',password='',email=''

    2.3  set_password(passwd)

    这个方法是用来更改密码的,使用步骤:

    user=User.objects.get(username='')#任何的修改都是建立在查询之上的所以你要先找到
    user.set_password(passeord='')#这也是user对象专属的方法
    user.save

    2.4  check_password(passwd)

    用户需要修改密码的时候 首先要让他输入原来的密码 ,如果给定的字符串通过了密码检查,返回 True

    下面进行一个注册的实例

    def sign_up(request):
    
    
        state = None
    
        if request.method == 'POST':
    
            password = request.POST.get('password', '')
            repeat_password = request.POST.get('repeat_password', '')
            email=request.POST.get('email', '')
            if password == '' or repeat_password == '':
                state = 'empty'
            elif password != repeat_password:
                state = 'repeat_error'
            else:
                username = request.POST.get('username', '')
                if User.objects.filter(username=username):
                    state = 'user_exist'
                else:
                    new_user = User.objects.create_user(username=username, password=password,email=email)
                    new_user.save()
                    new_my_user = MyUser(user=new_user, telephone=request.POST.get('telephone', ''))
                    new_my_user.save()
    
                    return redirect('/book/')
        content = {
            'state': state,
            'user': None,
        }
        return render(request, 'book/sign_up.html', content)

    改密码

    @login_required
    def set_password(request):
        user = request.user
        state = None
        if request.method == 'POST':
            old_password = request.POST.get('old_password', '')
            new_password = request.POST.get('new_password', '')
            repeat_password = request.POST.get('repeat_password', '')
            if user.check_password(old_password):
                if not new_password:
                    state = 'empty'
                elif new_password != repeat_password:
                    state = 'repeat_error'
                else:
                    user.set_password(new_password)
                    user.save()
                    return redirect("/log_in/")
            else:
                state = 'password_error'
        content = {
            'user': user,
            'state': state,
        }
        return render(request, 'book/set_password.html', content)
  • 相关阅读:
    day25:接口类和抽象类
    vue1
    How the weather influences your mood?
    机器学习实验方法与原理
    How human activities damage the environment
    Slow food
    Brief Introduction to Esports
    Massive open online course (MOOC)
    Online learning in higher education
    Tensorflow Dataset API
  • 原文地址:https://www.cnblogs.com/935415150wang/p/7464716.html
Copyright © 2011-2022 走看看