User模型

一、 User模型简介

1. 是验证和授权框架的核心模型,完整路径为:django.contrib.auth.models.User

2. 模型中拥有的字段:

  1. username:用户名,max_lenght = 150,不能为空且必须唯一,可以包含字符: _ @ + . -,可以包含数字和英文

  2. first_name:外国人的first_name,max_lenght = 150,可以为空

  3. last_name:外国人的last_name,max_lenght = 150,可以为空

  4. email:邮箱,可以为空

  5. password:密码,经过哈希加密后的密码

  6. groups:分组,一个用户可以属于多个分组,一个分组可以拥有多个用户

  7. user_permissions:权限

  8. is_staff:是否可以进入到admin站点,代表是否为员工

  9. is_active:是否可用 True/False

  10. is_superuser:是否为超级管理员,拥有网站所有权限

  11. last_login:上次登录时间

  12. date_joined:账号创建时间

二、User模型基本用法(一般会将User模型进行拓展重构,那样不会生成不必要的一些字段):

1. 用户创建(必须传递字段:username,email,password)

  ·创建普通用户(模型.objects.create_user()):

    示例代码: 

from django.contrib.auth.models import User
# 创建一个普通用户
user = User.objects.create_user('lijingxuan','lijingxuan@qq.com','123456')
# 对user对象模型中的字段进行修改
user.last_name='jingxuan'
user.save()

  ·创建超级用户(模型.objects.create_superuser()):

    使用代码创建:

from django.contrib.auth.models import User

user = User.objects.create_superuser('lijingxuan','lijingxuan@qq.com','123456')

    在终端通过命令行的方式创建:python manage.py createsuperuser

2. 密码修改(对象.set_password()):

  示例代码:

from django.contrib.auth.models import User
# 获得主键为1的用户数据
user = User.objects.get(pk=1)
# 使用set_password()方法将密码加密后,存入数据库
user.set_password('新的密码')
user.save()   

3. 登录验证(django.contrib.auth.authenticate):

  1. 这个方法只能通过:username 和 password 进行验证,可以通过重构设置 User 模型中 USERNAME_FIELD 字段值来更改

  代码示例:

from dango.contrib.auth import authenticate

# 如果验证失败将返回None
user = authenticate(username='lijingxuan',password='123456')
# 默认request=None,在视图中使用时需要传入
#user = authenticate(request,username='lijingxuan',password='123456')
if user is not None: # 验证通过 else: # 验证失败

三、User模型的拓展(重点部分):

  1. 方法1:设置Proxy模型

    采用情况:当对User模型中的字段无须进行修改,只是在此基础上增加一些处理方法,则可采纳

    缺点:拓展性差

    示例代码:

from django.contrib.auth import User
# 定义一个Person继承自User
class Person(User):
# 在Meta中设置proxy为True,表示这个是User的一个代理模型
class Meta:
proxy=True
def get_blacklist(self):
    # 自定义一个方法,返回没有被拉黑的用户账号信息
    # User.objects.all() 与 Person.objects.all() 是等价的,因为他们都从User模型中获取数据
return self.objects.filter(is_active=Flase)

  

  2. 方法2:一对一外键

    采用情况:当对验证方法 authenticate 没有其他要求(验证 username 和 password 即可完成),但是有想要增加一些新字段,则可采用

    缺点:拓展性一般

    代码示例:

from django.contrib.auth.models improt User
from django.db improt models
# receiver: 新号处理方法,当User模型调用了save方法,那么就会创建一个 UserExtension 对象和 User 进行绑定
from django.dispatch import receiver
from django.db.models.signals import post_save # 自动以一个模型
class UserExtension(models.Model):
#与 User 模型进行绑定,当User调用save()方法的时候,会发送一个信号,通过receiver来监听 related_name:区别名
user = models.OneToOneField(User,on_delete=models.CASCADE,related_name='extension')
birthday = models.DateField(null=True,blank=True)
school = models.CharField(max_length=100) # 信号监听装饰器:监听User模型的save方法,一旦User模型使用save方法则会执行create_user_extension方法
@receiver(post_save,sender=User)
def create_user_extension(sender,instance,created,**kwargs):
# 创建一个处理方法:
# 参数:create:是否为创建,instance:User对象,sender:发送者
if created:
# 如果为新创建对象,则创建一个对应的对象
UserExtension.objects.create(user=instance)
else:
     # 如果为已有的对象,则也保存一下
