• Flask学习笔记(4):cookie


    Cookie为“小型文本文件”,是某些网站为了辨别用户身份,进行Session跟踪而储存在用户本地终端上的数据(通常经过加密),由用户客户端计算机暂时或永久保存的信息。
    flask中通过set_cookie()方法来设置cookie。

    这个方法有很多参数:

    1、key/value:设置Cookie的名称及相对应的字符串值,这是必选项;
    2、max-age: 与expires作用相同,用来告诉浏览器此cookie多久过期(单位是秒),而不是一个固定的时间点。正常情况下,max-age的优先级高于expires;
    3、expires:设置Cookie的生存期。有两种存储类型的Cookie:会话性与持久性。Expires属性缺省时,为会话性Cookie,仅保存在客户端内存中,并在用户关闭浏览器时失效;持久性Cookie会保存在用户的硬盘中,直至生存期到或用户直接在网页中单击“注销”等按钮结束会话时才会失效 ,这个值是GMT时间格式;
    4、path:定义了Web站点上可以访问该Cookie的目录 ;
    5、domain属性:指定了可以访问该 Cookie 的 Web 站点或域。Cookie 机制并未遵循严格的同源策略,允许一个子域可以设置或获取其父域的 Cookie。当需要实现单点登录方案时,Cookie 的上述特性非常有用,然而也增加了 Cookie受攻击的危险,比如攻击者可以借此发动会话定置攻击。因而,浏览器禁止在 Domain 属性中设置.org、.com 等通用顶级域名、以及在国家及地区顶级域下注册的二级域名,以减小攻击发生的范围 ;
    6、secure属性:指定是否使用HTTPS安全协议发送Cookie。使用HTTPS安全协议,可以保护Cookie在浏览器和Web服务器间的传输过程中不被窃取和篡改。该方法也可用于Web站点的身份鉴别,即在HTTPS的连接建立阶段,浏览器会检查Web网站的SSL证书的有效性。但是基于兼容性的原因(比如有些网站使用自签署的证书)在检测到SSL证书无效时,浏览器并不会立即终止用户的连接请求,而是显示安全风险信息,用户仍可以选择继续访问该站点。由于许多用户缺乏安全意识,因而仍可能连接到Pharming攻击所伪造的网站 ;
    7、httponly 属性 :用于防止客户端脚本通过document.cookie属性访问Cookie,有助于保护Cookie不被跨站脚本攻击窃取或篡改。但是,HTTPOnly的应用仍存在局限性,一些浏览器可以阻止客户端脚本对Cookie的读操作,但允许写操作;此外大多数浏览器仍允许通过XMLHTTP对象读取HTTP响应中的Set-Cookie头 ;
     
    flask中cookie的添加和删除:
     1 from flask import Flask,request,Response
     2 from datetime import datetime,timedelta
     3 app = Flask(__name__)
     4 @app.route('/')
     5 def index():
     6     res = Response('这是主页,已经设置cookie')
     7     # exp = datetime(2020,4,25)
     8     exp = datetime.now() + timedelta(days=1,hours=16) # 两天时间
     9     res.set_cookie("username","wangyi",max_age=60)
    10     res.set_cookie("age","18",expires=exp)
    11     return res
    12     """ 
    13     注意:
    14     1、max_age和expires同时设置时以max_age为标准;
    15     2、都不写则浏览器会话结束时自动删除(关闭整个浏览器则会话结束);
    16     3、cookie默认只能在主域名下使用,传入参数domain后才能在子域名下使用
    17     4、expires中使用的是格林威治时间;
    18     """
    19 
    20 @app.route("/profile")
    21 def peofile():
    22     return "这是个人中心页"
    23 
    24 @app.route("/del")
    25 def del_cookie():
    26     res = Response('删除cookie')
    27     res.delete_cookie("username")
    28     return res
    29 
    30 if __name__ == '__main__':
    31     app.run()
    Chrom浏览器直接在地址栏查看cookie:
  • 相关阅读:
    自己实现 一个 Vue框架,包含了Vue的核心原理
    Vue-Cli 3.0 中配置高德地图的两种方式
    element-ui table 点击某行高亮(修改背景色)
    input type="file"获取文件名方法
    使用 http-proxy-middleware 做转发, post 请求转发失败
    core-js@2 core-js@3报错问题
    VUE判断当前设备是PC还是移动端
    Vue函数式组件 简单实现
    清明节哀悼日网页变黑白色的CSS代码
    Vue实现递归menu
  • 原文地址:https://www.cnblogs.com/wangyi0419/p/12765031.html
Copyright © 2020-2023  润新知