SpringBoot通过Cors解决跨域问题(三十一)上

简介: SpringBoot通过Cors解决跨域问题(三十一)上

一. 跨域问题

一.一 浏览器的同源策略

同源策略是由 Netscape 提出的一个著名的安全策略,它是浏览器最核心也最基本的安全功能,

现在所有支持 JavaScript 的浏览器都会使用这个策略。


所谓同源是指协议、域名以及端口要相同。


同源策略是基于安全方面的考虑提出来的,这个策略本身没问题,但是我们在实际开发中,


由于各种原因又经常有跨域的需求,传统的跨域方案是 JSONP,JSONP 虽然能解决跨域但是有一个很大的局限性,

那就是只支持 GET 请求,


不支持其他类型的请求,而今天我们说的 CORS(跨域源资源共享)

(CORS,Cross-origin resource sharing)是一个 W3C 标准,


它是一份浏览器技术的规范,提供了 Web 服务从不同网域传来沙盒脚本的方法,以避开浏览器的同源策略,

这是 JSONP 模式的现代版。


一.二 验证同源策略,复现跨域问题

创建两个项目,一个是服务的提供者, SpringBoot_Cors_Provider (服务提供者),

SpringBoot_Cors_Consumer (服务的消费者),

这两个项目均是 SpringBoot整合Thymeleaf 的相关项目


一.二.一 服务提供者

端口号是 8081, 服务路径为: Cors_Provider


一.二.一.一 提供服务

@Controller
public class InfoController {
    /**
     * 跳转到主页
     * @param model
     * @return
     */
    @RequestMapping("/index")
    public String info(Model model){
        return "index";
    }
    @GetMapping("/findById")
    @ResponseBody
    public User findById(Integer id){
        User user=new User();
        user.setId(id);
        user.setName("两个蝴蝶飞");
        user.setDescription("Get 提交 跨域问题");
        return user;
    }
    @PostMapping("/addUser")
    @ResponseBody
    public User addUser(@RequestBody  User user){
        //补充信息
        user.setName("岳泽霖");
        user.setDescription("POST提交 跨域问题");
        return user;
    }
}


一.二.一.二 首页 index.html

<body class="container">
<!--展示信息-->
提供者: <p id="message" style="margin-top:200px;"></p>
<button type="button" class="btn btn-success" id="get_submit">Get获取信息</button>
<button type="button" class="btn btn-success" id="post_submit">Post获取信息</button>
<script type="text/javascript" src="webjars/jquery/3.5.1/jquery.js"></script>
<script type="text/javascript" src="webjars/bootstrap/3.4.1/js/bootstrap.js"></script>
<script>
   $(function(){
   })
   //get请求
   $("#get_submit").click(function(){
       $.ajax({
           async:false,
           type:"get",
           url:"findById?id=1",
           success:function(data){
               $("#message").text(
                   JSON.stringify(data)
               );
           }
       });
   });
   //post 请求
   $("#post_submit").click(function(){
       $.ajax({
           async:false,
           type:"post",
           url:"addUser",
           data:JSON.stringify({
               "id":2
           }),
           dataType:"json",
           contentType:"application/json;charset=utf-8",
           success:function(data){
               $("#message").text(
                   JSON.stringify(data)
               );
           }
       });
   });
</script>
</body>


一.二.一.三 服务提供者验证

get 请求

image.png



post 请求


image.png


一.二.二 服务消费者

端口号是 8082, 项目路径是 Cors_Consumer


只需要一个前端的静态页面 index.html 和 一个跳转方法即可。


一.二.二.一 controller层跳转

@Controller
public class InfoController {
    /**
     * 普通展示
     * @param model
     * @return
     */
    @RequestMapping("/index")
    public String info(Model model){
        return "index";
    }
}


一.二.二.二 首页 index.html

<body class="container">
<!--展示信息-->
消费者:  <p id="message" style="margin-top:200px;"></p>
<button type="button" class="btn btn-success" id="get_submit">Get获取信息</button>
<button type="button" class="btn btn-success" id="post_submit">Post获取信息</button>
<script type="text/javascript" src="webjars/jquery/3.5.1/jquery.js"></script>
<script type="text/javascript" src="webjars/bootstrap/3.4.1/js/bootstrap.js"></script>
<script>
   $(function(){
   })
   //get请求
   $("#get_submit").click(function(){
       $.ajax({
           async:false,
           type:"get",   //填写具体的路径
           url:"http://localhost:8081/Cors_Provider/findById?id=1",
           success:function(data){
               $("#message").text(
                   JSON.stringify(data)
               );
           }
       });
   });
   //post 请求
   $("#post_submit").click(function(){
       $.ajax({
           async:false,
           type:"post",  //填写具体的路径
           url:"http://localhost:8081/Cors_Provider/addUser",
           data:JSON.stringify({
               "id":2
           }),
           dataType:"json",
           contentType:"application/json;charset=utf-8",
           success:function(data){
               $("#message").text(
                   JSON.stringify(data)
               );
           }
       });
   });