instance.extension.save()

  

  3. 继承1: AbstractUser:

    应用场景:对用户验证 authenticate 不满意,不想要修改 User 模型上的字段但想增加一些字段,那么可以直接继承 django.contrib.auth.models.AbstractUser,这个是 User 模型的父类

    缺点:会差生一些不想要的字段

    代码示例:

from django.db import models

# from django.contrib.auth.models import User

from django.contrib.auth.models import BaseUserManager,AbstractUser

class UserManager(BaseUserManager):
def _create_user(self,telephone,username,password,**kwargs):
if not telephone:
raise ValueError('手机号码不能为空!')
if not password:
raise ValueError('密码不能为空!')
user = self.model(telephone = telephone,username=username,**kwargs)
user.set_password(password)
user.save()

def create_user(self,telephone,username,password,**kwargs):
kwargs['is_superuser'] = False
return self._create_user(telephone,username,password,**kwargs)

def create_superuser(self,telephone,username,password,**kwargs):
kwargs['is_superuser'] = True
return self._create_user(telephone,username,password,**kwargs)

# 继承自AbstractUser,可以添加字段,修改默认验证字段与 objects 的重写
class User(AbstractUser):
telephone = models.CharField(max_length=11,unique=True)
school = models.CharField(max_length=100)
  
  #修改默认验证字段,从 username 修改为 telephone

USERNAME_FIELD = 'telephone'
    REQUIRED_FIELDS = []

objects = UserManager()

     继承2: AbstractBaseUser:

    应用场景:修改默认的验证方式,并且对原来 User 模型中的某些字段不想要,那么可以自定义一个模型,然后继承自 AbstractBaseUser,再添加你想要的字段

    步骤:

      1> 创建模型 和 自定义用户创建方法(Manager):        

from django.db import models

# from django.contrib.auth.models import User
from django.contrib.auth.models import BaseUserManager,AbstractUser

# 自定义用户验证方法(objects)
class UserManager(BaseUserManager):
def _create_user(self,telephone,username,password,**kwargs):
if not telephone:
raise ValueError('手机号码不能为空!')
if not password:
raise ValueError('密码不能为空!')
user = self.model(telephone = telephone,username=username,**kwargs)
user.set_password(password)
user.save()

def create_user(self,telephone,username,password,**kwargs):
kwargs['is_superuser'] = False
return self._create_user(telephone,username,password,**kwargs)

def create_superuser(self,telephone,username,password,**kwargs):
kwargs['is_superuser'] = True
return self._create_user(telephone,username,password,**kwargs)

class User(AbstractBaseUser,PermissionsMixin):
email = models.EmailField(unique=True)
username = models.CharField(max_length=150)
telephone = models.CharField(max_length=11,unique=True)
  # 标识用户是否可用,是否被拉黑
is_active = models.BooleanField(default=True)
    
  # 修改默认验证字段为 telephone
USERNAME_FIELD = 'telephone'
  # 当通过 createsuperuser 管理命令创建一个用户时的提示,一个列表
REQUIRED_FIELDS = []
  # 将 objects 方法执行 UserManager
objects = UserManager()

  # 获取完整的名称
def get_full_name(self):
return self.username
  
  # 获取一个比较简短的用户名
def get_short_name(self):
return self.username

  2. 在settings中配置 AUTH_USER_MODEL='app名称.User'

  3. 使用自定义模型

    代码示例:

      方法1:

 from django.db import models
from myauth.models import User class Article(models.Model):
title = models.CharField(max_length=100)
content = models.TextField()
# 设置外键
author = models.ForeignKey(User, on_delete=models.CASCADE)

    方法2(建议):

 from django.db import models
