django实现自定义登陆验证


  • 自定义装饰器函数和类
  •  from utils.http import HttpResponseUnauthorized
    from django.views import View # 登陆校验装饰器 函数视图校验
    def login_require(func):
    def wrapper(request): # 校验session中是否存在login_flag
    login_flag = request.session.get('login_flag') if not login_flag:
    return HttpResponseUnauthorized('用户未登录') result = func(request)
    return result return wrapper # 登陆校验视图类 类视图校验
    class LoginRequireMixin(View):
    @classmethod
    def as_view(cls, **initkwargs):
    # 对父类的as_view进行改写并封装
    view = super(LoginRequireMixin, cls).as_view(**initkwargs)
    return login_require(view)
  • HttpResponseUnauthorized
     from django.http import HttpResponse
    
     class HttpResponseUnauthorized(HttpResponse):
    status_code = 401
  • 具体使用
  •  # 保存成绩
    @login_require
    def saveScore(request):
    if request.method == 'POST': open_id = request.POST.get('open_id')
    nickName = request.POST.get('nickName')
    gameType = request.POST.get('gameType')
    spendTime = request.POST.get('spendTime')
    ageType = request.POST.get('ageType') if not all([open_id, nickName, gameType, spendTime, ageType]):
    date = {'success': False, 'info': '请求数据不完整'}
    return JsonResponse(date) if request.session.get('openId') != open_id:
    data = {'success': False, 'info': '请求玩家和使用玩家不一致'}
    return JsonResponse(data) Score(open_id=open_id, nickName=nickName, gameType=gameType, spendTime=spendTime, ageType=ageType).save()
    data = {'success': True, 'info': '保存成功!'}
    return JsonResponse(data) return HttpResponseForbidden('Method not allowed') # 分类成绩查询
    class RankingQuery(LoginRequireMixin): def post(self, request):
    queryType = request.POST.get('queryType')
    offset = request.POST.get('offset') if not all([queryType, offset]):
    data = {'success': False, 'info': '数据不完整'}
    return JsonResponse(data) queryTypeRoute = {
    'byScore': self.queryByScore
    }
    if queryType not in queryTypeRoute:
    return HttpResponseBadRequest('unsupport queryType') func = queryTypeRoute['queryType']
    data = func(offset) return JsonResponse(data)

django实现自定义登陆验证的更多相关文章

  1. Django自定义登陆验证后台

    支持邮箱/手机号/昵称登录,在django1.6.2测试成功.1.models # -*- encoding: utf-8 -*- from django.db import models from ...

  2. Django之Cookie Session详解,CBV,FBV登陆验证装饰器和自定义分页

    Cookie Session和自定义分页   cookie Cookie的由来 大家都知道HTTP协议是无状态的. 无状态的意思是每次请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接 ...

  3. Django(5) session登录注销、csrf及中间件自定义、django Form表单验证(非常好用)

    一.Django中默认支持Session,其内部提供了5种类型的Session供开发者使用: 数据库(默认) 缓存 文件 缓存+数据库 加密cookie 1.数据库Session 1 2 3 4 5 ...

  4. Django项目:CRM(客户关系管理系统)--38--30PerfectCRM实现King_admin编辑自定义字段验证

    # kingadmin.py # ————————04PerfectCRM实现King_admin注册功能———————— from crm import models #print("ki ...

  5. Django中间件(中间件版登陆验证、访问频率限制)

    一.介绍 官方的说法:中间件是一个用来处理Django的请求和响应的框架级别的钩子.它是一个轻量.低级别的插件系统,用于在全局范围内改变Django的输入和输出.每个中间件组件都负责做一些特定的功能. ...

  6. Cookie、Session登陆验证相关介绍和用法

    一.Cookie和Session 首先.HTTP协议是无状态的:所谓的无状态是指每次的请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接关系,它不会受前面的请求响应直接影响,也不会直接 ...

  7. form表单使用(博客系统的登陆验证,注册)

    先从小的实例来看form的用法 登陆验证实例,来看form的常规用法 1. forms.py # 用于登陆验证验证 from django.core.validators import RegexVa ...

  8. DRF JWT的用法 & Django的自定义认证类 & DRF 缓存

    JWT 相关信息可参考: https://www.jianshu.com/p/576dbf44b2ae DRF JWT 的使用方法: 1. 安装 DRF JWT # pip install djang ...

  9. 自己写登陆验证及借用auth的is_authenticated验证是否登陆

    一. 自己写登陆需要注册,一个session的处理,还有一个session的删除 #自定义一个闭包装饰器,来验证def checkLogin(func): def wrapper(request, * ...

随机推荐

  1. 实操教程丨使用Pod安全策略强化K8S安全

    本文来自Rancher Labs 什么是Pod安全策略? Kubernetes Pod安全策略(PSP)是Kubernetes安全版块中极为重要的组件.Pod安全策略是集群级别的资源,用于控制Pod安 ...

  2. 原生ajax动态添加数据

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  3. CSS每日学习笔记(0)

    7.29.2019 1. CSS 指层叠样式表 (Cascading Style Sheets) 样式定义如何显示 HTML 元素 样式通常存储在样式表中 把样式添加到 HTML 4.0 中,是为了解 ...

  4. 关于CORS(跨域资源共享)的几个http请求头小实验

    对几种与跨域相关的请求头做一个总结 关于跨域可以看:9 种常见的前端跨域解决方案(详解) 看完后可以配合我的代码做些实验,看看注释掉某个响应头会发生什么,整体代码会在最后贴出 跨域简单请求 需要在服务 ...

  5. 数据库-第三章 关系数据库标准语言SQL-3.3 数据查询

    数据查询 例: 一.单表查询 1.定义 是指仅涉及一个表的查询 2.选择表中的若干列 查询指定列 例: 查询全部列 例: 查询经过计算的值 例: 3.选择表中的若干元组 消除取值重复的行 例: 查询满 ...

  6. Python之split()函数

    在Python的高级特性里有切片(Slice)操作符,可以对字符串进行截取.Python还提供split()函数可以将一个字符串分裂成多个字符串组成的列表. split()的语法挺简单的: str.s ...

  7. 使用sklearn做单机特征工程(Performing Feature Engineering Using sklearn)

    本文转载自使用sklearn做单机特征工程 目录 目录 特征工程是什么 数据预处理 1 无量纲化 11 标准化 12 区间缩放法 13 标准化与归一化的区别 2 对定量特征二值化 3 对定性特征哑编码 ...

  8. 计算智能(CI)之粒子群优化算法(PSO)(一)

    欢迎大家关注我们的网站和系列教程:http://www.tensorflownews.com/,学习更多的机器学习.深度学习的知识! 计算智能(Computational Intelligence , ...

  9. JavaScript 趣味题。

    第一题: const Greeters = [] for (var i = 0 ; i < 10 ; i++) { Greeters.push(function () { return cons ...

  10. Oracle12C的卸载过程

    1.找到自己的Oracle12C安装目录,一般的安装目录为D:\app\u01\product\12.1.0\dbhome_1\deinstall ,双击deintall.dat文件进行卸载. 2.耐 ...