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

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

iningwei

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值