博客
关于我
springboot解决前后端交互跨域问题
阅读量:332 次
发布时间:2019-03-04

本文共 793 字,大约阅读时间需要 2 分钟。

问题描述

在前后端分离项目中,由于前端要接收后端接口返回的数据而产生的错误信息(跨域问题)。

错误信息

Access to XMLHttpRequest at 'http://localhost:8090/user/getotp' from origin 'null' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.

解决方法

后端:

  1. 在对象的Controller类上加上注解@CrossOrigin。
@CrossOrigin(originPatterns = "*",allowCredentials = "true",allowedHeaders = "*")
  1. 前端数据交互部分要加上以下内容:
 xhrFields:{   withCredentials:true}

你可能会遇到如下问题:
  前后端设置的都没问题了,但是设置在session域中的值,还是不能进行跨域访问。
跨域问题解决方案,有问题的童鞋看过来。
  google配置后仍然无法正确获取otpcode。由于谷歌浏览器的SameSite安全机制的问题,浏览器在跨域的时候不允许request请求携带cookie,导致每次sessionId都是新的,这里有个出问题前提:跨域,刚好和调试时的环境情况一致。浏览器版本chrome84.0.4147.135(谷歌游览器好像从80版本之后就加入了SameSite安全机制),直接在地址栏里输入chrome://flags/,然后在搜索框里搜索关键字SameSite,找到与之匹配的项SameSite by default cookies,将其设置为Disabled,然后关闭浏览器再打开,请求。

转载地址:http://ruve.baihongyu.com/

你可能感兴趣的文章
Ubuntu安装TensorFlow C++
查看>>
win10正版系统安装 win10系统启动盘制作 小白装机第一步(U盘装机)
查看>>
VL53L0x TOF激光测距的 stm32 HAL库驱动代码
查看>>
怎么玩LOG4J
查看>>
Oracle创建用户,分配表空间
查看>>
自定义标签(JSP2.0)简单标签
查看>>
MyBatis自定义类型转换器
查看>>
机器学习(湖北师范大学教程)-极大似然估计算法
查看>>
2019年下半年总结
查看>>
读《红楼梦》有感
查看>>
【C# 重构】—参数化查询, 需要参数,但未提供该参数
查看>>
决策树(二)—— ID3和C4.5
查看>>
leetcode做题记录0059
查看>>
leetcode做题记录0062
查看>>
Leetcode每日随机2021/4/26
查看>>
Leetcode每日随机2021/4/29
查看>>
Java集合框架 List集合、Set集合、Map集合 学习泛型与包装类的装箱拆箱
查看>>
MySQL~教你满分回答什么是数据库索引? 索引的数据结构是什么? 什么是事务?
查看>>
操作系统~进程的状态、转换、控制
查看>>
操作系统~线程概念以及多线程模型
查看>>