linux

Linux系统中Swagger如何处理跨域问题

小樊
42
2025-11-16 08:31:01
栏目: 智能运维

在Linux系统中,处理Swagger(现更名为OpenAPI)跨域问题的方法有以下几种:

方法一:使用Spring Boot的CORS配置

如果你使用的是Spring Boot作为后端框架,可以通过配置CORS(跨域资源共享)来解决Swagger的跨域问题。

  1. 全局CORS配置: 在Spring Boot应用中,你可以创建一个配置类来全局配置CORS。

    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.web.servlet.config.annotation.CorsRegistry;
    import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
    
    @Configuration
    public class WebConfig implements WebMvcConfigurer {
    
        @Override
        public void addCorsMappings(CorsRegistry registry) {
            registry.addMapping("/**")
                    .allowedOrigins("*") // 允许所有来源
                    .allowedMethods("GET", "POST", "PUT", "DELETE", "OPTIONS")
                    .allowedHeaders("*")
                    .allowCredentials(true);
        }
    }
    
  2. Swagger配置: 确保你的Swagger配置没有覆盖或禁用CORS设置。

    import springfox.documentation.builders.PathSelectors;
    import springfox.documentation.builders.RequestHandlerSelectors;
    import springfox.documentation.spi.DocumentationType;
    import springfox.documentation.spring.web.plugins.Docket;
    import springfox.documentation.swagger2.annotations.EnableSwagger2;
    
    @Configuration
    @EnableSwagger2
    public class SwaggerConfig {
    
        @Bean
        public Docket api() {
            return new Docket(DocumentationType.SWAGGER_2)
                    .select()
                    .apis(RequestHandlerSelectors.basePackage("com.example.demo"))
                    .paths(PathSelectors.any())
                    .build();
        }
    }
    

方法二:使用Nginx反向代理

如果你使用Nginx作为反向代理服务器,可以在Nginx配置中添加CORS相关的头信息。

  1. 编辑Nginx配置文件: 打开你的Nginx配置文件(通常位于/etc/nginx/nginx.conf/etc/nginx/sites-available/default)。

    server {
        listen 80;
        server_name yourdomain.com;
    
        location /swagger-ui.html {
            proxy_pass http://localhost:8080; # 你的Spring Boot应用地址
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Proto $scheme;
    
            add_header 'Access-Control-Allow-Origin' '*' always;
            add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS, PUT, DELETE' always;
            add_header 'Access-Control-Allow-Headers' 'Origin, X-Requested-With, Content-Type, Accept, Authorization' always;
        }
    
        location /v2/api-docs {
            proxy_pass http://localhost:8080; # 你的Spring Boot应用地址
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Proto $scheme;
    
            add_header 'Access-Control-Allow-Origin' '*' always;
            add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS, PUT, DELETE' always;
            add_header 'Access-Control-Allow-Headers' 'Origin, X-Requested-With, Content-Type, Accept, Authorization' always;
        }
    }
    
  2. 重启Nginx: 保存配置文件后,重启Nginx以应用更改。

    sudo systemctl restart nginx
    

方法三:使用CORS过滤器

如果你使用的是其他框架或自定义过滤器,可以在应用中添加一个CORS过滤器。

  1. 创建CORS过滤器: 创建一个实现javax.servlet.Filter接口的类。

    import javax.servlet.Filter;
    import javax.servlet.FilterChain;
    import javax.servlet.FilterConfig;
    import javax.servlet.ServletException;
    import javax.servlet.ServletRequest;
    import javax.servlet.ServletResponse;
    import javax.servlet.http.HttpServletResponse;
    import java.io.IOException;
    
    public class SimpleCORSFilter implements Filter {
    
        @Override
        public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {
            HttpServletResponse response = (HttpServletResponse) res;
            response.setHeader("Access-Control-Allow-Origin", "*");
            response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE, PUT");
            response.setHeader("Access-Control-Max-Age", "3600");
            response.setHeader("Access-Control-Allow-Headers", "Content-Type, Authorization, X-Requested-With");
            chain.doFilter(req, res);
        }
    
        @Override
        public void init(FilterConfig filterConfig) {
        }
    
        @Override
        public void destroy() {
        }
    }
    
  2. 注册过滤器: 在Spring Boot应用中注册过滤器。

    import org.springframework.boot.web.servlet.FilterRegistrationBean;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    
    @Configuration
    public class WebConfig {
    
        @Bean
        public FilterRegistrationBean<SimpleCORSFilter> simpleCORSFilter() {
            FilterRegistrationBean<SimpleCORSFilter> registrationBean = new FilterRegistrationBean<>();
            registrationBean.setFilter(new SimpleCORSFilter());
            registrationBean.addUrlPatterns("/*");
            return registrationBean;
        }
    }
    

通过以上方法之一,你应该能够解决Swagger在Linux系统中的跨域问题。选择适合你项目的方法进行配置即可。

0
看了该问题的人还看了