在Linux系统中,处理Swagger(现更名为OpenAPI)跨域问题的方法有以下几种:
如果你使用的是Spring Boot作为后端框架,可以通过配置CORS(跨域资源共享)来解决Swagger的跨域问题。
全局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);
}
}
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配置中添加CORS相关的头信息。
编辑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;
}
}
重启Nginx: 保存配置文件后,重启Nginx以应用更改。
sudo systemctl restart nginx
如果你使用的是其他框架或自定义过滤器,可以在应用中添加一个CORS过滤器。
创建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() {
}
}
注册过滤器: 在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系统中的跨域问题。选择适合你项目的方法进行配置即可。