博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
cookie<------>session
阅读量:6140 次
发布时间:2019-06-21

本文共 2005 字,大约阅读时间需要 6 分钟。

什么是cookie:

      保存在浏览器上的一组键值对.

为什么有cookie:

      http协议是无状态,每次请求都是无关联的,没办法保存状态.使用cookie保存状态.

cookie的特性:

         1.由服务器让浏览器进行设置的

      2.浏览器有权不设置

      3.下次访问时自动携带响应的cookie

Django中的操作:

       设置:

          1,设置普通cookie

            response.set_cookie(key,value,max_age=5,)

          2,设置加密cookie

            response.set_signed_cookie(key,value,max_age=5,salt='xxx')

            key(键)

            value(值)

            max_age=None(超时时间)

            salt='xx'(要加密的盐)

            path='/'(路径,/表示根路径,根路径的cookie可以被任何url的页面访问)

            domain=None, Cookie生效的域名

            secure=False, https传输

            httponly=False 只能http协议传输,无法被JavaScript获取(不是绝对,底层抓包可以获取到也可以被覆盖)

       获取:

          1,获取未加密的cookie(两种)

            request.COOKIES[ke]

            request.COOKIES.get(key)

          2,获取加密的cookie

            request.get_signed_cookie(key,salt='xxx',default=' ')

            default: 默认值

       删除:

          response.delete_cookie(key)

 

什么是session:

      保存在服务器上的一组键值对.-----(依赖于cookie)

为什么有session:

        1.cookie保存在浏览器本地,不安全

        2.cookie有长度限制,个数限制.

Django中的操作:

        设置:

          request.session[key] = value  (存在修改,不存在添加)

          request.session.setdefault(key,value)  (存在不修改,不存在添加)

          request.session.set_expiry(5)  (设置超时时间)

        获取:

          request.session[key]

          request.session.get(key)

        删除:

          del request.session[key]

        request.session.flush() 删除所有的session信息和cookie

        request.session.delete()   删除所有的session信息,不删除cookie

        其他:

          request.session.exists("session_key")       ----/检查会话session的key在数据库中是否存在

          request.session.set_expiry(value)    设置会话Session和Cookie的超时时间

                如果value是个datatime或timedelta,session就会在这个时间后失效。

                如果value是0,用户关闭浏览器session就会失效。
                如果value是None,session会依赖全局session失效策略。

        配置:

           from django.conf import global_settings,settings   # 全局的配置和局部的配置

          from django.contrib.sessions.backends import db  

 

转载于:https://www.cnblogs.com/leo-tail-x/p/10098043.html

你可能感兴趣的文章
技术绩效考量:你们可能都做错了
查看>>
“亲切照料”下的领域驱动设计
查看>>
除了输入法,移动端AI还有哪些想象空间?
查看>>
回家路上想起来关于Js一个有趣的东西
查看>>
B端大数据应用的架构实践与思考
查看>>
2019 SRE 调查报告:事故处理是主要工作,SRE 压力山大
查看>>
React创建组件的三种方式及其区别
查看>>
大中型企业的天网:Apache Geode
查看>>
Windows Server已可安装Docker,Azure开始支持Mesosphere
查看>>
本地部署比SaaS更容易满足GDPR要求吗?
查看>>
业内预测:2017中国光通信设备规模将达近千亿元
查看>>
网页开发从业者仍更重视桌面程序及网页应用
查看>>
如何解决mysql数据库8小时无连接自动关闭
查看>>
ASP.NET Aries 入门开发教程5:自定义列表页工具栏区
查看>>
Rushcrm:如何利用CRM系统的权限设置
查看>>
《Cisco IPv6网络实现技术(修订版)》一2.7 复习题
查看>>
Facebook 开源 Android 调试工具 —— Stetho
查看>>
生活不止有苟且,还有N个免费DevOps开源工具
查看>>
视频直播Android推流SDK初体验
查看>>
第十三天:制定预算
查看>>