cookie及其常用属性值

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了cookie及其常用属性值相关的知识,希望对你有一定的参考价值。

参考技术A Cookie通过在客户端记录信息确定用户身份,Session通过在服务器端记录信息确定用户身份。

expires是当前cookie的过期时间。max-age是当前cookie经过多少秒失效,等于0是关闭浏览器立即失效,小于0是cookie无效 立即删除。max-age的优先级比exprises高。

path:路径,指定与cookie关联的web,目录或路径,

"/"  凡是来自同一服务器,URL里有相同路径的所有web页面都可以共享cookies。

domain:域,指定关联的web服务器或域,值是域名,如果我们想让www.achome.cn能够访问bbs.achome.cn设置的cookies,该怎么办? 我们可以把domain属性设置成“achome.cn”,并把path属性设置成“/”。

secure:安全,指定cookie的值通过网络如何在用户和服务器之间传递。不设置或为空的情况就是使用不安全的HTTP链接传递数据。否则就是通过HTTPS或者其他安全协议传递数据。

本地的cookie文件并不加密。

samesite:(strict、lax、none)

strict最严格,完全禁止第三方cookie,跨站点时任何情况都不发送cookie。当前URL与请求目标一致才会带上cookie。

lax除了导航到目标网址的get请求外大多数情况也不发送第三方cookie,允许链接、预加载、get 表单携带cookie,但post表单、iframe、ajax等不允许携带cookie。基本也杜绝了CSRF攻击。

none任何时候都带上cookie。

HTTPonly:安全性,客户端脚本无法通过document.cookie等方式获取读写。有助于避免xss攻击。

CSRF攻击:cookie往往用来存储用户的身份信息,恶意网站可以设法伪造带有正确cookie的HTTP请求。第三方网站诱导发出的cookie,称为第三方cookie。

设置cookie:响应头中的set-cookie 前端设置cookie。同站same-site 二级域名+顶级域名,相等即可。www.lilnong.top 主机名.二级域名.顶级域名。同源和跨域same-origin 和cross-origin 。

雷林鹏分享:Flask Cookies处理

  Cookie以文本文件的形式存储在客户端计算机上。 其目的是记住和跟踪与客户使用有关的数据,以获得更好的访问体验和网站统计。

  Request对象包含一个cookie的属性。 它是所有cookie变量及其对应值的字典对象,客户端已发送。 除此之外,cookie还会存储其到期时间,路径和站点的域名。

  在Flask中,cookies设置在响应对象上。 使用make_response()函数从视图函数的返回值中获取响应对象。 之后,使用响应对象的set_cookie()函数来存储cookie。

  重读cookie很容易。 可以使用request.cookies属性的get()方法来读取cookie。

  在下面的Flask应用程序中,当访问URL => / 时,会打开一个简单的表单。

  @app.route(‘/‘)

  def index():

  return render_template(‘index.html‘)

  这个HTML页面包含一个文本输入,完整代码如下所示 -

  

  

  

  

  

  

  

 

  

 

Enter userID

 

 

  

 

  

 

  

 

  

  

  表单提交到URL => /setcookie。 关联的视图函数设置一个Cookie名称为:userID,并的另一个页面中呈现。

  @app.route(‘/setcookie‘, methods = [‘POST‘, ‘GET‘])

  def setcookie():

  if request.method == ‘POST‘:

  user = request.form[‘name‘]

  resp = make_response(render_template(‘readcookie.html‘))

  resp.set_cookie(‘userID‘, user)

  return resp

  readcookie.html 包含超链接到另一个函数getcookie()的视图,该函数读回并在浏览器中显示cookie值。

  @app.route(‘/getcookie‘)

  def getcookie():

  name = request.cookies.get(‘userID‘)

  return ‘

welcome ‘+name+‘

 

  完整的应用程序代码如下 -

  from flask import Flask

  from flask import render_template

  from flask import request

  from flask import make_response

  app = Flask(__name__)

  @app.route(‘/‘)

  def index():

  return render_template(‘index.html‘)

  @app.route(‘/setcookie‘, methods = [‘POST‘, ‘GET‘])

  def setcookie():

  if request.method == ‘POST‘:

  user = request.form[‘name‘]

  resp = make_response(render_template(‘readcookie.html‘))

  resp.set_cookie(‘userID‘, user)

  return resp

  @app.route(‘/getcookie‘)

  def getcookie():

  name = request.cookies.get(‘userID‘)

  print (name)

  return ‘

welcome, ‘+name+‘

 

  if __name__ == ‘__main__‘:

  app.run(debug = True)

  运行该应用程序并访问URL => http://localhost:5000/

技术图片

  设置cookie的结果如下所示 -

技术图片

  重读cookie的输出如下所示 -

技术图片

  (编辑:雷林鹏 来源:网络 侵删)

以上是关于cookie及其常用属性值的主要内容,如果未能解决你的问题,请参考以下文章

常用的CSS属性。

Winform中TreeView的常用属性和方法?

ajax对象的获取及其常用属性

LDAP常用属性及其描述

C# 常用开发类库整理

HTML a 标签的基本用法和常用属性