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


相关文章
|
10月前
|
JavaScript 前端开发 Java
Eclipse编辑HTML,JSP,JS等时的卡顿问题,非常有效!!!
Eclipse编辑HTML,JSP,JS等时的卡顿问题,非常有效!!!
106 0
|
11月前
|
人工智能 数据可视化 API
ArcGIS API for Python
ArcGIS API for Python
56 0
|
前端开发 JavaScript Java
前端——JSP中引入项目中的js文件或css文件或图片
前端——JSP中引入项目中的js文件或css文件或图片
|
12月前
|
JavaScript Java
JSP如何调用JS的数据(变量)?
JSP如何调用JS的数据(变量)?
266 0
|
JavaScript 前端开发 应用服务中间件
Arcgis api for javascript 详细部署
Arcgis api for javascript 详细部署
|
人工智能 数据可视化 数据管理
ArcGIS API for Python
ArcGIS API for Python
100 0
|
XML JavaScript 前端开发
JSP与JavaScript交互之(一)成绩信息输入的奖学金评定
JSP与JavaScript交互之(一)成绩信息输入的奖学金评定
129 0
JSP与JavaScript交互之(一)成绩信息输入的奖学金评定
|
数据可视化 数据管理 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 前端开发 Java
下一篇
DDNS