Parcourir la source

框架跨域配置

luojun il y a 2 ans
Parent
commit
452d9d6fb1

+ 57 - 0
soc-gateway/src/main/java/com/xunmei/gateway/config/CorsConfig.java

@@ -0,0 +1,57 @@
+package com.xunmei.gateway.config;
+
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+import org.springframework.http.HttpHeaders;
+import org.springframework.http.HttpMethod;
+import org.springframework.http.HttpStatus;
+import org.springframework.http.server.reactive.ServerHttpRequest;
+import org.springframework.http.server.reactive.ServerHttpResponse;
+import org.springframework.stereotype.Component;
+import org.springframework.web.cors.reactive.CorsUtils;
+import org.springframework.web.server.ServerWebExchange;
+import org.springframework.web.server.WebFilter;
+import org.springframework.web.server.WebFilterChain;
+import reactor.core.publisher.Mono;
+
+/**
+ * 跨域配置
+ *
+ * @author luojun
+ */
+@Component
+public class CorsConfig implements WebFilter
+{
+    /**
+     * 这里为支持的请求头,如果有自定义的header字段请自己添加
+     */
+    private static final String ALLOWED_HEADERS = "X-Requested-With, Content-Type, Authorization, credential, X-XSRF-TOKEN, token, Admin-Token, App-Token";
+    private static final String ALLOWED_METHODS = "GET,POST,PUT,DELETE,OPTIONS,HEAD";
+    private static final String ALLOWED_ORIGIN = "*";
+    private static final String ALLOWED_EXPOSE = "*";
+    private static final String MAX_AGE = "18000L";
+
+
+
+    @Override
+    public Mono<Void> filter(ServerWebExchange exchange, WebFilterChain chain) {
+        ServerHttpRequest request = exchange.getRequest();
+        if (CorsUtils.isCorsRequest(request)){
+            return chain.filter(exchange);
+
+        }
+        ServerHttpResponse response = exchange.getResponse();
+        HttpHeaders headers = response.getHeaders();
+        headers.add("Access-Control-Allow-Headers", ALLOWED_HEADERS);
+        headers.add("Access-Control-Allow-Methods", ALLOWED_METHODS);
+        headers.add("Access-Control-Allow-Origin", ALLOWED_ORIGIN);
+        headers.add("Access-Control-Max-Age", MAX_AGE);
+//        headers.add("Access-Control-Allow-Credentials", "true");
+        if (request.getMethod() == HttpMethod.OPTIONS)
+        {
+            response.setStatusCode(HttpStatus.OK);
+            return Mono.empty();
+        }
+        return chain.filter(exchange);
+    }
+}

+ 3 - 3
soc-modules/soc-modules-file/src/main/java/com/xunmei/file/config/ResourcesConfig.java

@@ -42,10 +42,10 @@ public class ResourcesConfig implements WebMvcConfigurer
     @Override
     public void addCorsMappings(CorsRegistry registry) {
         // 设置允许跨域的路由
-        registry.addMapping(localFilePrefix  + "/**")
+        registry.addMapping( "/**")
                 // 设置允许跨域请求的域名
-                .allowedOrigins("*")
+                .allowedOriginPatterns("*")
                 // 设置允许的方法
-                .allowedMethods("GET");
+                .allowedMethods ("GET","POST");
     }
 }

+ 2 - 0
soc-modules/soc-modules-system/src/main/java/com/xunmei/system/service/impl/SysOrgServiceImpl.java

@@ -37,6 +37,8 @@ public class SysOrgServiceImpl extends ServiceImpl<SysOrgMapper, SysOrg> impleme
         TableDataInfo rspData = new TableDataInfo();
         rspData.setRows(list.getRecords());
         rspData.setTotal(list.getTotal());
+        rspData.setCode(200);
+        rspData.setMsg("查询成功");
         return rspData;
 
     }