src/main/java/com/moon/server/entity/all/StaticData.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/java/com/moon/server/helper/HttpHelper.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/java/com/moon/server/service/sys/ProxyService.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 |
src/main/java/com/moon/server/entity/all/StaticData.java
@@ -176,6 +176,10 @@ public final static String DOM = "DOM"; public final static String REQUEST = "request"; public final static String GET_CAPABILITIES = "GetCapabilities"; public final static String SUCCESS = "$SUCCESS"; public final static String LINESTRING = "LINESTRING"; src/main/java/com/moon/server/helper/HttpHelper.java
@@ -273,23 +273,37 @@ return; } do { if (null == res || StringHelper.isNull(res.getUrl())) { switch (res.getCategory()) { case 2: copeGeoService(proxyResponse, request, response, res); break; } case 3: copeSjService(proxyResponse, request, response, res); break; default: entity.writeTo(response.getOutputStream()); break; } } Header[] headers = proxyResponse.getHeaders("content-type"); if (null != headers && headers.length > 0 && headers[0].getValue().contains(StaticData.TEXT_XML)) { String str = filterStr(request, response, res, EntityUtils.toString(entity, "UTF-8")); private void copeGeoService(HttpResponse proxyResponse, HttpServletRequest request, HttpServletResponse response, ResEntity res) throws IOException { if (StaticData.GET_CAPABILITIES.equals(request.getParameter(StaticData.REQUEST))) { // } byte[] bytes = str.getBytes(StandardCharsets.UTF_8); response.setContentLength(bytes.length); response.getOutputStream().write(bytes); return; } } while (false); proxyResponse.getEntity().writeTo(response.getOutputStream()); } entity.writeTo(response.getOutputStream()); private void copeSjService(HttpResponse proxyResponse, HttpServletRequest request, HttpServletResponse response, ResEntity res) throws IOException { Header[] headers = proxyResponse.getHeaders("content-type"); if (null != headers && headers.length > 0 && headers[0].getValue().contains(StaticData.TEXT_XML)) { String str = filterStr(request, response, res, EntityUtils.toString(proxyResponse.getEntity(), "UTF-8")); byte[] bytes = str.getBytes(StandardCharsets.UTF_8); response.setContentLength(bytes.length); response.getOutputStream().write(bytes); } else { proxyResponse.getEntity().writeTo(response.getOutputStream()); } } private String filterStr(HttpServletRequest request, HttpServletResponse response, ResEntity res, String str) { src/main/java/com/moon/server/service/sys/ProxyService.java
@@ -4,7 +4,6 @@ import com.moon.server.entity.all.*; import com.moon.server.entity.sys.ResEntity; import com.moon.server.entity.sys.ResLogEntity; import com.moon.server.entity.sys.TokenEntity; import com.moon.server.entity.sys.UserEntity; import com.moon.server.helper.AsyncHelper; import com.moon.server.helper.HttpHelper; @@ -61,7 +60,7 @@ } insertLog(req, ue, resId); String url = getUrl(req, entity, token, isRest); String url = getUrl(req, ue, entity, token, isRest); res.setHeader("token", token); forward(req, res, entity, url); } @@ -107,10 +106,9 @@ if (StaticData.ADMIN.equals(ue.getUid())) { return true; } // 7.检查白名单 // 7.检查白名单和IP一致性 if (!checkWhiteList(ip, req)) { // 检查IP一致性 if (!checkIpSource(ip, token)) { if (!ip.equals(sysService.tokenService.getEntityByToken(token).getIp())) { return WebHelper.writeStr2Page(res, AuthInterceptor.ILLEGAL_TOKEN); } } @@ -147,15 +145,6 @@ } /** * 检查IP一致性 */ private boolean checkIpSource(String ip, String token) { TokenEntity te = sysService.tokenService.getEntityByToken(token); return te.getIp().equals(ip); } /** * 检查资源权限 */ private ResEntity getResEntity(UserEntity ue, int resId) { @@ -163,7 +152,6 @@ if (null == rs || rs.isEmpty()) { return null; } // List<ResEntity> list = rs.stream().filter(resEntity -> resEntity.getId() == resId).collect(Collectors.toList()) for (ResEntity entity : rs) { if (resId == entity.getId()) { @@ -226,18 +214,18 @@ /** * 获取Url */ private String getUrl(HttpServletRequest req, ResEntity entity, String token, boolean isRest) { private String getUrl(HttpServletRequest req, UserEntity ue, ResEntity entity, String token, boolean isRest) { String proxyUrl = entity.getProxy().replace("{token}", token); int end = req.getRequestURL().indexOf(proxyUrl) + proxyUrl.length(); String url = entity.getUrl() + req.getRequestURL().substring(end); if (null != req.getQueryString()) { url = url + (url.contains("?") ? "&" : "?") + req.getQueryString(); } // category:0-其他,1-GisServer,2-GeoServer,3-数简 if (StaticData.I2 == entity.getCategory()) { // url = getGeoServerUrl(req, ue, entity, url); } else if (StaticData.I3 == entity.getCategory()) { if (null != req.getQueryString()) { url = url + (url.contains("?") ? "&" : "?") + req.getQueryString(); } if (isRest) { url = url.replace("/v6/wmts/", "/v6/rest/"); } @@ -250,6 +238,22 @@ } /** * 获取GeoServer地址 */ private String getGeoServerUrl(HttpServletRequest req, UserEntity ue, ResEntity entity, String url) { if (null == req.getQueryString()) { return url; } String str = req.getQueryString(); if (!StaticData.GET_CAPABILITIES.equals(req.getParameter(StaticData.REQUEST))) { // } return url + (url.contains("?") ? "&" : "?") + str; } /** * 转发请求 */ private void forward(HttpServletRequest request, HttpServletResponse response, ResEntity entity, String url) throws Exception {