Django之Cookie

Django之Cookie

目录

介绍

当我们上网使用社交媒体或者购物时,浏览器需要通过一种方式来记住我们。想象一下你进入一家商店,店员会将一张带有身份信息的会员卡片递给你,并让你每次进店时都将卡片带在身上,这张小卡片就是Cookie

Cookie是由服务器发送到用户的浏览器中的小型文本文件,它存储在用户的计算机上,方便用户每次访问同一个浏览器页面时能够让服务器对其识别

Django操作Cookie

三板斧中的redirect HttpResponse render对象都可以操作Cookie

设置Cookie

python 复制代码
def test(request):
    # response设置为响应对象
    response = HttpResponse()
    # 为该对象绑定Cookie并赋值
    response.set_cookie('name','Paul')
    # 将有Cookie的响应对象返回给web端
    return response
浏览器查看Cookie

获取Cookie

python 复制代码
def test2(request):
    my_cookie = request.COOKIES.get('name')
    print(my_cookie)
    return HttpResponse('ok')
python 复制代码
# 输出:Paul

设置超时Cookie

python 复制代码
# 设置超时Cookie
def test(request):
    response = HttpResponse()
    response.set_cookie('name', 'Paul',max_age=5)
    return response

# 间隔五秒获取两次Cookie
def test2(request):
    my_cookie = request.COOKIES.get('name')
    print(my_cookie)
    time.sleep(5)
    print(my_cookie)
    return HttpResponse('ok')
python 复制代码
# 输出:Paul
# 	   None

注销Cookie

python 复制代码
def test2(request):
    # 将浏览器重定向的同时注销Cookie
    response = redirect('home')
    response.delete_cookie('name')
    return response

模拟登录验证

python 复制代码
def test(request):
    form_obj = UserForm()
    user = request.POST.get('user')
    pwd = request.POST.get('pwd')
    if user =='123123' and pwd == '123123':
        response = HttpResponse('登录成功')
        response.set_cookie('user','123123')
        return response
    return render(request,'app01/register.html',locals())


def test2(request):
    response = redirect('home')
    if request.COOKIES.get('user'):
        return response
    return HttpResponse('请先登录')

登录验证装饰器

python 复制代码
def check_cookie(func):
    def inner(request, *args, **kwargs):
        if request.COOKIES.get('user'):
            res = func(request, *args, **kwargs)
            return res
        else:
            return HttpResponse('请先登录')
    return inner

@check_cookie
def test2(request):
    response = redirect('home')
    return render(request, 'app01/home.html')

登录验证装饰器-升级版

python 复制代码
def login(request):
    form_obj = UserForm()
    user = request.POST.get('user')
    pwd = request.POST.get('pwd')
    if user == '123123' and pwd == '123123':
    	# 获取Cookie后直接重定向到url中next的路由,如果没有则返回home
        response = redirect(request.GET.get('next', 'home'))
        response.set_cookie('user', '123123')
        return response
    return render(request, 'app01/register.html', locals())


def check_cookie(func):
    def inner(request, *args, **kwargs):
        target_url = request.get_full_path()
        if request.COOKIES.get('user') == '123123':
            res = func(request, *args, **kwargs)
            return res
        else:
            return redirect(f'/app01/test/?next={target_url}')

    return inner


@check_cookie
def home(request):
    return HttpResponse('这里是home界面')
相关推荐
2401_841495642 小时前
Windows 系统中ffmpeg安装问题的彻底解决
windows·python·ffmpeg·bug·语音识别·下载·安装步骤
waysolong902 小时前
MCP服务构建、使用
python
于小汐在咯2 小时前
深入浅出:增强现实(AR)技术全解析
后端·ar·restful
爱上妖精的尾巴2 小时前
5-27 WPS JS宏数组元素添加删除应用2
后端·restful·wps·js宏
努力的小郑2 小时前
与产品经理的“模糊”对决:Elasticsearch实现MySQL LIKE '%xxx%' 的奇幻之旅
后端·elasticsearch·搜索引擎
胜天半月子3 小时前
Python自动化测试 | 快速认识并了解pytest的基本使用
服务器·python·pytest
小小测试开发3 小时前
Python Web3库入门:从零开始与以太坊区块链交互
python·web3·区块链
独行soc3 小时前
2025年渗透测试面试题总结-224(题目+回答)
网络·python·安全·web安全·adb·渗透测试·安全狮
程序员三藏3 小时前
软件测试之环境搭建及测试流程
自动化测试·软件测试·python·功能测试·测试工具·职场和发展·测试用例
10岁的博客3 小时前
PyTorch快速搭建CV模型实战
人工智能·pytorch·python