1.auth简介

auth是什么?

auth是django内置的用户认证系统,可以快速的实现:登录,注销,修改密码........

2.autho的使用

1)先创建超级用户

python3 manage.py createsuperuser

输入用户名,邮箱(可以不输入),密码,敲回车,这样就创建出一个超级用户

也就是在auth_user这个表中插入了一条数据(密码是加密的,所以不能自己手动插入)

2)验证用户:

验证用户要先导入模块

from django.contrib import auth

3)登录

auth.login(request,user)

其实就是在session中写了一条数据

4)一旦登录成功,调用了这个函数login(request,user)

以后在视图类,函数中的request对象中,就有一个user对象,就是当前登录的用户对象

如果没有登录,request.user=AnonymousUser,匿名用户

5)注销

authl.ogout(request)

内部:调用了request.session.flush(),删除了登录状态

6)登录认证装饰器

@login_required()
#login_url='/login/'如果没有登录,则跳转的页面
#可以局部配置,可以全局配置(在settings中)
#全局的配置,如果没有登录,则跳转这个页面 LOGIN_URL='/login/'
def test(request):
    user = request.user
    print(user)
    return HttpResponse('OK')

7)创建用户

from django.contrib.auth.models import User
def register(request):
    name='egon2'
    password='
    user=User.objects.create_user(username=name,password=password)
    print(user)
    return HttpResponse('OK')

8)校验密码

def check(request):
    password='lqz1245'
    ret=request.user.check_password(password)
    print(ret)
    return HttpResponse('OK')

9)修改密码

def change_password(request):
    password='hahaha'
    user=request.user
    request.user.set_password(password)
    #必须要保存才能修改密码,不然保存不进去的
    user.save()
    return HttpResponse('OK')

10)is_authenticated

def shopping(request):
    user=request.user
    if user.is_authenticated():
        print(user.is_authenticated())
        return HttpResponse('通过验证')
    else:
        print(user.is_authenticated())
        return HttpResponse('请登录')

如果通过认证,是true反之false

11)其他方法(了解)

is_active:禁止登录网站(用户还存在,封号)

is_staff:是否对网站有管理权限(能不能登录admin)

12)删除用户

ORM删除

如果想在认证组件上加手机号等其他字段:如何处理

在models里进行定义

(1)定义一个表模型,跟User一对一关联

from django.contrib.auth.models import User
class UserDetail(models.Model):
    id=models.AutoField(primary_key=True)
    phone=models.CharField(max_length=32)
    #如果是从外部引入的表模型,是不能加引号的
    user=models.OneToOneField(to=User)

(2)定义一个表模型,继承AbstractUser

# 第二种方式,继承AbstractUser
from django.contrib.auth.models import User,AbstractUser
class UserInfo(AbstractUser):
    # username,password...都有
    phone=models.CharField(max_length=32)
    sex=models.BooleanField()

不仅仅要定义类,还要在settings里进行配置

AUTH_USER_MODEL='app01.UserInfo'

然后做数据库迁移,以后就没有auth_user这个表了,以后认证组件用的表就是UserInfo

Auth认证模块的更多相关文章

  1. auth 认证模块

    . auth认证模块: http://www.cnblogs.com/liwenzhou/p/9030211.html auth模块的知识点: . 创建超级用户 python manage.py cr ...

  2. django CBV装饰器 自定义django中间件 csrf跨站请求伪造 auth认证模块

    CBV加装饰器 第一种 @method_decorator(装饰器) 加在get上 第二种 @method_decorator(login_auth,name='get') 加在类上 第三种 @met ...

  3. csrf跨站请求伪造、csrf相关装饰器、auth认证模块、基于django中间件设计项目功能

    目录 csrf跨站请求网站 什么是csrf跨站请求网站 经典例子-钓鱼网站 模拟 如何避免这种现象(预防) 如何在django中解决这个问题 form表单 ajax csrf相关装饰器 FBV CBV ...

  4. Django--csrf跨站请求伪造、Auth认证模块

    form表单中使用跨站请求伪造 { % csrf_token % } 会动态生成一个input框,内部的value是随机刷新的 如果不想校验csrf from django.views.decorat ...

  5. Django之Auth认证模块

    一.Auth模块是什么 Auth模块是Django自带的用户认证模块: 我们在开发网站的时候,无可避免的需要设计实现网站的用户系统,此时我们需要实现包括用户注册,用户登陆,用户认证,注销修改密码等功能 ...

  6. Django进阶-auth集成认证模块

    auth认证模块是Django内置集成的一个用户认证模块. auth认证模块方法 方法 释义 auth.authenticate() 认证校验 auth.login(request,user) 封装认 ...

  7. django中间件 csrf auth认证

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

  8. (30)auth模块(django自带的用户认证模块)

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

  9. Django之auth模块用户认证模块

    一.Auth模块 1)auth模块是什么.登录后台使用的账号密码,则就是使用的auth模块创建的表 Auth模块是Django自带的用户认证模块: 我们在开发一个网站的时候,无可避免的需要设计实现网站 ...

随机推荐

  1. C# 如何提取字符串中的数字

    下面讲解如何在字符串当中抓取到数字 方法一.使用正则表达式 1.纯数字提取 string str = "提取123abc提取"; //我们抓取当前字符当中的123 string r ...

  2. jenkins之 pipeline 小尝试

    最近,一个小需求,动态建立slave节点来执行自动化用例,原有jenkins 老方式不满足需求,就用到jenkins2的pipeline来实现,但在实现过程中,2个小坑记录下 1.jenkins不能读 ...

  3. cordova 插件 调用iOS社交化分享(ShareSDK:微信QQ分享)

    1.github上已有的插件:https://github.com/nwpuhmz/ShareSDKPlugin 2.安装插件 cordova plugin add https://github.co ...

  4. Android Training Caching Bitmaps 翻译

    原文:http://developer.android.com/training/displaying-bitmaps/cache-bitmap.html 图片缓存 在Android开发中,加载一个图 ...

  5. [No000011D].NETCORE1/19-.NET Core 指南

    .NET Core 是一个通用开发平台,由 Microsoft 和 GitHub 上的 .NET 社区共同维护.跨平台的,支持 Windows.macOS 和 Linux,并且可用于设备.云和嵌入式/ ...

  6. CMSampleBufferRef转换

    参考链接:https://blog.csdn.net/shenyi0106/article/details/47004039 https://blog.csdn.net/jeffasd/article ...

  7. [daily][centos][nginx] 在centos7使用nginx启用对文件目录的http访问

    1. 安装nginx yum install nginx 2. 修改配置 2.1 提供目录权限: 我需要访问的目录是 /home/data, 用户是data, 所以修改如下配置: [root@S205 ...

  8. [archlinux][plasma][screensaver] plasma5配置屏保程序,没成功(-_-#)

    plamsa用了好久,一直没有屏保.我想要玄酷的屏保! 用xscreensaver, 之前用FVWM2的时候,就用过了,很玄酷. 一,安装 pacman -S xscreensaver 二,配置 xs ...

  9. 《HTTP - 状态码》

    推荐一首歌 - 那吾克热<儿子娃娃> 非常喜欢前奏 1:状态码的作用? - 职责是当客户端发起请求时候,描述请求返回结果.根据状态码,客户端可以知道服务端是正确处理了请求,还是返回了错误. ...

  10. filter的基本介绍和使用

    简介 过滤器是处在客户端和服务器资源之间的一到过滤网,我们可以根据具体的需求来对请求头和数据就行预处理,也可以对响应头和和数据进行后处理.例如Jsp, Servlet, 静态图片文件或静态 html ...