• SpringBoot使用Cors解决跨域


    CORS是一个W3C标准,全称是"跨域资源共享"(Cross-origin resource sharing)。

    它允许浏览器向跨源服务器,发出XMLHttpRequest请求,从而克服了AJAX只能同源使用的限制。

    CORS需要浏览器和服务器同时支持。目前,所有浏览器都支持该功能,IE浏览器不能低于IE10。

    • 浏览器端:

      目前,所有浏览器都支持该功能(IE10以下不行)。整个CORS通信过程,都是浏览器自动完成,不需要用户参与。

    • 服务端:

      CORS通信与AJAX没有任何差别,因此你不需要改变以前的业务逻辑。只不过,浏览器会在请求中携带一些头信息,我们需要以此判断是否允许其跨域,然后在响应头中加入一些信息即可。这一般通过过滤器完成即可。

    SpringMVC提供了CorsFilter过滤器来解决Ajax跨域!!!!

    使用方法是编写一个配置类

    package com.gateway.config;
    
    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;
    
    /**
     *Cors解决跨域问题
     */
    @Configuration
    public class CorsConfiguration {
        @Bean
        public CorsFilter corsFilter(){
            //初始化Cors配置对象
            CorsConfiguration corsConfiguration = new CorsConfiguration();
            //允许跨域域名,如果携带Cookie不可以写*
            corsConfiguration.addAllowedOrigin("http://manage.leyou.com");
            //允许携带cookie
            corsConfiguration.setAllowCredentials(true);
            //设置允许请求方式,*代表所有的请求方法包括GETPOSTPUTDELETE
            corsConfiguration.addAllowedMethod("*");
            //允许携带头信息,*允许携带任何头信息
            corsConfiguration.addAllowedHeader("*");
            //初始化Cors数据源对象
            UrlBasedCorsConfigurationSource configurationSource = new UrlBasedCorsConfigurationSource();
            configurationSource.registerCorsConfiguration("/**",corsConfiguration);
    
            //返回cors实例,需要一个Cors配置源对象
            return new CorsFilter(configurationSource);
        }
    }
  • 相关阅读:
    NPS之Socks流量分析以及未授权复现
    某OA系统审计小记
    记一次MCMS的审计之路
    Eoffice Server_v9.0 漏洞分析
    goahead环境变量注入漏洞分析
    Java反序列化之原生
    ThinkPHP6.0.13反序列化漏洞分析
    Docker
    Mybatisplus进阶
    软件项目文档
  • 原文地址:https://www.cnblogs.com/sheng-se/p/14145559.html
Copyright © 2020-2023  润新知