基于Django-Cookie的CBV和FBV的用户验证装饰器

FBV模式


def cookie(func):  
    def deco(request,*args,**kwargs):    
        u = request.get_signed_cookie(‘username‘, salt=‘user‘, default=None)  
        if not u:  
            return render(request,‘login.html‘)  
        return func(request,*args,**kwargs)  
    return deco  
  
@cookie  
def houtai(request):  
    u = request.get_signed_cookie(‘username‘,salt=‘user‘,default=None)  
    return render(request,‘houtai.html‘,{‘user‘:u})

CBV模式


from django.utils.decorators import method_decorator  
from django import views  
  
# @method_decorator(cookie,name=‘dispatch‘)    # dispatch的便捷写法  
class CBVtest(views.View):  
  
    @method_decorator(cookie)   # 给dispatch方法添加装饰器,那么下面所有的get,post都会添加  
    def dispatch(self, request, *args, **kwargs):  
        return super(CBVtest,self).dispatch(request,*args,**kwargs)  
  
    # @method_decorator(cookie)  
    def get(self,request):  
        u = request.get_signed_cookie(‘username‘,salt=‘user‘,default=None)  
        return render(request,‘houtai.html‘,{‘user‘:u})  
  
    def post(self,request):  
        return HttpResponse(‘post ok‘)

原文地址:https://www.cnblogs.com/zhuifeng-mayi/p/9067121.html

时间: 2024-10-10 16:11:20

基于Django-Cookie的CBV和FBV的用户验证装饰器的相关文章

Django中的CBV和FBV

Django中的CBV和FBV 一.  CBV CBV是采用面向对象的方法写视图文件. CBV的执行流程: 浏览器向服务器端发送请求,服务器端的urls.py根据请求匹配url,找到要执行的视图类,执行dispatch方法区分出是POST请求还是GET请求,执行views.py对应类中的POST方法或GET方法. 使用实例: urls.py path('login/',views.Login.as_view()) views.py from django import views #在views

django权限验证装饰器

1.模型定义User from django.db import models from django.contrib.auth.models import BaseUserManager, AbstractBaseUser, PermissionsMixin from django.contrib.auth import get_user_model class UserManager(BaseUserManager): def _create_user(self , telephone, u

django登陆验证装饰器

登陆成功返回内层函数结果 outer(func):     wrapper(request, *args, **kwargs):         is_login = request.session.get(, )         is_login:             func(request, *args, **kwargs)         :             redirect()     wrapper

基于hi-nginx的web开发(python篇)——路由装饰器

现在,有了起步的基本认识,现在需要一个可以媲美flask或者bottle的简洁易用的路由功能,可以用装饰器写法任意映射 URLs 到代码. 这个,并不难.首先,来一个叫做hi的模块:hi.py: 1 import re 2 3 class hi: 4 def __init__(self): 5 self.uri_map={} 6 self.uri_regex_map={} 7 8 def route(self,pattern,method): 9 def wrapper_a(func): 10

Django—Cookie and Session

一.Cookie Cookie,有时也用其复数形式 Cookies,指某些网站为了辨别用户身份.进行 session 跟踪而储存在用户本地终端上的数据(通常经过加密). 1. 应用 服务器可以利用Cookies包含信息的任意性来筛选并经常性维护这些信息,以判断在HTTP传输中的状态. Cookies最典型的应用是判定注册用户是否已经登录网站,用户可能会得到提示,是否在下一次进入此网站时保留用户信息以便简化登录手续,这些都是Cookies的功用. 另一个重要应用场合是"购物车"之类处理.

simple_tag,filte,分页以及cookie和装饰器

自定义simple_tag 内置的方法 首先Django中包含了很多内置的方法: 这里通过lower实现 在views视图函数中写如下代码: def tp3(request): name= "ABCDEFG" return render(request,"tp3.html",{"name":name}) 在urls路由关系中添加如下: url(r'^tp3/',views.tp3), 在tp3页面中写如下: {{ name }} {{ name|

Django的CBV和FBV

1. Django支持两种对应关系,CBV和FBV FBV:function base view &CBV:class base view  url.py    index---函数名  views.py    def 函数(request): /index/ -> 函数名 /index/ ->类,请求来了以后,会执行类里面的指定的方法. 2.CBV提交----- class Home(view) Home类必须继承view. 2.1 urls.py中写对应关系 2.2 views.p

Django基于Cookie装饰器实现用户认证

def login(request): if request.method =="GET": return render(request,"login.html") elif request.method == "POST": u = request.POST.get("user") p = request.POST.get("password") print(u,p) if u ==user and p

django之基于cookie和装饰器实现用户认证

一.使用Django自带的decorator 通常情况,使用 函数定义的view,可以直接使用 login_required 直接装饰 @login_required def index(request): if request.method == "GET": return render(request, "index.htm") def user_login(request): if request.method == "GET": retu