Cookie 是可以伪造的,比如说学生证是可以伪造的
Session 是不可以伪造的,这是学校系统记录在册的
如何获取 Cookie
我们先用 Servlet 原生的获取 cookie 的方式
data:image/s3,"s3://crabby-images/94d0f/94d0f6562b06fdc64b0ac5bba6a74e38364c6674" alt=""
我们在浏览器进行访问
data:image/s3,"s3://crabby-images/e4d40/e4d4048e6765b7c7c007a29a53caa6d1bb44acad" alt=""
但是实际上目前是没有 cookie 的,我们按 F12 进行添加
data:image/s3,"s3://crabby-images/b6a8c/b6a8c27694191f0624692275e961fe34ce72f631" alt=""
然后再重新访问,就能在 idea 看到 cookie 了
data:image/s3,"s3://crabby-images/023ff/023ff8119b9e8e9f35d9aa191b9a33292bb5dedb" alt=""
接下来我们用 String 的方式获取 cookie
data:image/s3,"s3://crabby-images/9cfea/9cfeaa9c528fe5c27464e46852fac1b125520dc0" alt=""
这样就能获取到 cookie 了
data:image/s3,"s3://crabby-images/fd9cb/fd9cb7cdbd6d650b35042cb9c1b5819434a08d6f" alt=""
也可以一次性拿两个,自己设置,想拿几个拿几个
我们发现 Servlet 的方式可以拿到所有 cookie ,但是 Spring 的方式只能一个一个地拿 cookie
实际中具体情况具体选择哪种方式
获取 Session
Session 的结构内容如下
data:image/s3,"s3://crabby-images/bd884/bd8845bdc66595d4d6483f8cb9c0940255c4bd10" alt=""
data:image/s3,"s3://crabby-images/a4ac3/a4ac3dadcadff977bf53c13dbd947f7cc123c7f9" alt=""
这是原始的获取 Session 的方式
data:image/s3,"s3://crabby-images/b96ac/b96ac513b372052d6e6727e85bc64e3d58a1d522" alt=""
刚开始的时候 Session 为空
data:image/s3,"s3://crabby-images/6ed63/6ed63023ad4125e0758595dde15a93f4bafe8ab1" alt=""
所以接下来我们先存放一个 Session
data:image/s3,"s3://crabby-images/18576/185764fa3248bd8cf78468cc2a788dc798d7dde9" alt=""
运行并且访问之后发现 cookie 中多了一行数据
data:image/s3,"s3://crabby-images/645a5/645a585f58c7f02cc6e0dceacbebac3db6e60939" alt=""
用 fiddler 抓包就能发现这行数据是怎么来的,服务器告诉客户端要帮我们设置一个cookie,设置的cookie 内容如下,然后客户端接收到之后就会在 cookie 中加入这行内容,这就是 cookie 和 Session的关系,sessionId 可以看做他们俩之间的桥梁
data:image/s3,"s3://crabby-images/779d4/779d462ac0efa9b6939dba4f33d372a9ac3d1291" alt=""
此时就可以 getSession 了
data:image/s3,"s3://crabby-images/51fe3/51fe34d3d2a3994f788af3e7e134adcbb83767f5" alt=""
Cookie 和 Session 之间主要是通过 SessionId 关联起来的.SessionId 是 Cookie 和 Session 之间的桥梁
通过 Spring 来获取 Session
data:image/s3,"s3://crabby-images/e1547/e1547c2efe4e96257b9104b94b64542ea41371ce" alt=""
此时运行程序之后 Session 就会被清空,所以我们在此之前还需要先进行 setSession,再进行getSession2
下面是另一种方式获得 Session
data:image/s3,"s3://crabby-images/c4062/c406250b76d09b58b6e9d2dcd11732277dd2016b" alt=""
获取 header
我们先用传统方式获取 user-agent,获取使用的是哪个浏览器
data:image/s3,"s3://crabby-images/7d09d/7d09dfca422bc0c5ea34a52380277ecaa24759a1" alt=""
data:image/s3,"s3://crabby-images/83dc7/83dc7f06ef2eadd842e56cd7f644ea0c8861eeab" alt=""
这样我们就拿到了浏览器的信息
data:image/s3,"s3://crabby-images/35ed0/35ed0a534dcbb3f81bada01f1db790e9be4978fa" alt=""
下面是使用注解的方式获取 header
data:image/s3,"s3://crabby-images/2f0d3/2f0d38075acd3c6aaee8a945c0b39513bbc7cf0a" alt=""