项目名称为 third_template
目录
1??cookie
1.1??设置
1.2??读取
1.3??删除
2??session
2.1??设置
2.2??获取
1??cookie
cookie是储存在用户本地上的数据,一般用来辨明用户身份
1.1??设置
我们可以通过make_response中的set_cookie设置cookie
data:image/s3,"s3://crabby-images/dcf7b/dcf7b3690e123d0d36d5604f71b4c824ddf52d45" alt=""
我们访问一下
data:image/s3,"s3://crabby-images/0c1c9/0c1c96c1a5a19283bf223d7c840aca23b79bdafa" alt=""
发现可以看到cookie的数据,我们也可以在这里查看cookie
data:image/s3,"s3://crabby-images/fa9f6/fa9f6418de74a614529c17e9fa2062610d628d2f" alt=""
在这里可以看到我们cookie的信息
data:image/s3,"s3://crabby-images/a91fa/a91fa50ec7f8c93b02becb7e2d01f2349b13336f" alt=""
在信息下方会有cookie的有效期,默认是浏览会话结束时失效,我们将这种cookie称为临时cookie
data:image/s3,"s3://crabby-images/42afc/42afc4767e5780a17a2ad7eb476d9519674ba79b" alt=""
我们可以通过max_age参数,来设置cookie的有效期,我们现在设置为3600秒(一小时)
data:image/s3,"s3://crabby-images/7a003/7a0030673487021598bfd03ed2fdcc9f9700d5de" alt=""
访问之后我们看一下cookie
data:image/s3,"s3://crabby-images/2db8c/2db8cd00eda3da4b9d0a271015595c519d992f54" alt=""
我们观察响应头可以发现设置cookie实则是在响应头中加入了Set-Cookie这个属性
data:image/s3,"s3://crabby-images/3098d/3098d35dd9b0ddd31bbae18c0415de6cd6e4995f" alt=""
1.2??读取
一般来讲我们都是通过一个路由把cookie给出去,然后再到另一个路由中读cookie,我们现在写一个视图使用request.cookies.get()读cookie
data:image/s3,"s3://crabby-images/8185a/8185ab35b5c196501db1ce0940d78ac98ed54d9e" alt=""
我们现在访问一下
data:image/s3,"s3://crabby-images/628bc/628bc8d925ce007e64234ec8cced29e109d043e5" alt=""
那我们现在在浏览器中给浏览器删了
data:image/s3,"s3://crabby-images/05972/05972dd0b3f481f16f1d478692e563740a53c94f" alt=""
删除之后我们再访问一下
data:image/s3,"s3://crabby-images/03fb3/03fb3b984f740029d73195e45d00450a47d2e070" alt=""
1.3??删除
我们可以让有这个cookie时怎么做,没有这个cookie时就做另一件事,所以在服务端删除cookie也是很有必要的
我们使用delete_cookie删除cookie
data:image/s3,"s3://crabby-images/83c8b/83c8b7a5e2cae48608e5939087ba7870e83738d9" alt=""
运行后首先我们先访问 127.0.0.1/set_cookie 设置一个cookie
data:image/s3,"s3://crabby-images/c8a74/c8a74849e86b4bef5601afd1a2b7589ddcbb404d" alt=""
之后我们再访问 127.0.0.1/delete_cookie 删除一个cookie
data:image/s3,"s3://crabby-images/dbe43/dbe4365d7da4fd6082a1889b32432451b5c8a339" alt=""
我们发现 到期时间 给了一个奇异的值,我们现在访问 127.0.0.1/load_cookie 看一下
data:image/s3,"s3://crabby-images/200df/200df10bb225377ede5eec2ce860a75052e7f473" alt=""
发现那个奇异的值其实代表的就是cookie没了
- 设置cookie是在响应头加入了Set-cookie这个属性,删除cookie实则就是把Set-cookie这个属性变为空值且有效期会给到要给很早的日期,上面显示的50000多年是解码问题
2??session
首先我们说一下session与cookie的区别
- 存储位置 理论上session存储在服务器的缓存中,cookie存储在客户端,但是flask在默认情况下使用的是浏览器session,也就是说session与cookie是一样的
- 作用对象 cookie是针对网站的,session是针对用户的,如果我搞了一个登陆界面,我像让用户在第二次进入登陆界面时不要再登陆一边,那么我就要将用户名与密码数据放在session中而不是cookie中
他们的相同点就是根据不同的信息返回不同的页面,所以在下面我们看到处理方式很相似
在使用session前,我们首先需要设置SECRET_KEY
data:image/s3,"s3://crabby-images/3970f/3970f7d4cd089652e0976b28b5af9deb42ca0f14" alt=""
2.1??设置
data:image/s3,"s3://crabby-images/71120/7112004faf74c5becea3bb074d64080e3f944954" alt=""
我们访问一下
data:image/s3,"s3://crabby-images/81381/81381021a09c158b2a45e322708f720d86ad8457" alt=""
我们在这里可以看到session,这里的密文是配合我们之前设置的SECRET_KEY生成的
也可以在这里看
data:image/s3,"s3://crabby-images/f68fd/f68fde87f1f3f897de6a03d9beb778296d27d5f4" alt=""
2.2??获取
data:image/s3,"s3://crabby-images/b9b7a/b9b7ac32fd5f9a991454d2348651437f9f1b726a" alt=""
我们访问一下
data:image/s3,"s3://crabby-images/05125/05125436cb975220b75945183e7ff900162d2763" alt=""
|