使用Django认证系统auth认证

    auth认证系统可以处理范围非常广泛的任务,且具有一套细致的密码和权限实现。对于需要与默认配置不同需求的项目,Django支持扩展和自定义认证;会将用户信息写入到 auth_user 表中;

User对象

    User对象是认证系统的核心。它们通常表示与你的站点进行交互的用户,并用于启用限制访问、注册用户信息和给创建者关联内容等。在Django的认证框架中只存在一种类型的用户,因此诸如'superusers'或管理员'staff'用户只是具有特殊属性集的user对象,而不是不同类型的user对象。

默认user的基本属性有:

username    必选。少于等于30个字符。 用户名可以包含字母、数字、_、@、+、.和- 字符。
password 必选。 密码的哈希及元数据。(Django 不保存原始密码)。原始密码可以无限长而且可以包含任意字符。
email 可选。邮箱地址。
first_name 可选。 少于等于30个字符。
last_name 可选。少于30个字符。
is_superuser 可选。布尔值。指定这个用户拥有所有的权限而不需要给他们分配明确的权限。1为super 0 为普通用户。
last_login 无需设置。用户最后一次登录的时间。自动记录。
is_staff 可选。布尔值。指示用户是否可以访问Admin 站点。
is_active 可选。布尔值。指示用户的账号是否激活。 1为激活 0 为未激活(未激活用户不可登陆)。
date_joined 无需设置。账户创建的时间。当账号创建时,默认设置为当前的date/time。

详情djangoAPI

创建用户users

1.创建users最直接的方法是使用create_user()辅助函数:

from django.contrib.auth.models import User
user = User.objects.create_user('zhangsan', 'zhangsan@qq.com', 'zhangsanpassword') # 此时已经保存用户对象到数据库,可以继续更改其属性,如果你想改变其他领域。
user.last_name = 'Li'
user.save()

创建superusers

1.使用createsuperuser命令创建superusers:

D:\file_Djang\auth>python manage.py createsuperuser --username=baolin --email=baolin@gmail.com

# 将会提示你输入一个密码。在你输入一个密码后,该user将会立即创建。如果不带--username和--email选项,将会提示你输入这些值。

修改密码

Django不会在user模型上存储原始的(明文)密码,而只是一个哈希值。因此不要尝试直接操作user的password属性,修改密码;

1.修改密码方法一:changepassword username

# 密码必须包含至少8个字符。
D:\file_Djang\auth>python manage.py changepassword zhangsan
Changing password for user 'zhangsan'
Password:
Password (again):
Password changed successfully for user 'zhangsan'

2.通过程序修改密码,使用set_password()

from django.contrib.auth.models import User
u = User.objects.get(username='zhangsan')
u.set_password("zhangsan123")
u.save()

认证Users

    使用authenticate(),认证一组给定的用户名和密码。它接收关键字参数形式的凭证,使用默认配置时参数是username和password,如果密码能够匹配给定的用户名,它将返回一个User对象。如果密码无效,authenticate()返回None。

1.urls.py

from django.conf.urls import url
from django.contrib import admin
from app01 import views urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^login/', views.login),
url(r'^index/', views.index),
url(r'^logout/', views.log_out),
url(r'^reg/', views.reg),
url(r'^set_pwd/', views.set_pwd),
]

2.获取前端login.html传入得用户密码,判断用户验证是否正确,正确跳转到index页面,否则跳转到登陆页面;

from django.shortcuts import render, redirect, HttpResponse

