【现象】
前后端分离项目,在nginx环境下部署。依靠shiro中session存储验证码,前台发送请求校验验证码时,发现拿到的不是同一个session,因此取验证码时一直为null。
【解决:更改nginx配置】
proxy_cookie_path 前面是项目路径,后面是配置文件代理的路径
例如后台配置中是:server.context-path=/api 且nginx的路径为 location /pathname{......}
则,需要配置proxy_cookie_path形如下:
location /pathname{
proxy_pass 后端服务地址;
proxy_cookie_path /api /pathname;
}
【问题原因】
如果cookie_path与地址栏上的path不一致,浏览器不会接受这个cookie,会导致session失效。
proxy_cookie_path 的作用是改变cookie的路径,使路径固定,让浏览器接受cookie。