Tomcat 本地配置Arcgis api for js 服务器

版本说明

使用的是最新的V4.9版本Arcgis api for js.
解压后目录如下图所示:
arcgis api for js

Tomcat配置

1,拷贝arcgis_js_api到Tomcat的webapps目录下
拷贝api
2,
把上述arcgis_js_api/library/4.9/dojo/dojs.js和arcgis_js_api/library/4.9/init.js这两个文件中的
[HOSTNAME_AND_PATH_TO_JSAPI]都替换为http://192.168.31.102:8080/arcgis_js_api/library/4.9/
其中192.168.31.102:8080为tomcat服务器的ip和端口。
重启tomcat服务器
3,然后把前端代码原来通过CDN的引用改一下

    <!--<link rel="stylesheet" href="https://js.arcgis.com/4.9/esri/css/main.css">-->
    <!--<script src="https://js.arcgis.com/4.9/"></script>-->
      <link rel="stylesheet" href="http://192.168.31.102:8080/arcgis_js_api/library/4.9/esri/css/main.css">
      <script src="http://192.168.31.102:8080/arcgis_js_api/library/4.9/init.js"></script>

4,测试
浏览器输入 http://192.168.31.102:8080/arcgis_js_api/library/4.9/init.js
若是能访问,则说明部署成功
5,Run
却发现界面是乱的,F12一看,报错如下:
has been blocked by CORS policy: No ‘Access-Control-Allow-Origin’ header is present on the requested resource

跨域访问解决

1,根据上述报错很容易找到tomcat服务器跨域解决方案:https://enable-cors.org/server_tomcat.html
即在tomcat安装目录下的conf/web.xml中添加

<filter>
  <filter-name>CorsFilter</filter-name>
  <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
</filter>
<filter-mapping>
  <filter-name>CorsFilter</filter-name>
  <url-pattern>/*</url-pattern>
</filter-mapping>

需要注意的是,如果web.xml里面还有其它filter配置,需要把上述配置放在最上面

2,然而搞死,依旧报同样的错
3,最终找到原因
原来跨域需要依赖两个jar库,即cors-filter.jar和java-property-utils.jar。
tomcat默认lib目录下并没有这两个库。真的是神坑啊!!!
好心的网友分享了java-property-utils-1.9.jar和cors-filter-1.7.jar这两个库,且反编译发现这两个库的命名空间为com.thetransactioncompany.cors
拷贝需要的jar文件到lib目录下,修改一下上述代码段org.apache.catalina.filters为com.thetransactioncompany.cors
重启tomcat

顺利解决问题!!!

其它

1,网友还提供了一种把arcgis api for js直接配置到项目中的方法:https://blog.csdn.net/qq_36375770/article/details/80019651
2,arcgis api for js 使用arcgis server跨域:
https://blog.csdn.net/GISuuser/article/details/81099355

猜你喜欢

转载自blog.csdn.net/iningwei/article/details/83625103