from django.conf import settings class Article(models.Model):
title = models.CharField(max_length=100)
content = models.TextField()
# 使用 settings 中定义的 AUTH_USER_MODEL 字段来表示,为了更好的使用性
author = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)

    

四、权限和分组

    1. 登录:django.contrib.auth.login

        · 在使用 authenticate 进行验证后,如果通过验证,则会返回一个 user 对象,可以使用 django.contrib.auth.login 进行登录

        · 示例代码:

def my_login(request):
  if request.method == 'GET'
    return render(request,'login.html')
  else:
    # 将post数据放入自定义的表单验证方法:LoginForm 中
    form = LoginForm(request.POST)
    # 判断表单数据是否验证成功
    if form.is_valid():
      # 得到表单数据
      telephone = form.cleaned_data.get('telephone')
      password = form.cleaned_data.get('password')
      remember = form.cleaned_data.get('remember')
      # 进行表单验证
      user = authenticate(request,username=username,password=password)
      # 判断是否验证成功
      if user is not None and user.is_active:
        # 判断用户是否可用
     # 进行登录:将 user 的主键放到 request.session['pk'] 中
     login(request,user)
        if remember:
          # 判断是否需要记住我
          # 设置登录过期时间,session.set_expiry(None):表示没有过期时间
          request.session.set_expiry(None)
        else:
          # 设置登录过期时间,session.set_expiry(0):表示当关闭浏览器后,就过期
          request.session.set_expiry(0)
        # 查找 next 参数内容
        next_url = request.GET.get('next')
        if next_url:#如果找到next内容,则重定向到 next 参数代表的页面
          return redirect(next_url)      
        else:
          # 如果没有 next 参数,则返回到登录成功后的首页
          return HttpResponse('登录成功')
      else:
        # 账号或密码错误
    else:
      # 表单验证失败,登录失败,重定向到 视图
      return redirect(reverse('视图名称'))
        

    2. 注销:django.contrib.auth.logout

from django.contrib.auth import logout

      def my_logout(request):
        # 就是把 session 的登录信息清除掉
        logout(request)
        return HttpResponse('成功退出登录')

    3. 登录限制:django.contrib.auth.decorators.login_required

      1. 通过一个装饰器进行限制:@login_required()

       代码示例:

from django.contrib.auth.decorators import login_requried

# 装饰器:当没有登录的情况下访问 my_view,则会重定向到指定的login_url,并且会在 login_url 地址的后面加上一个 next 参数,值为你在未登录前访问的页面,在下次登录时可以直接重定向到 next 所代表的页面
@login_required(login_url='/accounts/login/')
def my_view(request):
pass

    4. 权限:(django.contrib.auth.models.Group)

     对应地址:https://www.cnblogs.com/ccorz/p/6358074.html

      

