【Java专题_03】spring-boot跨域问题如何解决

简介: 【Java专题_03】spring-boot跨域问题如何解决

一、什么是跨域?

1、域:协议 + 域名 + 端口;三者完全相同则为同域,反之有其一不同均为不同域。
         
   2、跨域请求:当前【发起请求】的域和【请求指向】的域属于不同域时,该次请求称之为跨域请求。
   
   3、同源限制:浏览器针对跨域请求做出同源限制资源访问,Cookie、LocalStorage 和 IndexDB 无法跨域问;
    
   4、DOM元素无法跨域访问;Ajax无法跨域请求。

二、跨域请求被谁拦截?

test.html代码如下:

<!DOCTYPE html>
<html>
<head>
  <title>使用ajax发送请求</title>
  <!-- 引入jq需要的js,可以上jq菜鸟教程里面复制这个js,是在线的,联网即可用 -->
  <script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js">
</script>
<script>
$(document).ready(function(){
     $("#send").click(function(){
              $.ajax({
                        url: "http://localhost:8080/user/getUser",
                        type: "GET",
                        success: function (result) {
                            console.log(result);
                        }
                    });
        })
       
});
</script>
</head>
<body>
  <button id="send">发送请求</button>
</body>
</html>

1、 看上面的图,我们可以看到当前台发送请求时,可以看到后台并没有拦截,只是在数据返回前台的时候出问题。
 
 2、总结:域名和端口不同时的跨域,并非浏览器拦截发起请求,实际请求可以正常到达指向的资源,也可以正常返回,只       是浏览器拦截了返回内容。协议不同时,例如https发起Ajax跨域请求到http,则部分浏览器(Chrome,Firefox)会直接拦截请求,请求无法到达指向的资源。

三、解决办法:

1、创建一个全局配置类:CorsConfig.java(工程目录如下:)

CorsConfig.java代码如下:

package com.xsy.Configuration;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.cors.CorsConfiguration;
import org.springframework.web.cors.UrlBasedCorsConfigurationSource;
import org.springframework.web.filter.CorsFilter;
@Configuration
public class CorsConfig {
    @Bean
    public CorsConfiguration corsConfiguration() {
        CorsConfiguration corsConfiguration = new CorsConfiguration();
        //实际请求中允许携带的首部字段
        corsConfiguration.addAllowedHeader("*");
        //允许那些域跨域访问
        corsConfiguration.addAllowedOrigin("*");
        //允许那些请求方法
        corsConfiguration.addAllowedMethod("*");
        return corsConfiguration;
    }
    @Bean
    public CorsFilter corsFilter(CorsConfiguration corsConfiguration) {
        UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
        source.registerCorsConfiguration("/**", corsConfiguration); 
        return new CorsFilter(source);
    }
}

此时可以看到已经可以访问到数据了

四、小提示

1、如果只是个别方法需要跨域访问的话,可以使用  @CrossOrigin(origin="*")来进行跨越:
使用如下:
在方法级别上只需要加上@CrossOrigin(origin="*")再次跨域请求即可正常访问:

相关文章
|
14天前
|
安全 Java 开发者
使用Spring Boot简化Java应用开发
【5月更文挑战第22天】Spring Boot简化Java应用开发,基于Spring框架,提供自动化配置、内置功能组件和微服务支持。通过Spring Initializr快速创建项目,选择依赖并生成代码。开发时,利用其内嵌Web服务器、日志及监控功能。打包后,可独立运行或部署,无需额外容器。掌握Spring Boot对Java开发者至关重要。
|
19天前
|
Java 数据库连接 数据库
spring--为web(1),富士康java面试题整理
spring--为web(1),富士康java面试题整理
|
21天前
|
Java 数据安全/隐私保护 Spring
Java 中 Spring Boot 框架下的 Email 开发
Java 中 Spring Boot 框架下的 Email 开发
272 2
|
21天前
|
前端开发 Java 测试技术
Java一分钟之Spring MVC:构建Web应用
【5月更文挑战第15天】Spring MVC是Spring框架的Web应用模块,基于MVC模式实现业务、数据和UI解耦。常见问题包括:配置DispatcherServlet、Controller映射错误、视图解析未设置、Model数据传递遗漏、异常处理未配置、依赖注入缺失和忽视单元测试。解决这些问题可提升代码质量和应用性能。注意配置`web.xml`、`@RequestMapping`、`ViewResolver`、`Model`、`@ExceptionHandler`、`@Autowired`,并编写测试用例。
307 3
|
9天前
|
存储 Java 对象存储
<Java EE 进阶> 3.Spring简单的读和取
<Java EE 进阶> 3.Spring简单的读和取
23 1
|
9天前
|
存储 Java Maven
<Java EE 进阶> 2.Spring 创建和使用
<Java EE 进阶> 2.Spring 创建和使用
16 0
|
9天前
|
存储 Java Spring
<Java EE 进阶> 1.Spring核心思想
<Java EE 进阶> 1.Spring核心思想
12 0
|
10天前
|
Java API 网络架构
利用Java Spring Boot构建微服务架构的实践探索
随着业务复杂性的增长和互联网技术的飞速发展,微服务架构已成为现代软件开发中不可或缺的一部分。本文旨在探讨如何利用Java Spring Boot框架构建微服务架构,包括微服务的定义、优势,以及通过实际案例展示如何设计、开发和部署微服务。我们将关注服务拆分、服务间通信、数据一致性、服务治理等核心问题,并探讨如何结合Spring Cloud生态中的组件来实现高效、可靠的微服务架构。
|
16天前
|
JSON 安全 前端开发
跨域详解及Spring Boot 3中的跨域解决方案
本文介绍了Web开发中的跨域问题,包括概念、原因、影响以及在Spring Boot 3中的解决方案。跨域是由浏览器的同源策略限制引起的,阻碍了不同源之间的数据传输。解决方法包括CORS、JSONP和代理服务器。在Spring Boot 3中,可以通过配置CorsFilter来允许跨域请求,实现前后端分离项目的正常运行。
69 3
 跨域详解及Spring Boot 3中的跨域解决方案
|
19天前
|
安全 Java 数据库
Spring boot 入门教程-Oauth2,java面试基础题核心
Spring boot 入门教程-Oauth2,java面试基础题核心