Geoserver跨域请求设置
已拦截跨源请求:同源策略禁止读取位于 http://localhost:8080/geoserver/weng_test/ows?service=WFS&version=1.0.0&request=GetFeature&typeName=weng_test:
dw_country&maxFeatures=50&outputFormat=application%2Fjson 的远程资源。(原因:CORS 头缺少 'Access-Control-Allow-Origin')。
Geoserver 测试版本为 2.12.1。可有以下两种方案。
方案1
(1)下载跨域jar包jetty-servlets.jar
下载geoserver使用的对应jetty版本——可以查看<Geoserver>\lib下jetty-servlet.jar (如,Geoserver 2.12.1 版本下的为 jetty-servlet-9.2.13.v20150730.jar)的版本作为对照。
下载地址:http://central.maven.org/maven2/org/eclipse/jetty/jetty-servlets/
并将jar包放到<Geoserver>\webapps\geoserver\WEB-INF\lib文件夹下。
(2)filter的位置
打开<Geoserver>\webapps\geoserver\WEB-INF\web.xml文件,找到文件中<filter>平级的位置,添加如下内容:
<filter> <filter-name>cross-origin</filter-name> <filter-class>org.eclipse.jetty.servlets.CrossOriginFilter</filter-class> <init-param> <param-name>allowedOrigins</param-name> <param-value>*</param-value> </init-param> <init-param> <param-name>allowedMethods</param-name> <param-value>GET,POST</param-value> </init-param> <init-param> <param-name>allowedHeaders</param-name> <param-value>x-requested-with,content-type</param-value> </init-param> </filter>
(3) filter-mapping设置
找到文件中<filter-mapping>平级的位置,添加如下内容:
<filter-mapping> <filter-name>cross-origin</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
(4) 重启Geoserver服务
方案2
(1)下载cors-filter-1.7.jar,Java-property-utils-1.9.jar两个库文件
下载后,将其放到<Geoserver>\webapps\geoserver\WEB-INF\lib目录下。
下载地址:https://files.cnblogs.com/files/ytwy/jar.rar
(2)filter设置
打开<Geoserver>\webapps\geoserver\web.xml文件,找到文件中<filter>平级的位置,添加如下内容:
<filter-name>CORS</filter-name> <filter-class>com.thetransactioncompany.cors.CORSFilter</filter-class> <init-param> <param-name>cors.allowOrigin</param-name> <param-value>*</param-value> </init-param> <init-param> <param-name>cors.supportedMethods</param-name> <param-value>GET, POST, HEAD, PUT, DELETE</param-value> </init-param> <init-param> <param-name>cors.supportedHeaders</param-name> <param-value>Accept, Origin, X-Requested-With, Content-Type, Last-Modified</param-value> </init-param> <init-param> <param-name>cors.exposedHeaders</param-name> <param-value>Set-Cookie</param-value> </init-param> <init-param> <param-name>cors.supportsCredentials</param-name> <param-value>true</param-value> </init-param>
(3) filter-mapping设置
找到文件中<filter-mapping>平级的位置,添加如下内容:
<filter-mapping> <filter-name>CORS</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
相关文章
- SpringSecurity配置跨域访问[通俗易懂]
- 留言站开发手记 跨域相关
- axios如何跨域请求_前端跨域请求
- VUE请求跨域,如何设置代理
- vue前端怎么解决跨域问题_前端跨域调用js方法解决方案
- php跨域访问的session_php跳转到另一个php
- 设置 CORS 实现跨域请求
- 详解html2canvas图片跨域问题
- PHP允许前端跨域请求的相关请求头设置、文件下载
- flash上传控件跨域详解编程语言
- ajax 设置Access-Control-Allow-Origin实现跨域访问详解编程语言
- 深入了解Redis跨域设置(redis设置跨域)
- P3P和跨域(cross-domain)cookie访问(读取和设置)
- JS跨域代码片段
- 如何设置iframe高度自适应在跨域情况下的可用方法