from django.contrib import auth
from django.contrib.auth.models import User
from django.contrib.auth.decorators import login_required def login(request):
if request.method == "POST":
username = request.POST.get("user")
password = request.POST.get("pwd") # 直接通过 authenticate 可以直接调用 auth_user 表中的用户进行验证
# 验证成功,就会有返回值,否则返回None
user = auth.authenticate(username=username, password=password)
if user:
# 匹配给 session 绑定相应的值 user
auth.login(request, user)
return redirect("/index/")
else:
# 不成功重定向到 login 页面
return redirect("/login/")
return render(request, "login.html") # 使用Django自带得装饰器login_required 实现验证
@login_required(login_url='/login/')
def index(request):
# 如不使用 @login_required 装饰器 认证,可以直接通过if 判断request.user.is_authenticated 是否有值
# if not request.user.is_authenticated():
# return redirect("/login/") return render(request, "index.html") # auth 提供的 用户注销 auth.logout(request)
def log_out(request):
# auth 提供的 用户注销
auth.logout(request)
return redirect("/login/") # 添加用户(可以判断如果是超级用户,允许创建用户)
@login_required(login_url="/login/")
def reg(request):
if request.method == "POST":
username = request.POST.get("user")
password = request.POST.get("pwd") # auth 提供的 向 auth.user 表写入用户信息的方法
User.objects.create_user(username=username, password=password)
return redirect("/index/")
return render(request, "reg.html") # 修改密码
@login_required(login_url="/login/")
def set_pwd(request):
if request.method == "POST":
pwd = request.POST.get("pwd")
# pwd1 = request.POST.get("pwd1")
username = request.user
print(username,pwd) # 修改密码 需要 分开写,最后save()报错结果
u = User.objects.get(username=username)
u.set_password(pwd)
u.save()
return redirect("/login/")
return render(request,"set_pwd.html")

3.前端html设置:

