解决前后端分离 vue+springboot 跨域 session+cookie失效问题


Posted in Javascript onMay 13, 2019

环境:

前端 vue ip地址:192.168.1.205

后端 springboot2.0 ip地址:192.168.1.217

主要开发后端。

问题:

首先登陆成功时将用户存在session中,后续请求在将用户从session中取出检查。后续请求取出的用户都为null。

解决过程:

首先发现sessionID不一致,导致每一次都是新的会话,当然不可能存在用户了。然后发现cookie浏览器不能自动保存,服务器响应set-cookie了

解决前后端分离 vue+springboot 跨域 session+cookie失效问题

搜索问题,发现跨域,服务器响应的setCookie浏览器无法保存,而且就算保存了域名不同也不能携带。

第一步:

后台添加过滤器,因为前后端分离,不可能每个方法都写一遍,所以添加过滤器统一处理。

package com.test.filter;
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@WebFilter(urlPatterns = "/*", filterName = "CORSFilter")
public class CORSFilter implements Filter {
 @Override
 public void destroy() {
 }
 /**
  * 此过滤器只是处理跨域问题
  * @param servletRequest
  * @param servletResponse
  * @param chain
  * @throws ServletException
  * @throws IOException
  */
 @Override
 public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain chain) throws ServletException, IOException {
  HttpServletRequest req = (HttpServletRequest) servletRequest;
  HttpServletResponse resp = (HttpServletResponse) servletResponse;
  String origin = req.getHeader("Origin");
  if(origin == null) {
   origin = req.getHeader("Referer");
  }
  resp.setHeader("Access-Control-Allow-Origin", origin);//这里不能写*,*代表接受所有域名访问,如写*则下面一行代码无效。谨记
  resp.setHeader("Access-Control-Allow-Credentials", "true");//true代表允许携带cookie
  chain.doFilter(servletRequest,servletResponse);
 }
 @Override
 public void init(FilterConfig filterConfig) throws ServletException {
 }
}

springboot2.配置过滤器时,启动类必须加上@ServletComponentScan才会加载过滤器

@SpringBootApplication
@EnableTransactionManagement(order = 10)
@ServletComponentScan
public class Application {
 public static void main(String[] args) {
  SpringApplication.run(Application.class, args);
 }
}

然后前端配置

使用vue.resource发送请求时配置如下:
main.js中
Vue.http.options.xhr = { withCredentials: true }
使用vue.axios发送请求时配置如下:
axios.defaults.withCredentials = true;
jquery请求带上 xhrFields: {withCredentials: true}, crossDomain: true;
$.ajax({
 type: "post",
 url: "",
 xhrFields: {withCredentials: true},
 crossDomain: true,
 data: {username:$("#username").val()},
 dataType: "json",
 success: function(data){ }
});

此时问题已解决。

但我查看请求时,还是没有带cookie,太纠结于这一点了。以至于查看全部cookie时突然明白了。

解决前后端分离 vue+springboot 跨域 session+cookie失效问题

没有带cookie。

浏览器全部cookie

解决前后端分离 vue+springboot 跨域 session+cookie失效问题

已经有服务器的cookie了。当向服务器发送请求时,会携带cookie,证明是同一会话。

发现火狐的请求头中存在cookie,不知道为什么谷歌的请求头不显示,不明白。望解答。

解决前后端分离 vue+springboot 跨域 session+cookie失效问题

总结

以上所述是小编给大家介绍的解决前后端分离 vue+springboot 跨域 session+cookie失效问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
jquery的extend和fn.extend的使用说明
Jan 09 Javascript
javascript加号"+"的二义性说明
Mar 04 Javascript
js播放wav文件(源码)
Apr 22 Javascript
JavaScript实现自动消除按钮功能的方法
Aug 05 Javascript
JavaScript事件学习小结(五)js中事件类型之鼠标事件
Jun 09 Javascript
JS获取当前使用的浏览器名字以及版本号实现方法
Aug 19 Javascript
javascript ES6 新增了let命令使用介绍
Jul 07 Javascript
纯html+css+javascript实现楼层跳跃式的页面布局(实例代码)
Oct 25 Javascript
js module大战
Apr 19 Javascript
vue实现节点增删改功能
Sep 26 Javascript
vue页面引入three.js实现3d动画场景操作
Aug 10 Javascript
Postman无法正常返回结果问题解决
Aug 28 Javascript
Vue.js@2.6.10更新内置错误处机制Fundebug同步支持相应错误监控
May 13 #Javascript
详解async/await 异步应用的常用场景
May 13 #Javascript
轻松解决JavaScript定时器越走越快的问题
May 13 #Javascript
JavaScript Math对象和调试程序的方法分析
May 13 #Javascript
jsonp跨域获取百度联想词的方法分析
May 13 #Javascript
基于Fixed定位的框选功能的实现代码
May 13 #Javascript
JQuery事件委托原理与用法实例分析
May 13 #jQuery
You might like
用libtemplate实现静态网页生成
2006/10/09 PHP
php微信开发之带参数二维码的使用
2016/08/03 PHP
详解Yii2.0使用AR联表查询实例
2017/06/16 PHP
JavaScript 轻松搞定快捷留言功能 只需一行代码
2010/04/01 Javascript
Ajax中解析Json的两种方法对比分析
2015/06/25 Javascript
javascript随机抽取0-100之间不重复的10个数
2016/02/25 Javascript
使用getBoundingClientRect方法实现简洁的sticky组件的方法
2016/03/22 Javascript
JS获取IMG图片高宽的简单实例
2016/05/17 Javascript
JavaScript中的 attribute 和 jQuery中的 attr 方法浅析
2017/01/04 Javascript
vue.js动态数据绑定学习笔记
2017/05/19 Javascript
关于webpack代码拆分的解析
2017/07/20 Javascript
JavaScript数据类型的存储方法详解
2017/08/25 Javascript
AngularJS表单验证功能
2017/10/19 Javascript
vue中使用localstorage来存储页面信息
2017/11/04 Javascript
解决element-ui中下拉菜单子选项click事件不触发的问题
2018/08/22 Javascript
详解VUE调用本地json的使用方法
2019/05/15 Javascript
Postman如何实现参数化执行及断言处理
2020/07/28 Javascript
js轮播图之旋转木马效果
2020/10/13 Javascript
[01:19]DOTA2城市挑战赛报名开始 开启你的城市传奇
2018/03/23 DOTA
Python接收Gmail新邮件并发送到gtalk的方法
2015/03/10 Python
Python3处理文件中每个词的方法
2015/05/22 Python
Python调用adb命令实现对多台设备同时进行reboot的方法
2018/10/15 Python
Django用户认证系统 Web请求中的认证解析
2019/08/02 Python
python实现简单的购物程序代码实例
2020/03/03 Python
关于python 的legend图例,参数使用说明
2020/04/17 Python
Kmeans均值聚类算法原理以及Python如何实现
2020/09/26 Python
python 批量将中文名转换为拼音
2021/02/07 Python
利用Python如何画一颗心、小人发射爱心
2021/02/21 Python
CSS3 中filter(滤镜)属性使用详解
2020/04/07 HTML / CSS
Funko官方商店:源自美国,畅销全球搪胶收藏玩偶
2018/09/15 全球购物
杰夫·班克斯男士服装网上商店:Jeff Banks
2019/10/24 全球购物
工商企业管理专业自荐信范文
2014/04/12 职场文书
小学五年级学生评语
2014/04/22 职场文书
财务工作失职检讨书
2014/11/21 职场文书
2015暑期社会实践通讯稿
2015/07/18 职场文书
老干部局2015年度工作总结
2015/10/22 职场文书