最近在整理框架,登陆成功后用户信息没有保存,后面获取用户信息怎么也获取不到,最后发现是每次请求的sessionId都不同。然后去了解了一下session原理,浏览器第一次请求服务器时,服务器生成了session并返回给了浏览器,在浏览器工具中可以看见response中的
Set-Cookie sessionId=7155a619-6e49-49c2-9e79-c4277532a0bb; Domain=.crystal.top; Path=/framework; Max-Age=1800; Expires
=Thu, 10-Aug-2017 08:15:20 GMT; HttpOnly
正常情况只有第一次访问时会设置,但是我的项目中每次访问都会设置一个新的Cookie,并且没有将设置后的cookie带到服务器端,后来发现是因为我本地host配的域名和shiro配置的cookies的域不同一导致,没有设置域名,而shiro中sessionIdCookie.domain=.crystal.top
<!-- sessionManager创建会话Cookie的模板 -->
<bean id="sessionIdCookie" class="org.apache.shiro.web.servlet.SimpleCookie">
<property name="name" value="sessionId"></property>
<!-- 设置Cookie的过期时间,秒为单位,默认-1表示关闭浏览器时过期Cookie -->
<property name="maxAge" value="1800"></property>
<property name="httpOnly" value="true"></property>
<!-- 配置存储Session Cookie的domain为 一级域名 -->
<property name="domain" value=".crystal.top"/>
</bean>
解决:找到文件C:\Windows\System32\drivers\etc\hosts,在文件最后添加配置如下:
127.0.0.1 localhost
127.0.0.1 www.crystal.top