###############index.html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<!-- 自行引入 Bootstrap 核心 组件 文件 -->
</head>
<body>
<nav class="navbar navbar-inverse">
<!-- Collect the nav links, forms, and other content for toggling -->
<div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
<ul class="nav navbar-nav navbar-right"> {# request.user 可以直接获取用 当前认证的用户 #}
<li><a href="#">{{ request.user }}</a></li>
<li><a href="/logout/">注销</a></li>
<li><a href="/reg/">添加用户</a></li>
</ul>
</div><!-- /.navbar-collapse -->
</nav>
</body>
</html> ###############login.html <!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form action="/login/" method="post">
{% csrf_token %}
<p>姓名:<input name="user" type="text"></p>
<p>密码:<input name="pwd" type="text"></p>
<input type="submit">
</form>
</body>
</html> ###############reg.html <!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h2>注册页面</h2>
<form action="/reg/" method="post">
{% csrf_token %}
<p>姓名:<input name="user" type="text"></p>
<p>密码:<input name="pwd" type="text"></p>
<input type="submit">
</form>
</body>
</html> ###############set_pwd.html <!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h2>修改密码:{{ request.user }} 用户</h2>
<form action="/set_pwd/" method="post">
{% csrf_token %}
<p>密码:<input name="pwd" type="text"></p>
{#<p>确认密码:<input name="pwd2" type="text"></p>#}
<input type="submit">
</form>
</body>
</html>

Django认证系统auth认证的更多相关文章

  1. Django之自带的认证系统 auth模块

    01-Django自带的用户认证 我们在开发一个网站的时候,无可避免的需要设计实现网站的用户系统.此时我们需要实现包括用户注册.用户登录.用户认证.注销.修改密码等功能,这还真是个麻烦的事情呢. Dj ...

  2. Django的认证系统—auth模块

    Django的认证系统 auth模块的知识点总结: 1. 创建超级用户 python manage.py createsuperuser from django.contrib import auth ...

  3. Django的认证系统 auth模块

    Django自带的用户认证 我们在开发一个网站的时候,无可避免的需要设计实现网站的用户系统.此时我们需要实现包括用户注册.用户登录.用户认证.注销.修改密码等功能,这还真是个麻烦的事情呢. Djang ...

  4. 『Django』第N+1节: Django自带的认证系统 - auth

    个人网站: lipeiguan.top 以后会慢慢转移到个人网站, 欢迎大家收藏^ . ^ 写在前面 我们在开发一个网站的时候, 经常需要实现网站的用户系统. 这个时候我们需要实现用户注册.用户登录. ...

  5. django框架进阶-auth认证系统-长期维护

    ##################    django的认证系统     ####################### 我们在开发一个网站的时候,无可避免的需要设计实现网站的用户系统.此时我们需要 ...

  6. Django的自带认证系统——auth模块

    Django自带的用户认证 auth模块 from django.contrib import auth 备注:使用auth模块时,我们默认使用Django提供的auth_user表,创建数据时,可以 ...

  7. django中间件 csrf auth认证

    django中间件 能做全局访问频率限制,身份校验,黑名单,白名单 用法: 新建一个文件夹,文件夹新建一个py文件,文件中写如下代码 注意点:你写的类必须继续MiddlewareMixin from ...

  8. django用户认证系统——自定义认证后台8

    Django auth 应用默认支持用户名(username)进行登录.但是在实践中,网站可能还需要邮箱.手机号.身份证号等进行登录,这就需要我们自己写一个认证后台,用于验证用户输入的用户信息是否正确 ...

  9. Django中间件、Auth认证

    中间件 一:什么是中间件 是介于request与response处理之间的一道处理过程 二:中间件的作用 如果你想修改请求,例如被传送到view中的HttpRequest对象. 或者你想修改view返 ...

随机推荐

  1. requests库入门04-http基本认证

    因为后续样例中GitHub都需要提供认证,所以先写关于基本认证的 http的请求中,有一些请求是需要通过授权认证之后才会响应,授权认证就是检查用户名和密码的过程.http有一个基本认证方式,在认证的过 ...

  2. 设计模式C++学习笔记之二十(完结篇 & 面向对象原则)设计模式C++实例下载

      Prototype(原型模式) 20.1.解释 概念:用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象. main(),客户 ICloneableNow,只有一个接口Clone CM ...

  3. BZOJ 3620: 似乎在梦中见过的样子

    似乎在梦中见过的样子.... 一道水题调了这么久,还半天想不出来怎么 T 的...佩服自己(果然蒟蒻) 这题想想 KMP 但是半天没思路瞟了一眼题解发现暴力枚举起始点,然后 KMP 如图: O( n2 ...

  4. 删除元素splice、shift\pop

      splice() 方法: 向/从数组中添加/删除项目,然后返回被删除的项目. splice( index位数, 数量, 新添加 ) 该方法会改变原始数组 删除数组中第一个元素 arr.shift( ...

  5. $Django ajax简介 ajax简单数据交互,上传文件(form-data格式数据),Json数据格式交互

    一.ajax  1 什么是ajax:异步的JavaScript和xml,跟后台交互,都用json  2 ajax干啥用的?前后端做数据交互:  3 之前学的跟后台做交互的方式:   -第一种:在浏览器 ...

  6. percona-xtrabackup工具实现mysql5.6.34的主从同步复制

    percona-xtrabackup工具实现mysql5.6.34的主从同步复制 下载并安装percona-xtrabackup工具 # wget https://www.percona.com/do ...

  7. go import 使用方法记录

    import "fmt"      最常用的一种形式 import "./test"   导入同一目录下test包中的内容 import f "fmt ...

  8. android系统下消息推送机制

    一.推送方式简介: 当前随着移动互联网的不断加速,消息推送的功能越来越普遍,不仅仅是应用在邮件推送上了,更多的体现在手机的APP上.当我们开发需要和服务器交互的应用程序时,基本上都需要获取服务器端的数 ...

  9. AndroidManifest.xml 最全详解

    AndroidManifest.xml 是每个android程序中必须的文件,它位于整个项目的根目录.我们每天都在使用这个文件,往里面配置程序运行所必要的组件,权限,以及一些相关信息.但是对于这个文件 ...

  10. 【进阶1-3期】JavaScript深入之内存空间详细图解(转)

    这是我在公众号(高级前端进阶)看到的文章,现在做笔记 https://mp.weixin.qq.com/s/x4ZOYysb9XdT1grJbBMVkg 今天介绍的是JS内存空间,了解内存空间中的堆和 ...