一句话简述cookie和session
两者都是保存用户信息和状态
Cookie保存在浏览器客户端,可修改
Session保存在服务端,创建后不能再修改
1.Cookie
先简单的用hyperf框架搭建环境并发送cookie(只要能发送或设置cookie即可)
data:image/s3,"s3://crabby-images/d5411/d54117479dda739843004bcda95584a4d5a802cc" alt=""
在这里我设置cookie名字为name,值为zzz
现在访问路径查看头信息
data:image/s3,"s3://crabby-images/d1bde/d1bde4c121dbeef49d0cef1de77f06eeb07a128f" alt=""
data:image/s3,"s3://crabby-images/6b4d5/6b4d56b6d495fe40d0a4463b1fef173ac4aa619c" alt=""
data:image/s3,"s3://crabby-images/19254/1925432f709b933db6dc473b27fc6cf1a1b127bd" alt=""
set-Cookie的第二个参数path=/表示只能在当前作域才能访问
1.服务端生成Cookie在响应中通过set-Cookie头部告知客户端
2.后续的http请求中都会自动携带Cookie头部
如上图为第一次请求没有Cookie字段
data:image/s3,"s3://crabby-images/a6e2e/a6e2e7d8f7ff93a9b54083eb8dd58e8d013819c7" alt=""
再次请求时多了Cookie:name=zzz的字段
Cookie在HTTP协议中以明文方式存在(HTTPS除外)
RFC中的Cookie定义
data:image/s3,"s3://crabby-images/e8d93/e8d9363a672704291bbdbc85e550b200dd947ca0" alt=""
不清理cookie,再发一个names的cookie
data:image/s3,"s3://crabby-images/779ca/779cae00711e519c54eb67dd666040b5c43afe44" alt=""
data:image/s3,"s3://crabby-images/e47a3/e47a378b0f919c4e462cd3a3603189da6a83e940" alt=""
RFC中关于set-cookie的表述
data:image/s3,"s3://crabby-images/37eed/37eed11a387fa95282c5bf88f626b74a3b61ad9f" alt=""
因为Cookie是在HTTP中传输
所以有4kb的大小限制
想要存储更多建议使用jwt即token的形式
2.Session
session存储在服务端通常以以数据库,文件或redis缓存形式存在在HTTP协议中观察不到就不表述了
http的连接是无状态的,指当前请求不会依赖于上一个请求
http的请求是可以有状态的:
有状态的http请求:服务端保存session
无状态的http请求:请求可以通过cookie携带
跨域问题
什么是跨域?
相同的协议,相同的主机和域名
http://www.xx.com
与https://www.xx.com不同源,因为协议不同
与http://www.aa.com不同源,因为主机不同
与http://www.xx.com:90不同源,因为端口不同
哪些不能跨域访问
1.cookie,localstorage,indexdb
2.DOM节点无法获取
3.ajax请求不能发送
html中哪些会出现跨域问题(即不允许跨域访问)
<script><img>等携带src属性的标签
html中允许跨域写操作:
如表单提交和重定向请求
从不安全的域名下有表单提交过来,造成对本站数据的非法修改等问题,这就是常说的CSRF安全问题,即跨站伪造请求
当业务需要跨域访问时,我们如何做
RFC中推荐使用CORS解决方案
如果跨域访问本站点,需要在HTTP响应中显示的告诉浏览器该站点被允许
即在响应头添加对应的允许头文件
1.当简单的请求进行跨域(比如ajax请求)
data:image/s3,"s3://crabby-images/8b625/8b625725972038e4b96936590e8036f507001cd3" alt=""
代码测试一下:
data:image/s3,"s3://crabby-images/b6b4c/b6b4cca7b2a5707c5e219a1d04c435ec2f043524" alt=""
data:image/s3,"s3://crabby-images/09ae3/09ae330aa3123cb47f87c6b7350432ffd369d1f9" alt=""
data:image/s3,"s3://crabby-images/6787f/6787ffcc3794f839c388b849a0a162c67d099482" alt=""
结果出现跨域问题并明确提示增加Access头部
data:image/s3,"s3://crabby-images/4b265/4b265310eb4e6e6eda9aa6a5ddf3da3dcf21510f" alt=""
data:image/s3,"s3://crabby-images/8ce91/8ce914d4978f1d63e9d9d151bf2bd592276d32f2" alt=""
即像ajax这种简单的跨域访问我们需要在响应中携带Access-Control-Allow-Origin头部,浏览器才会放行,*表示所有域
2.复杂的请求(比如axios请求)
会在发送请求前先发送一个Options请求来检测可以用哪些跨域请求访问
data:image/s3,"s3://crabby-images/befcb/befcbb40cbb8e3e9eee144aa660d6ee4b7625b4e" alt=""
在options请求中,access-control-request-method会告诉服务端即将发起什么请求
如access-control-request-method:POST表示下个请求为post
access-contril-request-headers会告诉服务端在这些请求中哪些响应头部会被使用到
如access-contril-request-headers:content-type表示content-type会被使用到
同理响应端
除了需要设置Access-Control-Allow-Origin还要一下几点:
access-control-allow-methods:表示哪些请求允许跨域访问
对应请求时的access-control-request-method头部
access-control-allow-headers表示哪些头部允许被使用
对应请求时的access-contril-request-headers
其他头部:
data:image/s3,"s3://crabby-images/f3231/f3231b9f1c8049c7dbc37fce6f5c435e98d281dc" alt=""
data:image/s3,"s3://crabby-images/cb5e8/cb5e8a54ff0ac2c6041d296a2e334a5da321ff30" alt=""
data:image/s3,"s3://crabby-images/f308b/f308b0a214dd244c88dea4d4908744cbb0dfaf5a" alt=""
data:image/s3,"s3://crabby-images/5c931/5c93135b18ff81f1d616bd379514876451044db3" alt=""
改成get和post方法
data:image/s3,"s3://crabby-images/768ca/768cad2315e28d94012f5eba12e72c3e63dd82a1" alt=""
都能读取到数据,因为是简单请求,头部有设置Access-Control-Allow-Origin
修改nginx支持delete请求
data:image/s3,"s3://crabby-images/68943/6894354c29836ac5666522db5ae2fb5d29ee7f03" alt=""
data:image/s3,"s3://crabby-images/768ca/768cad2315e28d94012f5eba12e72c3e63dd82a1" alt=""
此时可以读取数据
再观察请求的发送
delete请求在发送前多一次options请求
data:image/s3,"s3://crabby-images/a9706/a97066746962a9cf751f98e4e2cac47b3754a00f" alt=""
get请求只有一次
data:image/s3,"s3://crabby-images/7cc67/7cc67436f34b9c72a661ceeae182691a33ef0f42" alt=""
跨域总结
简单请求为get/post/head,这些请求只需要设置允许域即可,即Access-Controller-Origin
复杂请求会在发送前进行一次OPTIONS请求来读取头部是否允许进行该类请求至少需要设置二项
网友评论