GatewayRouterBuilder.java 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. package camel.central.gateway.route;
  2. import camel.central.gateway.processor.ErrorHandle;
  3. import camel.central.gateway.processor.GatewayProcessor;
  4. import camel.central.gateway.processor.SignProcessor;
  5. import com.fasterxml.jackson.databind.ObjectMapper;
  6. import com.fasterxml.jackson.databind.node.ObjectNode;
  7. import org.apache.camel.Exchange;
  8. import org.apache.camel.Message;
  9. import org.apache.camel.builder.RouteBuilder;
  10. import org.springframework.stereotype.Component;
  11. import javax.servlet.http.HttpServletResponse;
  12. import java.text.SimpleDateFormat;
  13. import java.util.Date;
  14. import java.util.concurrent.ExecutorService;
  15. import java.util.concurrent.Executors;
  16. /**
  17. * @author HZY
  18. * @vsrsion 1.0
  19. * Created at 2017/3/13.
  20. */
  21. @Component
  22. public class GatewayRouterBuilder extends RouteBuilder {
  23. private ExecutorService threadPool;
  24. @Override
  25. public void configure() throws Exception {
  26. threadPool = Executors.newCachedThreadPool();
  27. // getContext().setTracing(true);
  28. getContext().setStreamCaching(true);
  29. enableSSL();
  30. apiRoute();
  31. errorHandleRoute();
  32. logRoute();
  33. toolRoute();
  34. }
  35. private void enableSSL() {
  36. // if (httpsEnable) {
  37. // //全局ssl设置
  38. // KeyStoreParameters ksparams = new KeyStoreParameters();
  39. // ksparams.setResource("tomcat.keystore");
  40. // ksparams.setPassword("123456");
  41. //
  42. // KeyManagersParameters kmp = new KeyManagersParameters();
  43. // kmp.setKeyStore(ksparams);
  44. // kmp.setKeyPassword("123456");
  45. //
  46. // SSLContextParameters scp = new SSLContextParameters();
  47. // scp.setKeyManagers(kmp);
  48. //
  49. // JettyHttpComponent jettyComponent = getContext().getComponent("jetty", JettyHttpComponent.class);
  50. // jettyComponent.setSslContextParameters(scp);
  51. // }
  52. }
  53. private void apiRoute() {
  54. //EHR 解析服务代理
  55. from("jetty:http://0.0.0.0:9999/resolve?matchOnUriPrefix=true").routeId("resolveProxy")
  56. // .to("jetty:http://172.19.103.74:10170?bridgeEndpoint=true&throwExceptionOnFailure=false");
  57. .to("jetty:http://192.168.200.83:10170?bridgeEndpoint=true&throwExceptionOnFailure=false");
  58. //EHR ag-admin网关代理
  59. from("jetty:http://0.0.0.0:9998?matchOnUriPrefix=true").routeId("proxy")
  60. // .to("jetty:http://172.19.103.73:10000?bridgeEndpoint=true&throwExceptionOnFailure=false");
  61. .to("jetty:http://192.168.220.84:10000?bridgeEndpoint=true&throwExceptionOnFailure=false");
  62. //EHR 公钥获取
  63. from("jetty:http://0.0.0.0:9999/api/v1.0/organizations/{org_code}/key").routeId("publicKey")
  64. // .to("jetty:http://172.19.103.73:10400?bridgeEndpoint=true&throwExceptionOnFailure=false");
  65. .to("jetty:http://192.168.220.85:10000?bridgeEndpoint=true&throwExceptionOnFailure=false");
  66. // 非病人维度 档案上传接口代理
  67. from("jetty:http://0.0.0.0:9999/api/dataset/packages?bridgeEndpoint=true&enableMultipartFilter=false").routeId("proxyUploadPack")
  68. .removeHeaders("CamelHttp*")
  69. // .to("jetty:http://172.19.103.74:10140/api/v1.0/packages");
  70. .to("jetty:http://192.168.200.69:10140/api/v1.0/datasetPackages");
  71. // 档案上传接口代理
  72. from("jetty:http://0.0.0.0:9999/api/packages?bridgeEndpoint=true&enableMultipartFilter=false").routeId("proxyUploadPackage")
  73. .removeHeaders("CamelHttp*")
  74. // .to("jetty:http://172.19.103.74:10140/api/v1.0/packages");
  75. .to("jetty:http://192.168.220.233/packmgr/api/v1.0/packages");
  76. // 质控包上传接口代理
  77. from("jetty:http://0.0.0.0:9999/api/qcPackages?bridgeEndpoint=true&enableMultipartFilter=false").routeId("proxyQcPackUpload")
  78. .removeHeaders("CamelHttp*")
  79. // .to("jetty:http://172.19.103.73:10300/api/v1.0/report/receiveReportFile");
  80. .to("jetty:http://192.168.40.120:10300/api/v1.0/report/receiveReportFile");
  81. //统一网关入口(restful)
  82. from("jetty:http://0.0.0.0:9999/api").routeId("api")
  83. .wireTap("direct:gatewayLog").executorService(threadPool)
  84. .bean(method(GatewayProcessor.class, "route"))
  85. .wireTap("direct:gatewayLog").executorService(threadPool);
  86. }
  87. /**
  88. * 统一网关错误代码返回
  89. */
  90. private void errorHandleRoute() {
  91. from("direct:errorHandle").routeId("errorHandle")
  92. .choice()
  93. .when(header(Exchange.HTTP_URI).contains("paramError")).bean(new ErrorHandle(), "paramError")
  94. .when(header(Exchange.HTTP_URI).contains("outdateError")).bean(new ErrorHandle(), "outdateError")
  95. .when(header(Exchange.HTTP_URI).contains("signValidError")).bean(new ErrorHandle(), "signValidError")
  96. .when(header(Exchange.HTTP_URI).contains("unauthorizedError")).bean(new ErrorHandle(), "unauthorizedError")
  97. .endChoice();
  98. }
  99. private void toolRoute() {
  100. //流程健康测试接口
  101. from("jetty:http://0.0.0.0:9999/healthy").routeId("healthy")
  102. .log("=========================心跳测试=====================");
  103. //网关辅助工具路由,用于生成签名等内容。不要要发布到生产环境中。
  104. from("jetty:http://0.0.0.0:9999/sign").routeId("sign")
  105. .process(new SignProcessor());
  106. }
  107. private void logRoute() {
  108. from("direct:gatewayLog").aggregate(header("breadcrumbId"), (oldExchange, newExchange) -> {
  109. if (oldExchange == null) {
  110. Date date = new Date();
  111. newExchange.getIn().setHeader("time", date);
  112. return newExchange;
  113. } else {
  114. Date end = new Date();
  115. Date begin = oldExchange.getIn().getHeader("time", Date.class);
  116. long responseTime = end.getTime() - begin.getTime();
  117. oldExchange.getIn().setHeader("responseTime", responseTime);
  118. String body = newExchange.getIn().getBody(String.class);
  119. oldExchange.getIn().setBody(body);
  120. return oldExchange;
  121. }
  122. }).process(exchange -> {
  123. Message in = exchange.getIn();
  124. String api = in.getHeader("api", String.class);
  125. String appKey = in.getHeader("appKey", String.class);
  126. String sign = in.getHeader("sign", String.class);
  127. String timestamp = in.getHeader("timestamp", String.class);
  128. String v = in.getHeader("v", String.class);
  129. String param = in.getHeader("param", String.class);
  130. String token = in.getHeader("token", String.class);
  131. Date time = in.getHeader("time", Date.class);
  132. String requestTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(time);
  133. Long responseTime = in.getHeader("responseTime", Long.class);
  134. String url = in.getHeader("CamelHttpUrl", String.class);
  135. String method = in.getHeader("CamelHttpMethod", String.class);
  136. HttpServletResponse response = in.getHeader("CamelHttpServletResponse", HttpServletResponse.class);
  137. in.getHeader("CamelHttpServletResponse", HttpServletResponse.class);
  138. String body = in.getBody(String.class);
  139. ObjectMapper objectMapper = new ObjectMapper();
  140. ObjectNode objectNode = objectMapper.createObjectNode();
  141. objectNode.put("time", requestTime);
  142. objectNode.put("logType", 1);
  143. objectNode.put("caller", appKey);
  144. ObjectNode dataNode = objectMapper.createObjectNode();
  145. dataNode.put("responseTime", responseTime);
  146. dataNode.put("url", url);
  147. dataNode.put("responseCode", response.getStatus());
  148. dataNode.put("response", body);
  149. dataNode.put("api", api);
  150. dataNode.put("appKey", appKey);
  151. dataNode.put("method", method);
  152. ObjectNode paramNode = objectMapper.createObjectNode();
  153. paramNode.put("api", api);
  154. paramNode.put("appKey", appKey);
  155. paramNode.put("sign", sign);
  156. paramNode.put("timestamp", timestamp);
  157. paramNode.put("v", v);
  158. if (param != null) {
  159. paramNode.put("param", param);
  160. }
  161. if (token != null) {
  162. paramNode.put("token", token);
  163. }
  164. dataNode.set("params", paramNode);
  165. objectNode.set("data", dataNode);
  166. String content = objectMapper.writeValueAsString(objectNode);
  167. exchange.getOut().setBody(content);
  168. }).completionSize(2).to("file://e:/gatewayLog");
  169. }
  170. }