版本说明
使用的是最新的V4.9版本Arcgis api for js.
解压后目录如下图所示:
Tomcat配置
1,拷贝arcgis_js_api到Tomcat的webapps目录下
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