16 changed files with 8 additions and 1256 deletions
@ -0,0 +1,3 @@ |
|||||
|
[submodule "esua-epdc/epdc-cloud-gateway-shibei"] |
||||
|
path = esua-epdc/epdc-cloud-gateway-shibei |
||||
|
url = http://121.42.41.42:7070/r/epdc-cloud-gateway-shibei.git |
||||
@ -0,0 +1 @@ |
|||||
|
Subproject commit 806c6babd7c227a660c490cc7c1eb56015f5baa4 |
||||
@ -1,20 +0,0 @@ |
|||||
# 基础镜像 |
|
||||
FROM openjdk:8u242-jdk-buster |
|
||||
# 作者 |
|
||||
MAINTAINER rongchao@elink-cn.com |
|
||||
# 对应pom.xml文件中的dockerfile-maven-plugin插件JAR_FILE的值 |
|
||||
ARG JAR_FILE |
|
||||
# 对应pom.xml文件中的dockerfile-maven-plugin插件JAR_NAME的值 |
|
||||
ARG JAR_NAME |
|
||||
# 对应pom.xml文件中的dockerfile-maven-plugin插件SERVER_PORT的值 |
|
||||
ARG SERVER_PORT |
|
||||
# 复制打包完成后的jar文件到/opt目录下 |
|
||||
ENV JAR_PATH /mnt/epdc/${JAR_NAME}.jar |
|
||||
ADD ${JAR_FILE} $JAR_PATH |
|
||||
# /data设为环境变量 |
|
||||
ENV DATAPATH /data |
|
||||
# 挂载/data目录到主机 |
|
||||
VOLUME $DATAPATH |
|
||||
# 启动容器时执行 |
|
||||
ENTRYPOINT java -jar -Xmx1024m $JAR_PATH |
|
||||
EXPOSE ${SERVER_PORT} |
|
||||
@ -1,260 +0,0 @@ |
|||||
<?xml version="1.0" encoding="UTF-8"?> |
|
||||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" |
|
||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> |
|
||||
<modelVersion>4.0.0</modelVersion> |
|
||||
|
|
||||
<parent> |
|
||||
<groupId>com.esua.epdc</groupId> |
|
||||
<artifactId>esua-epdc</artifactId> |
|
||||
<version>1.0.0</version> |
|
||||
</parent> |
|
||||
|
|
||||
<artifactId>epdc-gateway</artifactId> |
|
||||
<packaging>jar</packaging> |
|
||||
|
|
||||
<dependencies> |
|
||||
<dependency> |
|
||||
<groupId>com.esua.epdc</groupId> |
|
||||
<artifactId>epdc-commons-tools</artifactId> |
|
||||
<version>1.0.0</version> |
|
||||
</dependency> |
|
||||
<dependency> |
|
||||
<groupId>org.springframework.cloud</groupId> |
|
||||
<artifactId>spring-cloud-starter-gateway</artifactId> |
|
||||
</dependency> |
|
||||
<dependency> |
|
||||
<groupId>com.alibaba.cloud</groupId> |
|
||||
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> |
|
||||
</dependency> |
|
||||
<dependency> |
|
||||
<groupId>org.springframework.cloud</groupId> |
|
||||
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId> |
|
||||
</dependency> |
|
||||
<dependency> |
|
||||
<groupId>de.codecentric</groupId> |
|
||||
<artifactId>spring-boot-admin-starter-client</artifactId> |
|
||||
<version>${spring.boot.admin.version}</version> |
|
||||
</dependency> |
|
||||
<!-- zipkin client --> |
|
||||
<dependency> |
|
||||
<groupId>org.springframework.cloud</groupId> |
|
||||
<artifactId>spring-cloud-starter-zipkin</artifactId> |
|
||||
</dependency> |
|
||||
<dependency> |
|
||||
<groupId>com.esua.epdc</groupId> |
|
||||
<artifactId>epdc-common-clienttoken</artifactId> |
|
||||
<version>1.0.0</version> |
|
||||
<scope>compile</scope> |
|
||||
</dependency> |
|
||||
|
|
||||
<dependency> |
|
||||
<groupId>com.esua.epdc</groupId> |
|
||||
<artifactId>epdc-common-clienttoken</artifactId> |
|
||||
<version>1.0.0</version> |
|
||||
</dependency> |
|
||||
</dependencies> |
|
||||
|
|
||||
<build> |
|
||||
<finalName>${project.artifactId}</finalName> |
|
||||
<plugins> |
|
||||
<plugin> |
|
||||
<groupId>org.springframework.boot</groupId> |
|
||||
<artifactId>spring-boot-maven-plugin</artifactId> |
|
||||
</plugin> |
|
||||
<plugin> |
|
||||
<groupId>org.apache.maven.plugins</groupId> |
|
||||
<artifactId>maven-surefire-plugin</artifactId> |
|
||||
<configuration> |
|
||||
<skipTests>true</skipTests> |
|
||||
</configuration> |
|
||||
</plugin> |
|
||||
<plugin> |
|
||||
<groupId>org.apache.maven.plugins</groupId> |
|
||||
<artifactId>maven-deploy-plugin</artifactId> |
|
||||
<configuration> |
|
||||
<skip>true</skip> |
|
||||
</configuration> |
|
||||
</plugin> |
|
||||
<plugin> |
|
||||
<groupId>com.spotify</groupId> |
|
||||
<artifactId>dockerfile-maven-plugin</artifactId> |
|
||||
</plugin> |
|
||||
</plugins> |
|
||||
</build> |
|
||||
|
|
||||
<profiles> |
|
||||
<profile> |
|
||||
<id>dev</id> |
|
||||
<activation> |
|
||||
<activeByDefault>true</activeByDefault> |
|
||||
</activation> |
|
||||
<properties> |
|
||||
<server.port>9094</server.port> |
|
||||
<spring.profiles.active>dev</spring.profiles.active> |
|
||||
<docker.tag>dev</docker.tag> |
|
||||
|
|
||||
<!-- redis配置 --> |
|
||||
<spring.redis.index>2</spring.redis.index> |
|
||||
<spring.redis.host>47.104.224.45</spring.redis.host> |
|
||||
<spring.redis.port>6379</spring.redis.port> |
|
||||
<spring.redis.password>elink@888</spring.redis.password> |
|
||||
|
|
||||
<!-- gateway routes --> |
|
||||
<gateway.routes.epdc-auth-server.uri>lb://epdc-auth-server</gateway.routes.epdc-auth-server.uri> |
|
||||
<gateway.routes.epdc-admin-server.uri>lb://epdc-admin-server</gateway.routes.epdc-admin-server.uri> |
|
||||
<!-- <gateway.routes.epdc-admin-server.uri>http://127.0.0.1:9092</gateway.routes.epdc-admin-server.uri>--> |
|
||||
<gateway.routes.epdc-activiti-server.uri>lb://epdc-activiti-server |
|
||||
</gateway.routes.epdc-activiti-server.uri> |
|
||||
<!--<gateway.routes.epdc-api-server.uri>lb://epdc-api-server</gateway.routes.epdc-api-server.uri>--> |
|
||||
<gateway.routes.epdc-api-server.uri>http://127.0.0.1:9040</gateway.routes.epdc-api-server.uri> |
|
||||
<gateway.routes.epdc-app-server.uri>lb://epdc-app-server</gateway.routes.epdc-app-server.uri> |
|
||||
<!-- <gateway.routes.epdc-app-server.uri>http://127.0.0.1:9058</gateway.routes.epdc-app-server.uri>--> |
|
||||
<gateway.routes.epdc-heart-server.uri>lb://epdc-heart-server</gateway.routes.epdc-heart-server.uri> |
|
||||
<!-- <gateway.routes.epdc-heart-server.uri>http://127.0.0.1:9060</gateway.routes.epdc-heart-server.uri>--> |
|
||||
<gateway.routes.epdc-job-server.uri>lb://epdc-job-server</gateway.routes.epdc-job-server.uri> |
|
||||
<!-- <gateway.routes.epdc-job-server.uri>http://127.0.0.1:9061</gateway.routes.epdc-job-server.uri>--> |
|
||||
<gateway.routes.epdc-message-server.uri>lb://epdc-message-server |
|
||||
</gateway.routes.epdc-message-server.uri> |
|
||||
<!--<gateway.routes.epdc-news-server.uri>lb://epdc-news-server</gateway.routes.epdc-news-server.uri>--> |
|
||||
<gateway.routes.epdc-news-server.uri>http://127.0.0.1:9064</gateway.routes.epdc-news-server.uri> |
|
||||
<gateway.routes.epdc-oss-server.uri>lb://epdc-oss-server</gateway.routes.epdc-oss-server.uri> |
|
||||
<gateway.routes.epdc-events-server.uri>lb://epdc-events-server</gateway.routes.epdc-events-server.uri> |
|
||||
<!-- <gateway.routes.epdc-events-server.uri>http://127.0.0.1:9066</gateway.routes.epdc-events-server.uri>--> |
|
||||
<gateway.routes.epdc-cloud-analysis-server.uri>http://127.0.0.1:9060 |
|
||||
</gateway.routes.epdc-cloud-analysis-server.uri> |
|
||||
<!-- <gateway.routes.epdc-cloud-analysis-server.uri>lb://epdc-cloud-analysis-server</gateway.routes.epdc-cloud-analysis-server.uri>--> |
|
||||
<gateway.routes.epdc-work-record-server.uri>http://127.0.0.1:9085 |
|
||||
</gateway.routes.epdc-work-record-server.uri> |
|
||||
<!-- <gateway.routes.epdc-work-record-server.uri>lb://epdc-work-record-server</gateway.routes.epdc-work-record-server.uri>--> |
|
||||
<gateway.routes.epdc-services-server.uri>lb://epdc-services-server |
|
||||
</gateway.routes.epdc-services-server.uri> |
|
||||
<!-- <gateway.routes.epdc-services-server.uri>http://127.0.0.1:9067</gateway.routes.epdc-services-server.uri>--> |
|
||||
<!--<gateway.routes.epdc-user-server.uri>lb://epdc-user-server</gateway.routes.epdc-user-server.uri>--> |
|
||||
<gateway.routes.epdc-user-server.uri>http://127.0.0.1:9068</gateway.routes.epdc-user-server.uri> |
|
||||
<gateway.routes.epdc-demo-server.uri>lb://epdc-demo-server</gateway.routes.epdc-demo-server.uri> |
|
||||
<gateway.routes.epdc-group-server.uri>http://127.0.0.1:9063</gateway.routes.epdc-group-server.uri> |
|
||||
<!--<gateway.routes.epdc-group-server.uri>lb://epdc-group-server</gateway.routes.epdc-group-server.uri>--> |
|
||||
<gateway.routes.epdc-websocket-server.uri>lb://epdc-websocket-server |
|
||||
</gateway.routes.epdc-websocket-server.uri> |
|
||||
<!-- <gateway.routes.epdc-custom-server.uri>http://127.0.0.1:9076</gateway.routes.epdc-kpi-server.uri>--> |
|
||||
<gateway.routes.epdc-custom-server.uri>lb://epdc-custom-server</gateway.routes.epdc-custom-server.uri> |
|
||||
<gateway.routes.epdc-points-server.uri>lb://epdc-points-server</gateway.routes.epdc-points-server.uri> |
|
||||
<!-- <gateway.routes.epdc-kpi-server.uri>lb://epdc-kpi-server</gateway.routes.epdc-kpi-server.uri>--> |
|
||||
<gateway.routes.epdc-kpi-server.uri>http://127.0.0.1:9069</gateway.routes.epdc-kpi-server.uri> |
|
||||
<!-- nacos --> |
|
||||
<nacos.register-enabled>false</nacos.register-enabled> |
|
||||
<nacos.server-addr>47.104.224.45:8848</nacos.server-addr> |
|
||||
<nacos.ip></nacos.ip> |
|
||||
<nacos.namespace>6a3577b4-7b79-43f6-aebb-9c3f31263f6a</nacos.namespace> |
|
||||
|
|
||||
<spring.zipkin.base-url>http://localhost:9411</spring.zipkin.base-url> |
|
||||
</properties> |
|
||||
</profile> |
|
||||
<profile> |
|
||||
<id>test</id> |
|
||||
<properties> |
|
||||
<server.port>10000</server.port> |
|
||||
<spring.profiles.active>test</spring.profiles.active> |
|
||||
<docker.tag>test</docker.tag> |
|
||||
|
|
||||
<!-- redis配置 --> |
|
||||
<spring.redis.index>2</spring.redis.index> |
|
||||
<spring.redis.host>114.215.125.123</spring.redis.host> |
|
||||
<spring.redis.port>9603</spring.redis.port> |
|
||||
<spring.redis.password>epdc!redis@master1405</spring.redis.password> |
|
||||
|
|
||||
<!-- gateway routes --> |
|
||||
<gateway.routes.epdc-auth-server.uri>lb://epdc-auth-server</gateway.routes.epdc-auth-server.uri> |
|
||||
<gateway.routes.epdc-admin-server.uri>lb://epdc-admin-server</gateway.routes.epdc-admin-server.uri> |
|
||||
<gateway.routes.epdc-activiti-server.uri>lb://epdc-activiti-server |
|
||||
</gateway.routes.epdc-activiti-server.uri> |
|
||||
<gateway.routes.epdc-api-server.uri>lb://epdc-api-server</gateway.routes.epdc-api-server.uri> |
|
||||
<gateway.routes.epdc-app-server.uri>lb://epdc-app-server</gateway.routes.epdc-app-server.uri> |
|
||||
<gateway.routes.epdc-heart-server.uri>lb://epdc-heart-server</gateway.routes.epdc-heart-server.uri> |
|
||||
<gateway.routes.epdc-job-server.uri>lb://epdc-job-server</gateway.routes.epdc-job-server.uri> |
|
||||
<gateway.routes.epdc-message-server.uri>lb://epdc-message-server |
|
||||
</gateway.routes.epdc-message-server.uri> |
|
||||
<gateway.routes.epdc-news-server.uri>lb://epdc-news-server</gateway.routes.epdc-news-server.uri> |
|
||||
<gateway.routes.epdc-oss-server.uri>lb://epdc-oss-server</gateway.routes.epdc-oss-server.uri> |
|
||||
<gateway.routes.epdc-events-server.uri>lb://epdc-events-server</gateway.routes.epdc-events-server.uri> |
|
||||
<gateway.routes.epdc-cloud-analysis-server.uri>lb://epdc-cloud-analysis-server |
|
||||
</gateway.routes.epdc-cloud-analysis-server.uri> |
|
||||
<gateway.routes.epdc-work-record-server.uri>lb://epdc-work-record-server |
|
||||
</gateway.routes.epdc-work-record-server.uri> |
|
||||
<gateway.routes.epdc-services-server.uri>lb://epdc-services-server |
|
||||
</gateway.routes.epdc-services-server.uri> |
|
||||
<gateway.routes.epdc-user-server.uri>lb://epdc-user-server</gateway.routes.epdc-user-server.uri> |
|
||||
<gateway.routes.epdc-demo-server.uri>lb://epdc-demo-server</gateway.routes.epdc-demo-server.uri> |
|
||||
<gateway.routes.epdc-group-server.uri>lb://epdc-group-server</gateway.routes.epdc-group-server.uri> |
|
||||
<gateway.routes.epdc-websocket-server.uri>lb://epdc-websocket-server |
|
||||
</gateway.routes.epdc-websocket-server.uri> |
|
||||
<gateway.routes.epdc-kpi-server.uri>lb://epdc-kpi-server</gateway.routes.epdc-kpi-server.uri> |
|
||||
<gateway.routes.epdc-custom-server.uri>lb://epdc-custom-server</gateway.routes.epdc-custom-server.uri> |
|
||||
<gateway.routes.epdc-points-server.uri>lb://epdc-points-server</gateway.routes.epdc-points-server.uri> |
|
||||
|
|
||||
<!-- nacos --> |
|
||||
<nacos.register-enabled>true</nacos.register-enabled> |
|
||||
<nacos.server-addr>47.104.224.45:8848</nacos.server-addr> |
|
||||
<nacos.ip>47.104.85.99</nacos.ip> |
|
||||
<nacos.namespace>6a3577b4-7b79-43f6-aebb-9c3f31263f6a</nacos.namespace> |
|
||||
|
|
||||
<spring.zipkin.base-url>http://localhost:9411</spring.zipkin.base-url> |
|
||||
</properties> |
|
||||
</profile> |
|
||||
|
|
||||
<profile> |
|
||||
<id>prod</id> |
|
||||
<properties> |
|
||||
<server.port>9094</server.port> |
|
||||
<spring.profiles.active>prod</spring.profiles.active> |
|
||||
<docker.tag>prod</docker.tag> |
|
||||
|
|
||||
<!-- gateway routes --> |
|
||||
<gateway.routes.epdc-auth-server.uri>lb://epdc-auth-server</gateway.routes.epdc-auth-server.uri> |
|
||||
<gateway.routes.epdc-admin-server.uri>lb://epdc-admin-server</gateway.routes.epdc-admin-server.uri> |
|
||||
<gateway.routes.epdc-activiti-server.uri>lb://epdc-activiti-server |
|
||||
</gateway.routes.epdc-activiti-server.uri> |
|
||||
<gateway.routes.epdc-api-server.uri>lb://epdc-api-server</gateway.routes.epdc-api-server.uri> |
|
||||
<gateway.routes.epdc-app-server.uri>lb://epdc-app-server</gateway.routes.epdc-app-server.uri> |
|
||||
<gateway.routes.epdc-heart-server.uri>lb://epdc-heart-server</gateway.routes.epdc-heart-server.uri> |
|
||||
<gateway.routes.epdc-job-server.uri>lb://epdc-job-server</gateway.routes.epdc-job-server.uri> |
|
||||
<gateway.routes.epdc-message-server.uri>lb://epdc-message-server |
|
||||
</gateway.routes.epdc-message-server.uri> |
|
||||
<gateway.routes.epdc-news-server.uri>lb://epdc-news-server</gateway.routes.epdc-news-server.uri> |
|
||||
<gateway.routes.epdc-oss-server.uri>lb://epdc-oss-server</gateway.routes.epdc-oss-server.uri> |
|
||||
<gateway.routes.epdc-cloud-analysis-server.uri>lb://epdc-cloud-analysis-server |
|
||||
</gateway.routes.epdc-cloud-analysis-server.uri> |
|
||||
<gateway.routes.epdc-work-record-server.uri>lb://epdc-work-record-server |
|
||||
</gateway.routes.epdc-work-record-server.uri> |
|
||||
<gateway.routes.epdc-events-server.uri>lb://epdc-events-server</gateway.routes.epdc-events-server.uri> |
|
||||
<gateway.routes.epdc-services-server.uri>lb://epdc-services-server |
|
||||
</gateway.routes.epdc-services-server.uri> |
|
||||
<gateway.routes.epdc-user-server.uri>lb://epdc-user-server</gateway.routes.epdc-user-server.uri> |
|
||||
<gateway.routes.epdc-demo-server.uri>lb://epdc-demo-server</gateway.routes.epdc-demo-server.uri> |
|
||||
<gateway.routes.epdc-group-server.uri>lb://epdc-group-server</gateway.routes.epdc-group-server.uri> |
|
||||
<gateway.routes.epdc-websocket-server.uri>lb://epdc-websocket-server |
|
||||
</gateway.routes.epdc-websocket-server.uri> |
|
||||
<gateway.routes.epdc-kpi-server.uri>lb://epdc-kpi-server</gateway.routes.epdc-kpi-server.uri> |
|
||||
<gateway.routes.epdc-custom-server.uri>lb://epdc-custom-server</gateway.routes.epdc-custom-server.uri> |
|
||||
<gateway.routes.epdc-points-server.uri>lb://epdc-points-server</gateway.routes.epdc-points-server.uri> |
|
||||
<gateway.routes.epdc-analysis-server.uri>lb://epdc-analysis-server |
|
||||
</gateway.routes.epdc-analysis-server.uri> |
|
||||
|
|
||||
<!-- redis配置 --> |
|
||||
<spring.redis.index>0</spring.redis.index> |
|
||||
<spring.redis.host>172.16.0.54</spring.redis.host> |
|
||||
<spring.redis.port>6379</spring.redis.port> |
|
||||
<spring.redis.password>Elink833066</spring.redis.password> |
|
||||
|
|
||||
<!-- nacos --> |
|
||||
<nacos.register-enabled>true</nacos.register-enabled> |
|
||||
<nacos.server-addr>172.16.0.52:8848</nacos.server-addr> |
|
||||
<nacos.ip></nacos.ip> |
|
||||
<nacos.namespace></nacos.namespace> |
|
||||
|
|
||||
<spring.zipkin.base-url>http://localhost:9411</spring.zipkin.base-url> |
|
||||
</properties> |
|
||||
</profile> |
|
||||
</profiles> |
|
||||
|
|
||||
</project> |
|
||||
@ -1,31 +0,0 @@ |
|||||
/** |
|
||||
* Copyright (c) 2018 人人开源 All rights reserved. |
|
||||
* |
|
||||
* https://www.renren.io
|
|
||||
* |
|
||||
* 版权所有,侵权必究! |
|
||||
*/ |
|
||||
|
|
||||
package com.elink.esua.epdc; |
|
||||
|
|
||||
import org.springframework.boot.SpringApplication; |
|
||||
import org.springframework.boot.autoconfigure.SpringBootApplication; |
|
||||
import org.springframework.cloud.client.discovery.EnableDiscoveryClient; |
|
||||
import org.springframework.cloud.openfeign.EnableFeignClients; |
|
||||
|
|
||||
/** |
|
||||
* 网关服务 |
|
||||
* |
|
||||
* @author Mark sunlightcs@gmail.com |
|
||||
* @since 1.0.0 |
|
||||
*/ |
|
||||
@SpringBootApplication |
|
||||
@EnableDiscoveryClient |
|
||||
@EnableFeignClients |
|
||||
public class GatewayApplication { |
|
||||
|
|
||||
public static void main(String[] args) { |
|
||||
SpringApplication.run(GatewayApplication.class, args); |
|
||||
} |
|
||||
|
|
||||
} |
|
||||
@ -1,69 +0,0 @@ |
|||||
/** |
|
||||
* Copyright (c) 2018 人人开源 All rights reserved. |
|
||||
* <p> |
|
||||
* https://www.renren.io
|
|
||||
* <p> |
|
||||
* 版权所有,侵权必究! |
|
||||
*/ |
|
||||
|
|
||||
package com.elink.esua.epdc.config; |
|
||||
|
|
||||
import org.springframework.beans.factory.annotation.Autowired; |
|
||||
import org.springframework.boot.autoconfigure.web.ServerProperties; |
|
||||
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.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; |
|
||||
|
|
||||
/** |
|
||||
* Cors跨域 |
|
||||
* |
|
||||
* @author Mark sunlightcs@gmail.com |
|
||||
* @since 1.0.0 |
|
||||
*/ |
|
||||
@Configuration |
|
||||
public class CorsConfig { |
|
||||
|
|
||||
private static final String MAX_AGE = "18000L"; |
|
||||
|
|
||||
@Autowired |
|
||||
private ServerProperties serverProperties; |
|
||||
|
|
||||
@Bean |
|
||||
public WebFilter corsFilter() { |
|
||||
return (ServerWebExchange ctx, WebFilterChain chain) -> { |
|
||||
ServerHttpRequest request = ctx.getRequest(); |
|
||||
if (!CorsUtils.isCorsRequest(request)) { |
|
||||
return chain.filter(ctx); |
|
||||
} |
|
||||
HttpHeaders requestHeaders = request.getHeaders(); |
|
||||
ServerHttpResponse response = ctx.getResponse(); |
|
||||
HttpMethod requestMethod = requestHeaders.getAccessControlRequestMethod(); |
|
||||
HttpHeaders headers = response.getHeaders(); |
|
||||
if (!request.getURI().getPath().startsWith(serverProperties.getServlet().getContextPath().concat("/ws"))) { |
|
||||
headers.add(HttpHeaders.ACCESS_CONTROL_ALLOW_ORIGIN, requestHeaders.getOrigin()); |
|
||||
headers.add(HttpHeaders.ACCESS_CONTROL_ALLOW_CREDENTIALS, "true"); |
|
||||
} |
|
||||
headers.addAll(HttpHeaders.ACCESS_CONTROL_ALLOW_HEADERS, requestHeaders.getAccessControlRequestHeaders()); |
|
||||
if (requestMethod != null) { |
|
||||
headers.add(HttpHeaders.ACCESS_CONTROL_ALLOW_METHODS, requestMethod.name()); |
|
||||
} |
|
||||
headers.add(HttpHeaders.ACCESS_CONTROL_EXPOSE_HEADERS, "*"); |
|
||||
headers.add(HttpHeaders.ACCESS_CONTROL_MAX_AGE, MAX_AGE); |
|
||||
if (request.getMethod() == HttpMethod.OPTIONS) { |
|
||||
response.setStatusCode(HttpStatus.OK); |
|
||||
return Mono.empty(); |
|
||||
} |
|
||||
return chain.filter(ctx); |
|
||||
}; |
|
||||
} |
|
||||
|
|
||||
} |
|
||||
@ -1,26 +0,0 @@ |
|||||
/** |
|
||||
* Copyright (c) 2018 人人开源 All rights reserved. |
|
||||
* |
|
||||
* https://www.renren.io
|
|
||||
* |
|
||||
* 版权所有,侵权必究! |
|
||||
*/ |
|
||||
|
|
||||
package com.elink.esua.epdc.config; |
|
||||
|
|
||||
import com.elink.esua.epdc.commons.tools.config.ModuleConfig; |
|
||||
import org.springframework.stereotype.Service; |
|
||||
|
|
||||
/** |
|
||||
* 模块配置信息 |
|
||||
* |
|
||||
* @author Mark sunlightcs@gmail.com |
|
||||
* @since 1.0.0 |
|
||||
*/ |
|
||||
@Service |
|
||||
public class ModuleConfigImpl implements ModuleConfig { |
|
||||
@Override |
|
||||
public String getName() { |
|
||||
return "gateway"; |
|
||||
} |
|
||||
} |
|
||||
@ -1,54 +0,0 @@ |
|||||
/** |
|
||||
* Copyright (c) 2018 人人开源 All rights reserved. |
|
||||
* <p> |
|
||||
* https://www.renren.io
|
|
||||
* <p> |
|
||||
* 版权所有,侵权必究! |
|
||||
*/ |
|
||||
|
|
||||
package com.elink.esua.epdc.feign; |
|
||||
|
|
||||
import com.elink.esua.epdc.common.token.dto.TokenDto; |
|
||||
import com.elink.esua.epdc.feign.fallback.ResourceFeignClientFallback; |
|
||||
import com.elink.esua.epdc.commons.tools.constant.ServiceConstant; |
|
||||
import com.elink.esua.epdc.commons.tools.security.user.UserDetail; |
|
||||
import com.elink.esua.epdc.commons.tools.utils.Result; |
|
||||
import org.springframework.cloud.openfeign.FeignClient; |
|
||||
import org.springframework.http.HttpHeaders; |
|
||||
import org.springframework.web.bind.annotation.GetMapping; |
|
||||
import org.springframework.web.bind.annotation.PostMapping; |
|
||||
import org.springframework.web.bind.annotation.RequestHeader; |
|
||||
import org.springframework.web.bind.annotation.RequestParam; |
|
||||
|
|
||||
/** |
|
||||
* 资源接口 |
|
||||
* |
|
||||
* @author Mark sunlightcs@gmail.com |
|
||||
* @since 1.0.0 |
|
||||
*/ |
|
||||
@FeignClient(name = ServiceConstant.EPDC_AUTH_SERVER, fallback = ResourceFeignClientFallback.class) |
|
||||
public interface ResourceFeignClient { |
|
||||
|
|
||||
/** |
|
||||
* 是否有资源访问权限 |
|
||||
* |
|
||||
* @param token token |
|
||||
* @param url 资源URL |
|
||||
* @param method 请求方式 |
|
||||
* @return 有访问权限,则返回用户信息 |
|
||||
*/ |
|
||||
@PostMapping("auth/resource") |
|
||||
Result<UserDetail> resource(@RequestHeader(HttpHeaders.ACCEPT_LANGUAGE) String language, @RequestParam("token") String token, |
|
||||
@RequestParam("url") String url, @RequestParam("method") String method); |
|
||||
|
|
||||
/** |
|
||||
* 获取登录用户信息 |
|
||||
* |
|
||||
* @param token |
|
||||
* @return com.elink.esua.epdc.commons.tools.utils.Result<com.elink.esua.epdc.commons.tools.security.user.CpUserDetail> |
|
||||
* @author |
|
||||
* @date 2019/8/19 17:19 |
|
||||
*/ |
|
||||
@GetMapping("auth/getLoginUserInfo") |
|
||||
Result<TokenDto> getLoginUserInfo(@RequestParam("token") String token); |
|
||||
} |
|
||||
@ -1,35 +0,0 @@ |
|||||
/** |
|
||||
* Copyright (c) 2018 人人开源 All rights reserved. |
|
||||
* <p> |
|
||||
* https://www.renren.io
|
|
||||
* <p> |
|
||||
* 版权所有,侵权必究! |
|
||||
*/ |
|
||||
|
|
||||
package com.elink.esua.epdc.feign.fallback; |
|
||||
|
|
||||
import com.elink.esua.epdc.common.token.dto.TokenDto; |
|
||||
import com.elink.esua.epdc.commons.tools.security.user.UserDetail; |
|
||||
import com.elink.esua.epdc.commons.tools.utils.Result; |
|
||||
import com.elink.esua.epdc.feign.ResourceFeignClient; |
|
||||
import org.springframework.stereotype.Component; |
|
||||
|
|
||||
/** |
|
||||
* 资源接口 Fallback |
|
||||
* |
|
||||
* @author Mark sunlightcs@gmail.com |
|
||||
* @since 1.0.0 |
|
||||
*/ |
|
||||
@Component |
|
||||
public class ResourceFeignClientFallback implements ResourceFeignClient { |
|
||||
|
|
||||
@Override |
|
||||
public Result<UserDetail> resource(String language, String token, String url, String method) { |
|
||||
return new Result<UserDetail>().error(); |
|
||||
} |
|
||||
|
|
||||
@Override |
|
||||
public Result<TokenDto> getLoginUserInfo(String token) { |
|
||||
return new Result<TokenDto>().error(); |
|
||||
} |
|
||||
} |
|
||||
@ -1,154 +0,0 @@ |
|||||
/** |
|
||||
* Copyright (c) 2018 人人开源 All rights reserved. |
|
||||
* |
|
||||
* https://www.renren.io
|
|
||||
* |
|
||||
* 版权所有,侵权必究! |
|
||||
*/ |
|
||||
|
|
||||
package com.elink.esua.epdc.filter; |
|
||||
|
|
||||
import com.alibaba.fastjson.JSON; |
|
||||
import com.elink.esua.epdc.feign.ResourceFeignClient; |
|
||||
import com.elink.esua.epdc.commons.tools.constant.Constant; |
|
||||
import com.elink.esua.epdc.commons.tools.security.user.UserDetail; |
|
||||
import com.elink.esua.epdc.commons.tools.utils.Result; |
|
||||
import org.apache.commons.lang3.StringUtils; |
|
||||
import org.springframework.beans.factory.annotation.Autowired; |
|
||||
import org.springframework.boot.context.properties.ConfigurationProperties; |
|
||||
import org.springframework.cloud.gateway.filter.GatewayFilterChain; |
|
||||
import org.springframework.cloud.gateway.filter.GlobalFilter; |
|
||||
import org.springframework.context.annotation.Configuration; |
|
||||
import org.springframework.core.io.buffer.DataBuffer; |
|
||||
import org.springframework.http.HttpHeaders; |
|
||||
import org.springframework.http.HttpStatus; |
|
||||
import org.springframework.http.MediaType; |
|
||||
import org.springframework.http.server.reactive.ServerHttpRequest; |
|
||||
import org.springframework.util.AntPathMatcher; |
|
||||
import org.springframework.web.server.ServerWebExchange; |
|
||||
import reactor.core.publisher.Flux; |
|
||||
import reactor.core.publisher.Mono; |
|
||||
|
|
||||
import java.nio.charset.StandardCharsets; |
|
||||
import java.util.List; |
|
||||
|
|
||||
/** |
|
||||
* 权限过滤器 |
|
||||
* |
|
||||
* @author Mark sunlightcs@gmail.com |
|
||||
* @since 1.0.0 |
|
||||
*/ |
|
||||
@Configuration |
|
||||
@ConfigurationProperties(prefix = "renren") |
|
||||
public class AuthFilter implements GlobalFilter { |
|
||||
|
|
||||
private final AntPathMatcher antPathMatcher = new AntPathMatcher(); |
|
||||
|
|
||||
@Autowired |
|
||||
private ResourceFeignClient resourceFeignClient; |
|
||||
/** |
|
||||
* 不拦截的urls |
|
||||
*/ |
|
||||
private List<String> urls; |
|
||||
|
|
||||
/** |
|
||||
* 不拦截工作端urls |
|
||||
*/ |
|
||||
private List<String> workLoginUrls; |
|
||||
|
|
||||
/** |
|
||||
* 拦截的工作端urls |
|
||||
*/ |
|
||||
private List<String> workUrls; |
|
||||
|
|
||||
@Override |
|
||||
public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) { |
|
||||
ServerHttpRequest request = exchange.getRequest(); |
|
||||
String requestUri = request.getPath().pathWithinApplication().value(); |
|
||||
|
|
||||
//请求放行,无需验证权限
|
|
||||
if(pathMatcher(requestUri)){ |
|
||||
return chain.filter(exchange); |
|
||||
} |
|
||||
|
|
||||
//获取用户token
|
|
||||
String token = request.getHeaders().getFirst(Constant.TOKEN_HEADER); |
|
||||
if(StringUtils.isBlank(token)){ |
|
||||
token = request.getHeaders().getFirst(Constant.AUTHORIZATION_HEADER); |
|
||||
if (StringUtils.isBlank(token)) { |
|
||||
token = request.getQueryParams().getFirst(Constant.TOKEN_HEADER); |
|
||||
} |
|
||||
} |
|
||||
|
|
||||
//资源访问权限
|
|
||||
String language = request.getHeaders().getFirst(HttpHeaders.ACCEPT_LANGUAGE); |
|
||||
Result<UserDetail> result = resourceFeignClient.resource(language, token, requestUri, request.getMethod().toString()); |
|
||||
//没权限访问,直接返回
|
|
||||
if(!result.success()){ |
|
||||
return response(exchange, result); |
|
||||
} |
|
||||
|
|
||||
//获取用户信息
|
|
||||
UserDetail userDetail = result.getData(); |
|
||||
if(userDetail != null){ |
|
||||
//当前登录用户userId,添加到header中
|
|
||||
ServerHttpRequest build = exchange.getRequest().mutate().header(Constant.USER_KEY, userDetail.getId()+"").build(); |
|
||||
return chain.filter(exchange.mutate().request(build).build()); |
|
||||
} |
|
||||
|
|
||||
return chain.filter(exchange); |
|
||||
} |
|
||||
|
|
||||
private Mono<Void> response(ServerWebExchange exchange, Object object) { |
|
||||
String json = JSON.toJSONString(object); |
|
||||
DataBuffer buffer = exchange.getResponse().bufferFactory().wrap(json.getBytes(StandardCharsets.UTF_8)); |
|
||||
exchange.getResponse().getHeaders().setContentType(MediaType.APPLICATION_JSON_UTF8); |
|
||||
exchange.getResponse().setStatusCode(HttpStatus.OK); |
|
||||
return exchange.getResponse().writeWith(Flux.just(buffer)); |
|
||||
} |
|
||||
|
|
||||
private boolean pathMatcher(String requestUri){ |
|
||||
for (String url : workLoginUrls) { |
|
||||
if(antPathMatcher.match(url, requestUri)){ |
|
||||
return true; |
|
||||
} |
|
||||
} |
|
||||
|
|
||||
for (String url : workUrls) { |
|
||||
if(antPathMatcher.match(url, requestUri)){ |
|
||||
return false; |
|
||||
} |
|
||||
} |
|
||||
|
|
||||
for (String url : urls) { |
|
||||
if(antPathMatcher.match(url, requestUri)){ |
|
||||
return true; |
|
||||
} |
|
||||
} |
|
||||
return false; |
|
||||
} |
|
||||
|
|
||||
public List<String> getUrls() { |
|
||||
return urls; |
|
||||
} |
|
||||
|
|
||||
public void setUrls(List<String> urls) { |
|
||||
this.urls = urls; |
|
||||
} |
|
||||
|
|
||||
public List<String> getWorkLoginUrls() { |
|
||||
return workLoginUrls; |
|
||||
} |
|
||||
|
|
||||
public void setWorkLoginUrls(List<String> workLoginUrls) { |
|
||||
this.workLoginUrls = workLoginUrls; |
|
||||
} |
|
||||
|
|
||||
public List<String> getWorkUrls() { |
|
||||
return workUrls; |
|
||||
} |
|
||||
|
|
||||
public void setWorkUrls(List<String> workUrls) { |
|
||||
this.workUrls = workUrls; |
|
||||
} |
|
||||
} |
|
||||
@ -1,131 +0,0 @@ |
|||||
|
|
||||
package com.elink.esua.epdc.filter; |
|
||||
|
|
||||
import com.alibaba.fastjson.JSON; |
|
||||
import com.elink.esua.epdc.common.token.dto.TokenDto; |
|
||||
import com.elink.esua.epdc.commons.tools.constant.Constant; |
|
||||
import com.elink.esua.epdc.commons.tools.utils.Result; |
|
||||
import com.elink.esua.epdc.feign.ResourceFeignClient; |
|
||||
import org.apache.commons.lang3.StringUtils; |
|
||||
import org.springframework.beans.factory.annotation.Autowired; |
|
||||
import org.springframework.cloud.gateway.filter.GatewayFilter; |
|
||||
import org.springframework.cloud.gateway.filter.factory.AbstractGatewayFilterFactory; |
|
||||
import org.springframework.core.io.buffer.DataBuffer; |
|
||||
import org.springframework.http.HttpHeaders; |
|
||||
import org.springframework.http.HttpStatus; |
|
||||
import org.springframework.http.MediaType; |
|
||||
import org.springframework.http.server.reactive.ServerHttpRequest; |
|
||||
import org.springframework.stereotype.Component; |
|
||||
import org.springframework.util.AntPathMatcher; |
|
||||
import org.springframework.web.server.ServerWebExchange; |
|
||||
import reactor.core.publisher.Flux; |
|
||||
import reactor.core.publisher.Mono; |
|
||||
|
|
||||
import java.nio.charset.StandardCharsets; |
|
||||
import java.util.Arrays; |
|
||||
import java.util.List; |
|
||||
|
|
||||
/** |
|
||||
* app接口权限过滤器 |
|
||||
* |
|
||||
* @author Mark sunlightcs@gmail.com |
|
||||
* @since 1.0.0 |
|
||||
*/ |
|
||||
@Component("CpAuth") |
|
||||
public class CpAuthGatewayFilterFactory extends AbstractGatewayFilterFactory<CpAuthGatewayFilterFactory.CpAuthConfig> { |
|
||||
|
|
||||
@Autowired |
|
||||
private ResourceFeignClient resourceFeignClient; |
|
||||
|
|
||||
@Autowired |
|
||||
private CpProperty cpProperty; |
|
||||
|
|
||||
private final AntPathMatcher antPathMatcher = new AntPathMatcher(); |
|
||||
|
|
||||
@Override |
|
||||
public List<String> shortcutFieldOrder() { |
|
||||
return Arrays.asList("enabled"); |
|
||||
} |
|
||||
|
|
||||
public CpAuthGatewayFilterFactory() { |
|
||||
super(CpAuthGatewayFilterFactory.CpAuthConfig.class); |
|
||||
} |
|
||||
|
|
||||
@Override |
|
||||
public GatewayFilter apply(CpAuthConfig config) { |
|
||||
return (exchange, chain) -> { |
|
||||
if (!config.isEnabled()) { |
|
||||
return chain.filter(exchange); |
|
||||
} |
|
||||
|
|
||||
ServerHttpRequest request = exchange.getRequest(); |
|
||||
String requestUri = request.getPath().pathWithinApplication().value(); |
|
||||
|
|
||||
//请求放行,无需验证权限
|
|
||||
if (!pathMatcher(requestUri)) { |
|
||||
return chain.filter(exchange); |
|
||||
} |
|
||||
|
|
||||
HttpHeaders headers = request.getHeaders(); |
|
||||
String token = headers.getFirst(Constant.AUTHORIZATION_HEADER); |
|
||||
if (StringUtils.isBlank(token)) { |
|
||||
token = request.getQueryParams().getFirst(Constant.AUTHORIZATION_HEADER); |
|
||||
if (StringUtils.isBlank(token)) { |
|
||||
return chain.filter(exchange); |
|
||||
} |
|
||||
} |
|
||||
Result<TokenDto> result = resourceFeignClient.getLoginUserInfo(token); |
|
||||
if (!result.success()) { |
|
||||
return response(exchange, result); |
|
||||
} |
|
||||
TokenDto user = result.getData(); |
|
||||
//当前登录用户userId,添加到header中
|
|
||||
if (user != null) { |
|
||||
ServerHttpRequest build = exchange.getRequest().mutate().header(Constant.APP_USER_KEY, user.getUserId()).build(); |
|
||||
return chain.filter(exchange.mutate().request(build).build()); |
|
||||
} |
|
||||
return chain.filter(exchange); |
|
||||
}; |
|
||||
} |
|
||||
|
|
||||
private Mono<Void> response(ServerWebExchange exchange, Object object) { |
|
||||
String json = JSON.toJSONString(object); |
|
||||
DataBuffer buffer = exchange.getResponse().bufferFactory().wrap(json.getBytes(StandardCharsets.UTF_8)); |
|
||||
exchange.getResponse().getHeaders().setContentType(MediaType.APPLICATION_JSON_UTF8); |
|
||||
exchange.getResponse().setStatusCode(HttpStatus.OK); |
|
||||
return exchange.getResponse().writeWith(Flux.just(buffer)); |
|
||||
} |
|
||||
|
|
||||
private boolean pathMatcher(String requestUri) { |
|
||||
for (String url : cpProperty.getSwaggerUrls()) { |
|
||||
if (antPathMatcher.match(url, requestUri)) { |
|
||||
return false; |
|
||||
} |
|
||||
} |
|
||||
for (String url : cpProperty.getUrls()) { |
|
||||
if (antPathMatcher.match(url, requestUri)) { |
|
||||
return true; |
|
||||
} |
|
||||
} |
|
||||
return false; |
|
||||
} |
|
||||
|
|
||||
public static class CpAuthConfig { |
|
||||
|
|
||||
/** |
|
||||
* 控制是否开启认证 |
|
||||
*/ |
|
||||
private boolean enabled; |
|
||||
|
|
||||
public CpAuthConfig() { |
|
||||
} |
|
||||
|
|
||||
public boolean isEnabled() { |
|
||||
return enabled; |
|
||||
} |
|
||||
|
|
||||
public void setEnabled(boolean enabled) { |
|
||||
this.enabled = enabled; |
|
||||
} |
|
||||
} |
|
||||
} |
|
||||
@ -1,27 +0,0 @@ |
|||||
package com.elink.esua.epdc.filter; |
|
||||
|
|
||||
import lombok.Data; |
|
||||
import org.springframework.boot.context.properties.ConfigurationProperties; |
|
||||
import org.springframework.boot.context.properties.EnableConfigurationProperties; |
|
||||
import org.springframework.stereotype.Component; |
|
||||
|
|
||||
import java.util.List; |
|
||||
|
|
||||
/** |
|
||||
* @author rongchao |
|
||||
* @Date 19-5-17 |
|
||||
*/ |
|
||||
@Data |
|
||||
@Component |
|
||||
@EnableConfigurationProperties |
|
||||
@ConfigurationProperties(prefix = "epdc") |
|
||||
public class CpProperty { |
|
||||
|
|
||||
private List<String> urls; |
|
||||
|
|
||||
/** |
|
||||
* 不处理token,直接通过 |
|
||||
*/ |
|
||||
private List<String> swaggerUrls; |
|
||||
|
|
||||
} |
|
||||
@ -1,286 +0,0 @@ |
|||||
server: |
|
||||
tomcat: |
|
||||
max-swallow-size: 100MB |
|
||||
port: @server.port@ |
|
||||
servlet: |
|
||||
context-path: /epdc-api |
|
||||
|
|
||||
spring: |
|
||||
application: |
|
||||
name: epdc-gateway-server |
|
||||
#环境 dev|test|prod |
|
||||
profiles: |
|
||||
active: @spring.profiles.active@ |
|
||||
servlet: |
|
||||
multipart: |
|
||||
enabled: true |
|
||||
file-size-threshold: 0 |
|
||||
max-file-size: 100MB |
|
||||
max-request-size: 100MB |
|
||||
redis: |
|
||||
database: @spring.redis.index@ |
|
||||
host: @spring.redis.host@ |
|
||||
timeout: 30s |
|
||||
port: @spring.redis.port@ |
|
||||
password: @spring.redis.password@ |
|
||||
cloud: |
|
||||
gateway: |
|
||||
locator: |
|
||||
enabled: true |
|
||||
routes: |
|
||||
#认证服务 |
|
||||
- id: epdc-auth-server |
|
||||
uri: @gateway.routes.epdc-auth-server.uri@ |
|
||||
order: 1 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/auth/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
#Admin服务 |
|
||||
- id: epdc-admin-server |
|
||||
uri: @gateway.routes.epdc-admin-server.uri@ |
|
||||
order: 2 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/sys/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
#OSS服务 |
|
||||
- id: epdc-oss-server |
|
||||
uri: @gateway.routes.epdc-oss-server.uri@ |
|
||||
order: 3 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/oss/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
#消息服务 |
|
||||
- id: epdc-message-server |
|
||||
uri: @gateway.routes.epdc-message-server.uri@ |
|
||||
order: 4 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/message/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
#工作流服务 |
|
||||
- id: epdc-activiti-server |
|
||||
uri: @gateway.routes.epdc-activiti-server.uri@ |
|
||||
order: 5 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/activiti/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
#定时任务服务 |
|
||||
- id: epdc-job-server |
|
||||
uri: @gateway.routes.epdc-job-server.uri@ |
|
||||
order: 6 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/job/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
#APP流服务 |
|
||||
- id: epdc-api-server |
|
||||
uri: @gateway.routes.epdc-api-server.uri@ |
|
||||
order: 7 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/api/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
- CpAuth=true |
|
||||
#爱心互助模块 |
|
||||
- id: epdc-heart-server |
|
||||
uri: @gateway.routes.epdc-heart-server.uri@ |
|
||||
order: 8 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/heart/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
#友邻社群模块 |
|
||||
- id: epdc-group-server |
|
||||
uri: @gateway.routes.epdc-group-server.uri@ |
|
||||
order: 9 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/group/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
#新闻公告模块 |
|
||||
- id: epdc-news-server |
|
||||
uri: @gateway.routes.epdc-news-server.uri@ |
|
||||
order: 10 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/news/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
#党群议事模块 |
|
||||
- id: epdc-events-server |
|
||||
uri: @gateway.routes.epdc-events-server.uri@ |
|
||||
order: 11 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/events/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
#生活服务模块 |
|
||||
- id: epdc-services-server |
|
||||
uri: @gateway.routes.epdc-services-server.uri@ |
|
||||
order: 12 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/services/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
#APP用户模块 |
|
||||
- id: epdc-user-server |
|
||||
uri: @gateway.routes.epdc-user-server.uri@ |
|
||||
order: 13 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/app-user/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
#DEMO服务 |
|
||||
- id: epdc-demo-server |
|
||||
uri: @gateway.routes.epdc-demo-server.uri@ |
|
||||
order: 14 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/demo/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
#websocket服务 |
|
||||
- id: epdc-websocket-server |
|
||||
uri: @gateway.routes.epdc-websocket-server.uri@ |
|
||||
order: 15 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/ws/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
#绩效考核模块 |
|
||||
- id: epdc-kpi-server |
|
||||
uri: @gateway.routes.epdc-kpi-server.uri@ |
|
||||
order: 16 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/kpi/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
#定制模块 |
|
||||
- id: epdc-custom-server |
|
||||
uri: @gateway.routes.epdc-custom-server.uri@ |
|
||||
order: 17 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/custom/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
#积分管理 |
|
||||
- id: epdc-points-server |
|
||||
uri: @gateway.routes.epdc-points-server.uri@ |
|
||||
order: 18 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/points/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
- id: epdc-cloud-analysis-server |
|
||||
uri: @gateway.routes.epdc-cloud-analysis-server.uri@ |
|
||||
order: 19 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/cloudAnalysis/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
#工作日志 |
|
||||
- id: epdc-work-record-server |
|
||||
uri: @gateway.routes.epdc-work-record-server.uri@ |
|
||||
order: 20 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/workRecord/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
- id: epdc-analysis-server |
|
||||
uri: @gateway.routes.epdc-analysis-server.uri@ |
|
||||
order: 21 |
|
||||
predicates: |
|
||||
- Path=${server.servlet.context-path}/analysis/** |
|
||||
filters: |
|
||||
- StripPrefix=1 |
|
||||
nacos: |
|
||||
discovery: |
|
||||
server-addr: @nacos.server-addr@ |
|
||||
register-enabled: @nacos.register-enabled@ |
|
||||
ip: @nacos.ip@ |
|
||||
namespace: @nacos.namespace@ |
|
||||
zipkin: |
|
||||
# 指定了 zipkin 服务器的地址 |
|
||||
base-url: @spring.zipkin.base-url@ |
|
||||
sleuth: |
|
||||
sampler: |
|
||||
# 将采样比例设置为 1.0,也就是全部都需要。默认是 0.1 |
|
||||
probability: 1.0 |
|
||||
management: |
|
||||
endpoints: |
|
||||
web: |
|
||||
exposure: |
|
||||
include: "*" |
|
||||
endpoint: |
|
||||
health: |
|
||||
show-details: ALWAYS |
|
||||
|
|
||||
|
|
||||
feign: |
|
||||
hystrix: |
|
||||
enabled: true |
|
||||
|
|
||||
hystrix: |
|
||||
command: |
|
||||
default: |
|
||||
execution: |
|
||||
isolation: |
|
||||
thread: |
|
||||
timeoutInMilliseconds: 60000 #缺省为1000 |
|
||||
|
|
||||
ribbon: |
|
||||
ReadTimeout: 300000 |
|
||||
ConnectTimeout: 300000 |
|
||||
|
|
||||
renren: |
|
||||
urls: |
|
||||
- /auth/captcha |
|
||||
- /auth/login |
|
||||
- /*/swagger-resources/** |
|
||||
- /*/swagger-ui.html |
|
||||
- /*/webjars/** |
|
||||
- /*/v2/api-docs |
|
||||
- /*/swagger/api-docs |
|
||||
- /monitor/** |
|
||||
- /api/** |
|
||||
- /activiti/modeler.html |
|
||||
- /activiti/service/** |
|
||||
- /activiti/editor-app/** |
|
||||
- /message/sms/sendCode #发送验证码 |
|
||||
- /oss/file/download |
|
||||
- /ws/** |
|
||||
- /custom/epidemicSentryPost/downloadQRCode/** |
|
||||
workLoginUrls: |
|
||||
- /api/work/user/getToken #工作端-获取token |
|
||||
- /api/work/user/login #工作端-登录 |
|
||||
- /api/analysis/user/getToken #数据分析端-获取token |
|
||||
- /api/analysis/user/login #数据分析端-登录 |
|
||||
- /api/work/*/swagger/** |
|
||||
workUrls: |
|
||||
- /api/work/** #工作端接口 |
|
||||
- /api/analysis/** #数据端接口 |
|
||||
- /cloudAnalysis/** #数据端接口 |
|
||||
- /workRecord/** #工作日志接口 |
|
||||
|
|
||||
epdc: |
|
||||
# 党建e家接口 |
|
||||
urls: |
|
||||
- /api/** |
|
||||
# 不处理token,直接通过 |
|
||||
swaggerUrls: |
|
||||
- /api/wx/getWxConfig # 获取微信公众号配置 |
|
||||
- /api/admin/dept/completeName # 获取完整部门名称 |
|
||||
- /api/message/sms/sendCode # 发送短信验证码 |
|
||||
- /api/message/sms/registerResult # 发送用户注册审核结果 |
|
||||
- /api/events/issue/upload # 上传图片 |
|
||||
- /api/app-user/user/mp/regist # 公众号用户注册 |
|
||||
- /api/app-user/user/ma/getToken # 小程序用户 登录 |
|
||||
- /api/app-user/user/ma/regist # 小程序用户 注册 |
|
||||
- /api/app-user/user/ma/gridLeaderRegister # 小程序用户 网格长注册 |
|
||||
- /api/app-user/user/ma/v2/getToken # 小程序用户 注册或登录(版本v2) |
|
||||
- /api/work/** #工作端接口不拦截 |
|
||||
- /api/analysis/** #数据端接口不拦截 |
|
||||
- /cloudAnalysis/** #数据端接口 |
|
||||
- /workRecord/** #工作日志接口 |
|
||||
@ -1,159 +0,0 @@ |
|||||
<?xml version="1.0" encoding="UTF-8"?> |
|
||||
<configuration> |
|
||||
<include resource="org/springframework/boot/logging/logback/base.xml"/> |
|
||||
|
|
||||
<property name="log.path" value="logs/gateway"/> |
|
||||
|
|
||||
<!-- 彩色日志格式 --> |
|
||||
<property name="CONSOLE_LOG_PATTERN" |
|
||||
value="${CONSOLE_LOG_PATTERN:-%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}"/> |
|
||||
|
|
||||
<!--1. 输出到控制台--> |
|
||||
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender"> |
|
||||
<!--此日志appender是为开发使用,只配置最底级别,控制台输出的日志级别是大于或等于此级别的日志信息--> |
|
||||
<filter class="ch.qos.logback.classic.filter.ThresholdFilter"> |
|
||||
<level>debug</level> |
|
||||
</filter> |
|
||||
<encoder> |
|
||||
<Pattern>${CONSOLE_LOG_PATTERN}</Pattern> |
|
||||
<!-- 设置字符集 --> |
|
||||
<charset>UTF-8</charset> |
|
||||
</encoder> |
|
||||
</appender> |
|
||||
|
|
||||
<!--2. 输出到文档--> |
|
||||
<!-- 2.1 level为 DEBUG 日志,时间滚动输出 --> |
|
||||
<appender name="DEBUG_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> |
|
||||
<!-- 正在记录的日志文档的路径及文档名 --> |
|
||||
<file>${log.path}/debug.log</file> |
|
||||
<!--日志文档输出格式--> |
|
||||
<encoder> |
|
||||
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern> |
|
||||
<charset>UTF-8</charset> <!-- 设置字符集 --> |
|
||||
</encoder> |
|
||||
<!-- 日志记录器的滚动策略,按日期,按大小记录 --> |
|
||||
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> |
|
||||
<!-- 日志归档 --> |
|
||||
<fileNamePattern>${log.path}/debug-%d{yyyy-MM-dd}.%i.log</fileNamePattern> |
|
||||
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> |
|
||||
<maxFileSize>100MB</maxFileSize> |
|
||||
</timeBasedFileNamingAndTriggeringPolicy> |
|
||||
<!--日志文档保留天数--> |
|
||||
<maxHistory>15</maxHistory> |
|
||||
</rollingPolicy> |
|
||||
<!-- 此日志文档只记录debug级别的 --> |
|
||||
<filter class="ch.qos.logback.classic.filter.LevelFilter"> |
|
||||
<level>debug</level> |
|
||||
<onMatch>ACCEPT</onMatch> |
|
||||
<onMismatch>DENY</onMismatch> |
|
||||
</filter> |
|
||||
</appender> |
|
||||
|
|
||||
<!-- 2.2 level为 INFO 日志,时间滚动输出 --> |
|
||||
<appender name="INFO_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> |
|
||||
<!-- 正在记录的日志文档的路径及文档名 --> |
|
||||
<file>${log.path}/info.log</file> |
|
||||
<!--日志文档输出格式--> |
|
||||
<encoder> |
|
||||
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern> |
|
||||
<charset>UTF-8</charset> |
|
||||
</encoder> |
|
||||
<!-- 日志记录器的滚动策略,按日期,按大小记录 --> |
|
||||
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> |
|
||||
<!-- 每天日志归档路径以及格式 --> |
|
||||
<fileNamePattern>${log.path}/info-%d{yyyy-MM-dd}.%i.log</fileNamePattern> |
|
||||
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> |
|
||||
<maxFileSize>100MB</maxFileSize> |
|
||||
</timeBasedFileNamingAndTriggeringPolicy> |
|
||||
<!--日志文档保留天数--> |
|
||||
<maxHistory>15</maxHistory> |
|
||||
</rollingPolicy> |
|
||||
<!-- 此日志文档只记录info级别的 --> |
|
||||
<filter class="ch.qos.logback.classic.filter.LevelFilter"> |
|
||||
<level>info</level> |
|
||||
<onMatch>ACCEPT</onMatch> |
|
||||
<onMismatch>DENY</onMismatch> |
|
||||
</filter> |
|
||||
</appender> |
|
||||
|
|
||||
<!-- 2.3 level为 WARN 日志,时间滚动输出 --> |
|
||||
<appender name="WARN_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> |
|
||||
<!-- 正在记录的日志文档的路径及文档名 --> |
|
||||
<file>${log.path}/warn.log</file> |
|
||||
<!--日志文档输出格式--> |
|
||||
<encoder> |
|
||||
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern> |
|
||||
<charset>UTF-8</charset> <!-- 此处设置字符集 --> |
|
||||
</encoder> |
|
||||
<!-- 日志记录器的滚动策略,按日期,按大小记录 --> |
|
||||
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> |
|
||||
<fileNamePattern>${log.path}/warn-%d{yyyy-MM-dd}.%i.log</fileNamePattern> |
|
||||
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> |
|
||||
<maxFileSize>100MB</maxFileSize> |
|
||||
</timeBasedFileNamingAndTriggeringPolicy> |
|
||||
<!--日志文档保留天数--> |
|
||||
<maxHistory>15</maxHistory> |
|
||||
</rollingPolicy> |
|
||||
<!-- 此日志文档只记录warn级别的 --> |
|
||||
<filter class="ch.qos.logback.classic.filter.LevelFilter"> |
|
||||
<level>warn</level> |
|
||||
<onMatch>ACCEPT</onMatch> |
|
||||
<onMismatch>DENY</onMismatch> |
|
||||
</filter> |
|
||||
</appender> |
|
||||
|
|
||||
<!-- 2.4 level为 ERROR 日志,时间滚动输出 --> |
|
||||
<appender name="ERROR_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> |
|
||||
<!-- 正在记录的日志文档的路径及文档名 --> |
|
||||
<file>${log.path}/error.log</file> |
|
||||
<!--日志文档输出格式--> |
|
||||
<encoder> |
|
||||
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern> |
|
||||
<charset>UTF-8</charset> <!-- 此处设置字符集 --> |
|
||||
</encoder> |
|
||||
<!-- 日志记录器的滚动策略,按日期,按大小记录 --> |
|
||||
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> |
|
||||
<fileNamePattern>${log.path}/error-%d{yyyy-MM-dd}.%i.log</fileNamePattern> |
|
||||
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> |
|
||||
<maxFileSize>100MB</maxFileSize> |
|
||||
</timeBasedFileNamingAndTriggeringPolicy> |
|
||||
<!--日志文档保留天数--> |
|
||||
<maxHistory>15</maxHistory> |
|
||||
</rollingPolicy> |
|
||||
<!-- 此日志文档只记录ERROR级别的 --> |
|
||||
<filter class="ch.qos.logback.classic.filter.LevelFilter"> |
|
||||
<level>ERROR</level> |
|
||||
<onMatch>ACCEPT</onMatch> |
|
||||
<onMismatch>DENY</onMismatch> |
|
||||
</filter> |
|
||||
</appender> |
|
||||
|
|
||||
<!-- 开发、测试环境 --> |
|
||||
<springProfile name="dev,test"> |
|
||||
<logger name="org.springframework.web" level="INFO"/> |
|
||||
<logger name="org.springboot.sample" level="INFO"/> |
|
||||
<logger name="com.elink.esua.epdc" level="INFO"/> |
|
||||
<logger name="com.elink.esua.epdc.dao" level="DEBUG"/> |
|
||||
<root level="INFO"> |
|
||||
<appender-ref ref="DEBUG_FILE"/> |
|
||||
<appender-ref ref="INFO_FILE"/> |
|
||||
<appender-ref ref="WARN_FILE"/> |
|
||||
<appender-ref ref="ERROR_FILE"/> |
|
||||
</root> |
|
||||
</springProfile> |
|
||||
|
|
||||
<!-- 生产环境 --> |
|
||||
<springProfile name="prod"> |
|
||||
<logger name="org.springframework.web" level="INFO"/> |
|
||||
<logger name="org.springboot.sample" level="INFO"/> |
|
||||
<logger name="com.elink.esua.epdc" level="INFO"/> |
|
||||
<root level="INFO"> |
|
||||
<appender-ref ref="CONSOLE"/> |
|
||||
<appender-ref ref="DEBUG_FILE"/> |
|
||||
<appender-ref ref="INFO_FILE"/> |
|
||||
<appender-ref ref="WARN_FILE"/> |
|
||||
<appender-ref ref="ERROR_FILE"/> |
|
||||
</root> |
|
||||
</springProfile> |
|
||||
|
|
||||
</configuration> |
|
||||
Loading…
Reference in new issue