arcgis api for javascript中使用proxy.jsp

简介:

当我们使用arcgis api for javascript 查询arcgis服务时,如果查询的参数很长时,通过get方式提交会查询不到结果,因为get方式提交的参数有长度限制,需要通过代理的方式使用post提交。

arcgis 提供了一种解决方案就是proxy.jsp.

首先在项目页面js中引入 proxy.jsp:esriConfig.defaults.io.proxyUrl=http://servername:prot/arcgis_js_api/proxy.jsp  引入代理页面

esriConfig.defaults.io.alwaysUseProxy=true;         设置代理是否一直起作用

引入之后把proxy.jsp放入到项目中。

代理页面源码如下:

<%@page session="false"%>
<%@page import="java.net.*,java.io.*" %>
<%!
String[] serverUrls = {
 "http://servername:8399/arcgis/rest/services"//对什么服务起作用,可以配置多个用","分割。
};
try {
 String reqUrl = request.getQueryString();
 boolean allowed = false;
 String token = null;
 for(String surl : serverUrls) {
   String[] stokens = surl.split("\\s*,\\s*");
   if(reqUrl.toLowerCase().contains(stokens[0].toLowerCase())) {
     allowed = true;
     if(stokens.length >= 2 && stokens[1].length() > 0)
       token = stokens[1];
     break;
   }
 }
 if(reqUrl.endsWith(".png")) allowed = true;
 if(!allowed) {
   response.setStatus(403);
   return;
 }
 if(token != null) {
   reqUrl = reqUrl + (reqUrl.indexOf("?") > -1 ? "&" : "?") + "token=" + token;
 }
         URL url = new URL(reqUrl);
       HttpURLConnection con = (HttpURLConnection)url.openConnection();
       con.setDoOutput(true);
       con.setRequestMethod(request.getMethod());
       if(request.getContentType() != null) {
         con.setRequestProperty("Content-Type", request.getContentType());
       }
         con.setRequestProperty("Referer", request.getHeader("Referer"));
       int clength = request.getContentLength();
       if(clength > 0) {
               con.setDoInput(true);
               InputStream istream = request.getInputStream();
               OutputStream os = con.getOutputStream();
               final int length = 5000;
         byte[] bytes = new byte[length];
         int bytesRead = 0;
         while ((bytesRead = istream.read(bytes, 0, length)) > 0) {
           os.write(bytes, 0, bytesRead);
         }
       }
 else {
   con.setRequestMethod("GET");
 }
   out.clear();
   out = pageContext.pushBody();
   OutputStream ostream = response.getOutputStream();
   response.setContentType(con.getContentType());
   InputStream in = con.getInputStream();
   final int length = 5000;
   byte[] bytes = new byte[length];
   int bytesRead = 0;
   while ((bytesRead = in.read(bytes, 0, length)) > 0) {
       ostream.write(bytes, 0, bytesRead);
   }
} catch(Exception e) {
   response.setStatus(500);
}
%>

引用地址:http://blog.csdn.net/javadwr/article/details/9119627


本文转自 stock0991 51CTO博客,原文链接:http://blog.51cto.com/qing0991/1339554


相关文章
|
6月前
|
人工智能 数据可视化 API
ArcGIS API for Python
ArcGIS API for Python
33 0
|
10月前
|
JavaScript 前端开发 应用服务中间件
Arcgis api for javascript 详细部署
Arcgis api for javascript 详细部署
|
12月前
|
人工智能 数据可视化 数据管理
ArcGIS API for Python
ArcGIS API for Python
76 0
|
JavaScript 前端开发 定位技术
ArcGIS API For JavaScript官方文档(六)之设置范围
ArcGIS API For JavaScript官方文档(六)之设置范围
|
存储 JSON 前端开发
ArcGIS API For JavaScript官方文档(一)之默认API配置
ArcGIS API For JavaScript官方文档(一)之默认API配置
|
数据可视化 数据管理 API
​​​​​​​ARCGIS API for Python进行城市区域提取
​​​​​​​ARCGIS API for Python进行城市区域提取
​​​​​​​ARCGIS API for Python进行城市区域提取
arcgis api 3.X 修改自带弹窗样式 2022年6月12日
自带的弹窗介绍: arcgis api 3.X 修改自带弹窗样式插图 /*修改原有弹窗的css样式*/ /* 弹窗整体 */ .esriPopup { font-size: 16px; box-shadow: 10px 10px 5px #888888; } .esriPopup .sizer { position: relative; width: 400px; /* 弹窗宽度 */ z-index: 1; } /* 标题部分 */ .esriPopup .titlePane { background-color: rgba(7
|
JavaScript 前端开发 数据可视化
ArcGIS API for JavaScript 4.10 重大更新,强势来袭!
ArcGIS API for JavaScript 4.10 版引入了大量新功能,并对原有功能进行了增强: 引入了一种新的建筑图层类型BuildingSceneLayer,用于可视化BIM数据; 新增众多微件,如3D剖切、草图绘制、二维面积和距离测量、改善编辑工作流的FeatureTemplates微件等; 地图中的所有图层均可使用WebGL进行绘制,从而提升渲染性能; 通过更高性能的 WebStyleSymbols增强了3D体验; 还有诸多精彩变化,下文将为您一一呈现。
2549 0
|
JavaScript 前端开发 应用服务中间件
离线部署ArcGIS API for Javascript
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/bitree1/article/details/58611551 1.
1451 0
|
JavaScript 前端开发 API
arcgis api for javascript之加载图层
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/gisdoer/article/details/82116422 arcgis ap...
2479 0