</script>
</body>


一.二.二.三 跨域请求


image.png



CORS error

image.png



端口号不同,不属于同源,所以无法访问。


注意,是浏览器无法访问, 如果是用 Postman 的话,是可以正常请求通过的


如果是后端之间通过 RestTemplate, Feign 等相互调用,也是可以访问到的。


(所以,不要说,我接口 postman没有问题啊,你前端怎么访问不到呢)


相关文章
|
29天前
|
安全 API PHP
PHP中实现CORS跨域资源共享的方法
通过这种方式,你可以在PHP应用中灵活地实现CORS,以支持跨域Web应用的需求。
148 15
|
6月前
|
人工智能 前端开发 JavaScript
webpack-dev-server代理后端一直报CORS跨域或500错误
在Vue项目中使用Webpack的devServer代理后端接口时,遇到500错误。问题根源在于浏览器请求中携带的Origin头导致服务器报错,而Postman测试正常。通过分析发现,调整或移除Origin头可解决问题。解决办法包括:1) 在代理配置中添加正确的Origin头;2) 删除请求中的Origin头。文章还深入解析了Origin头的作用及changeOrigin配置的实际意义,并附带相关文档链接,帮助开发者更好地理解与解决类似跨域问题。
438 20
|
8月前
|
前端开发 JavaScript 应用服务中间件
前端跨域问题解决Access to XMLHttpRequest at xxx from has been blocked by CORS policy
跨域问题是前端开发中常见且棘手的问题,但通过理解CORS的工作原理并应用合适的解决方案,如服务器设置CORS头、使用JSONP、代理服务器、Nginx配置和浏览器插件,可以有效地解决这些问题。选择合适的方法可以确保应用的安全性和稳定性,并提升用户体验。
5410 90
|
8月前
|
JSON 缓存 前端开发
对CORS(跨域)的一些见解
CORS(跨域资源共享)是W3C标准,用于解决AJAX跨源请求限制。浏览器与服务器需共同支持CORS,浏览器自动处理请求头,开发者无需额外操作。CORS分为简单请求与非简单请求:简单请求满足特定条件(如方法为GET/POST/HEAD且头信息有限制),浏览器直接发送;非简单请求需先进行“预检”请求(OPTIONS方法),确认服务器允许后才发送实际请求。服务器回应需包含Access-Control-Allow-Origin等字段,以控制跨域访问权限。
208 10
|
12月前
|
JavaScript 前端开发 Java
springboot解决js前端跨域问题,javascript跨域问题解决
本文介绍了如何在Spring Boot项目中编写Filter过滤器以处理跨域问题,并通过一个示例展示了使用JavaScript进行跨域请求的方法。首先,在Spring Boot应用中添加一个实现了`Filter`接口的类,设置响应头允许所有来源的跨域请求。接着,通过一个简单的HTML页面和jQuery发送AJAX请求到指定URL,验证跨域请求是否成功。文中还提供了请求成功的响应数据样例及请求效果截图。
191 3
springboot解决js前端跨域问题,javascript跨域问题解决
|
12月前
|
前端开发 安全 Java
springboot解决跨域问题
跨域问题指前端调用与后端接口不在同一域名或端口时产生的安全限制。本文介绍两种在Spring Boot中解决跨域问题的方法:一是通过配置CorsFilter,二是实现WebMvcConfigurer接口。配置完成后重启项目即可生效。作者:博笙困了。来源:稀土掘金。
431 6
|
11月前
|
安全 Java 应用服务中间件
SpringBoot:CORS是什么?SpringBoot如何解决跨域问题?
CORS是Web开发中常见且重要的机制,SpringBoot通过提供注解、全局配置和过滤器等多种方式来解决跨域问题。选择适合的方式可以帮助开发者轻松处理跨域请求,提高应用的灵活性和安全性。
656 2
|
12月前
|
安全 JavaScript Java
SpringBoot解决跨域最佳实践
本文介绍了跨域问题的起因及最佳实践,重点讲解了SpringBoot中如何利用`CorsFilter`解决跨域问题。首先解释了由于浏览器的同源策略限制导致的跨域现象,然后提出了在服务端入口处解决跨域问题的建议,最后详细展示了三种SpringBoot中配置跨域的方法:使用默认配置、自定义配置规则以及通过配置文件管理跨域设置,以适应不同的应用场景。
579 5
SpringBoot通过Cors解决跨域问题(三十一)下
SpringBoot通过Cors解决跨域问题(三十一)下
268 0
SpringBoot通过Cors解决跨域问题(三十一)下
|
1月前
|
JavaScript Java 关系型数据库
基于springboot的项目管理系统
本文探讨项目管理系统在现代企业中的应用与实现,分析其研究背景、意义及现状,阐述基于SSM、Java、MySQL和Vue等技术构建系统的关键方法,展现其在提升管理效率、协同水平与风险管控方面的价值。