django 验证和授权的更多相关文章

  1. Django学习笔记之验证和授权

    验证和授权概述 Django有一个内置的授权系统.他用来处理用户.分组.权限以及基于cookie的会话系统.Django的授权系统包括验证和授权两个部分.验证是验证这个用户是否是他声称的人(比如用户名 ...

  2. Django 之验证和授权

    一.验证和授权概述 Django有一个内置的授权系统.他用来处理用户.分组.权限以及基于cookie的会话系统.Django的授权系统包括验证和授权两个部分.验证是验证这个用户是否是他声称的人(比如用 ...

  3. Django(59)验证和授权

    验证和授权概述   Django有一个内置的授权系统.他用来处理用户.分组.权限以及基于cookie的会话系统.Django的授权系统包括验证和授权两个部分.验证是验证这个用户是否是他声称的人(比如用 ...

  4. Windows Azure Active Directory (1) 前言 - 基于声明的验证和授权

    <Windows Azure Platform 系列文章目录> 在我们介绍整套系统架构之前,我们需要首先定义一些基本的概念. 用户及其属性: 用户值得是要使用某项服务的个体.用户一般都有一 ...

  5. ASP.NET Web API身份验证和授权

    英语原文地址:http://www.asp.net/web-api/overview/security/authentication-and-authorization-in-aspnet-web-a ...

  6. asp.net2.0安全性(3)--验证与授权--转载来自车老师

    "验证"与"授权"是对网页资源安全管理的两道门. 验证(Authentication):检查用户是否是合法的用户.就像是网站大门口的保卫,服责验证使用的用户名和 ...

  7. 01_Weblogic课程之概念篇:代理服务器,web服务器,应用程序服务器,JNDI概念,JTA概念,Java消息服务,Java验证和授权(JAAS),Java管理扩展,Web客户机,客户机应用程序

     1 什么是服务器 Weblogic中服务器分为两种,一种是受管服务器,另外一种是管理服务器. Weblogic课程(Weblogic是Oracle公司的,最开始的是BEA公司的) 一 系统管理 ...

  8. .Net Core 权限验证与授权(AuthorizeFilter、ActionFilterAttribute)

    在.Net Core 中使用AuthorizeFilter或者ActionFilterAttribute来实现登录权限验证和授权 一.AuthorizeFilter 新建授权类AllowAnonymo ...

  9. .NET Core微服务之基于Ocelot+IdentityServer实现统一验证与授权

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 一.案例结构总览 这里,假设我们有两个客户端(一个Web网站,一个移动App),他们要使用系统,需要通过API网关(这里API网关始终作为 ...

随机推荐

  1. 【LeetCode】416. Partition Equal Subset Sum 解题报告(Python & C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 DFS 动态规划 日期 题目地址:https://l ...

  2. uniapp中使用animate.css4.1.1动画库在小程序中不生效解决办法

    找到源码animate.css修改以下代码 :root { --animate-duration: 1s; --animate-delay: 1s; --animate-repeat: 1; } // ...

  3. <数据结构>并查集与树

    作用 查:给定一个元素,查询它在哪个集合内 并:合并两个元素所在的集合 实现思路 对应关系 元素-->结点 集合-->树 多个集合-->森林 用树的根节点作为不同树的标志 合并时只需 ...

  4. k8s loadbalancer与ingress实践

    k8s可以通过三种方式将集群内服务暴露到外网,分别是NodePort.LoadBalancer.Ingress,其中NodePort作为基础通信形式我们在<k8s网络模型与集群通信>中进行 ...

  5. 日志分析系统 - k8s部署ElasticSearch集群

    K8s部署ElasticSearch集群 1.前提准备工作 1.1 创建elastic的命名空间 namespace编排文件如下: elastic.namespace.yaml --- apiVers ...

  6. windows 找不到文件gpedit.msc

    前言: 最新在装一个软件的时候,需要更改本地组的一些内容,win+R输入gpedit.msc,提示找不到文件. 解决: 第一种方法:笔者电脑是window10 家庭版,试了网上新建一个txt文件,写入 ...

  7. Java定时调度

    一.实现方式 Timer:单线程,串行: ScheduledExecutor:并行,论询,实现麻烦: Spring Scheduler:适合小任务: JcronTab:按照crontab语法编写的ja ...

  8. synchronized学习笔记

    概述 我们都知道加锁的目的就是:序列化访问临界资源,即同一时刻只能有一个线程访问临界资源(同步互斥访问).在java对象中,每一个对象有且只有一个同步锁.这也意味着,同步锁依赖于对象而存在,当我们访问 ...

  9. k8s中的nginx-ingress如何配置路径重定向

    k8s中的nginx-ingress如何配置路径重定向 一. 需求描述 路径重定向的一般应用场景: 调整用户浏览的URL,看起来更规范 为了让搜索引擎收录网站内容,让用户体验更好 网站更换新域名后 根 ...

  10. 【代码优化】Bean映射之MapStruct

    [代码优化]Bean映射之MapStruct 一.背景 领域模型相互转换就只能靠手工的 get()/set()? 普遍的做法有以下几种: 手工 get()/set(): 构造器: BeanUtils ...