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

版本说明

使用的是最新的V4.9版本Arcgis api for js.
解压后目录如下图所示:
Tomcat 本地配置Arcgis api for js 服务器_第1张图片

Tomcat配置

1,拷贝arcgis_js_api到Tomcat的webapps目录下
Tomcat 本地配置Arcgis api for js 服务器_第2张图片
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的引用改一下

    
    
      
      

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中添加


  CorsFilter
  org.apache.catalina.filters.CorsFilter


  CorsFilter
  /*

需要注意的是,如果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

你可能感兴趣的:(ArcGIS)