• 解决跨域访问


    解决跨域访问:
    (1)nginx配置: (不同服务器站点之间失效)

    add_header Access-Control-Allow-Origin *;

    add_header Access-Control-Allow-Headers X-Requested-With;

    add_header Access-Control-Allow-Methods GET,POST,OPTIONS;

    (2)在拦截器中加入:(均可)
    response.setHeader("Access-Control-Allow-Origin", "*");
    response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE");
    response.setHeader("Access-Control-Max-Age", "3600");
    response.setHeader("Access-Control-Allow-Headers", "x-requested-with");

    (3)controller加入注解:Controller上使用@CrossOrigin注解
    Spring MVC 从4.2版本开始增加了对CORS的支持
    在spring MVC 中增加CORS支持非常简单,可以配置全局的规则,也可以使用@CrossOrigin注解进行细粒度的配置。
    使用@CrossOrigin注解
    先通过源码看看该注解支持的属性:
    在Controller上使用@CrossOrigin注解
    @CrossOrigin(origins = "*", maxAge = 3600)
    @RestController
    @RequestMapping("/account")
    public class AccountController {

    @RequestMapping("/{id}")
    public Account retrieve(@PathVariable Long id) {
        // ...
    }
    
    @RequestMapping(method = RequestMethod.DELETE, path = "/{id}")
    public void remove(@PathVariable Long id) {
        // ...
    }
    

    }
    这里指定当前的AccountController中所有的方法可以处理所有域上的请求,
    在方法上使用@CrossOrigin注解
    @CrossOrigin(maxAge = 3600)
    @RestController
    @RequestMapping("/account")
    public class AccountController {

    @CrossOrigin("http://domain2.com")
    @RequestMapping("/{id}")
    public Account retrieve(@PathVariable Long id) {
        // ...
    }
    
    @RequestMapping(method = RequestMethod.DELETE, path = "/{id}")
    public void remove(@PathVariable Long id) {
        // ...
    }
    

    }
    在这个例子中,AccountController类上也有@CrossOrigin注解,retrieve方法上也有注解,Spring会合并两个注解的属性一起使用。
    CORS全局配置
    除了细粒度基于注解的配置,你可能会想定义一些全局CORS的配置。这类似于使用过滤器,但可以在Spring MVC中声明,并结合细粒度@CrossOrigin配置。默认情况下所有的域名和GET、HEAD和POST方法都是允许的。
    基于JAVA的配置
    看下面例子:
    @Configuration
    public class WebConfig extends WebMvcConfigurerAdapter {

    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**");
    }
    

    }
    您可以轻松地更改任何属性,以及配置适用于特定的路径模式的CORS:
    如果你使用Spring Boot,你可以通过这种方式方便的进行配置。
    @Configuration
    public class WebConfig extends WebMvcConfigurerAdapter {

    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/api/**")
            .allowedOrigins("http://domain2.com")
            .allowedMethods("PUT", "DELETE")
            .allowedHeaders("header1", "header2", "header3")
            .exposedHeaders("header1", "header2")
            .allowCredentials(false).maxAge(3600);
    }
    

    }
    不限制任何请求(方便复制粘贴)
    @Configuration
    public class CorsConfig extends WebMvcConfigurerAdapter {
    @Override
    public void addCorsMappings(CorsRegistry registry) {
    registry.addMapping("/**")
    .allowedOrigins("*")
    .allowedMethods("GET", "HEAD", "POST", "PUT", "PATCH", "DELETE", "OPTIONS", "TRACE");
    }
    }

    基于XML的配置
    mvc:cors
    <mvc:mapping path="/**" />
    </mvc:cors>
    这个配置和上面Java方式的第一种作用一样。
    同样,你可以做更复杂的配置:
    mvc:cors

    <mvc:mapping path="/api/**"
        allowed-origins="http://domain1.com, http://domain2.com"
        allowed-methods="GET, PUT"
        allowed-headers="header1, header2, header3"
        exposed-headers="header1, header2" allow-credentials="false"
        max-age="123" />
    
    <mvc:mapping path="/resources/**"
        allowed-origins="http://domain1.com" />
    

    </mvc:cors>

  • 相关阅读:
    aspectj this target within 区别
    window 启用telnet 方法 和基本使用
    spring aspectj 切入点表达式详解
    foreach 和 数据库批量执行 效率比较
    零拷贝
    JDK 动态代理 和 cgLib动态代理
    类和类之间的6种关系
    easyExcel 比poi 更加简单的 excel 解析工具
    spring生命周期监听接口概述
    raspberry的64bit img下载
  • 原文地址:https://www.cnblogs.com/kevinzhwl/p/6119235.html
Copyright © 2020-2023  润新知