From aa4429a11d9b73bbcb1628090b6bafb75c4c6a00 Mon Sep 17 00:00:00 2001 From: 13693261870 <252740454@qq.com> Date: 星期三, 27 九月 2023 14:51:07 +0800 Subject: [PATCH] 修改代理服务-2 --- src/main/java/com/moon/server/helper/HttpHelper.java | 42 ++++++++++++++++++++++++++++-------------- 1 files changed, 28 insertions(+), 14 deletions(-) diff --git a/src/main/java/com/moon/server/helper/HttpHelper.java b/src/main/java/com/moon/server/helper/HttpHelper.java index 77379ad..6d621d0 100644 --- a/src/main/java/com/moon/server/helper/HttpHelper.java +++ b/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) { @@ -304,7 +318,7 @@ .replace("?" + res.getArgs() + "&", "?").replace("&" + res.getArgs() + "&", "&"); } - if (StaticData.THREE == res.getFirm() && str.contains(StaticData.REST_LAYER)) { + if (StaticData.I3 == res.getCategory() && str.contains(StaticData.REST_LAYER)) { str = str.replace(res.getUrl().replace("/v6/wmts/", StaticData.REST_LAYER), proxyUrl.replace("/proxy/", "/proxy/rest/")); } } -- Gitblit v1.9.3