首页 > 其他分享 >12.22

12.22

时间:2022-12-22 17:14:26浏览次数:36  
标签:return get 12.22 request django session cookie

今日内容

1.django中间件的三个了解方法

2.基于django中间件的功能设计

3.cookie与session

4.django操作cookie

5.django操作session

1.django中间件的三个了解方法

1.process_view  路由匹配成功之后执行视图函数/类之前自动触发(顺序同process_request)
2.process_exception  视图函数/类执行报错自动触发(顺序同process_response)
3.process_template_response  视图函数/类返回的HttpResponse对象含有render并且对应一个方法的时候自动触发(顺序同process_response)

2.基于django中间件的功能设计

将各个功能制作成配置文件的字符串形式
如果想拥有该功能就编写对应的字符串,如果不想有该功能则注释掉对应的字符串
 	
利用字符串导入模块
import importlib
s1 = 'bbb.b'  # aaa.bbb.ccc.b
res = importlib.import_module(s1)  # from aaa.bbb.ccc import b
print(res)  # <module 'bbb.b' from 'D:\\pythonProject03\\djangomiddle\\bbb\\b.py'>
注意字符串的结尾最小单位只能是py文件,不能是py文件里面的变量名

需求分析
模拟编写一个消息通知功能(微信、qq、邮箱)
 
方式1:基于函数封装的版本
	没有眼前一亮的感觉,很一般
方式2:基于django中间件的功能设计
 	眼前一亮,回味无穷

3.cookie与session

cookie  保存在客户端与用户状态相关的信息
session  保存在服务端与用户状态相关的信息
ps:session的工作需要依赖于cookie,浏览器有资格拒绝保存服务端发送过来的cookie数据

4.django操作cookie

编写一个真正的用户登录功能
要想操作cookie就不能直接返回HttpResponse对象,必须先用变量接收
def login_func(request):
    if request.method == 'POST':
        username = request.POST.get('username')
        password = request.POST.get('password')
        if username == 'jason' and password == '123':
            obj = redirect('/home/')
            obj.set_cookie('name', username)
            return obj
    return render(request, 'loginPage.html')

def login_auth(func_name):
    def inner(request, *args, **kwargs):
        if request.COOKIES.get('name'):
            res = func_name(request, *args, **kwargs)
            return res
        return redirect('/login/')

    return inner

@login_auth
def home_func(request):
    return HttpResponse('home页面 只有登录的用户才可以查看')

进阶操作:用户没有登录之前想访问某个网站输入用户名密码之后就应该调回该网站
def login_func(request):
    if request.method == 'POST':
        username = request.POST.get('username')
        password = request.POST.get('password')
        if username == 'jason' and password == '123':
            target_path = request.GET.get('next')
            if target_path:
                obj = redirect(target_path)
            else:
                obj = redirect('/home/')
            obj.set_cookie('name', username)
            return obj
    return render(request, 'loginPage.html')

def login_auth(func_name):
    def inner(request, *args, **kwargs):
        # print(request.path)  # 只获取用户输入的路由信息
        # print(request.path_info)  # 只获取用户输入的路由信息
        target_path = request.path_info
        # print(request.get_full_path())  # 获取用户输入的路由信息+问号后面携带的数据
        if request.COOKIES.get('name'):
            res = func_name(request, *args, **kwargs)
            return res
        return redirect('/login/?next=%s' % target_path)

    return inner

5.django操作session

由于session是保存在服务端上面的数据,就应该有个地方能够存储
我们只需要执行数据库迁移命令即可,django会自动创建很多需要的表
django默认的session失效时间是14天
设置session	
	request.session['key'] = value
        1.生成一个随机字符串
        2.对value数据做加密处理,并在django_session表中存储
            随机字符串>>>加密数据
        3.将随机字符串也发送一份给客户端保存(cookie)
            sessionid:随机字符串
获取session	
	request.session.get('key')
        1.自动获取随机字符串
        2.去django_session表中根据随机字符串获取加密的数据
        3.自动解密数据并处理到request.sesion.get()中
    
	1.可以设置过期时间		
 	2.存储session数据的位置也可以修改

标签:return,get,12.22,request,django,session,cookie
From: https://www.cnblogs.com/yueq43/p/16999150.html

相关文章