geoserver跨域问题多种解决方案

文章介绍了在使用Geoserver时可能会遇到的跨域问题,并提供了四种解决方案:通过nginx配置代理,修改tomcat的web.xml,配置Geoserver自身的CORS设置,以及前端的跨域处理。详细阐述了每种方法的步骤和相关配置。
摘要由CSDN通过智能技术生成

geoserver发布服务完成之后,很重要的一个应用场景是前端服务调用,来展示服务数据,那么很可能遇到一个跨域问题,今天我们分享一下跨越问题的多种解决方案,来适用不同需求的业务场景。

一、nginx服务均衡策略

如果你的项目正在使用nginx,那么很简单操作,在conf/nginx.conf文件里面添加一个路由配置

1、添加路由

方案一:

       location /geoserver{
            proxy_pass http://127.0.0.1:8080/geoserver;
			proxy_set_header Host $host;
			proxy_set_header X-Real-IP $remote_addr;
			proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
			
			fastcgi_buffer_size 4k;
			fastcgi_buffers 8 4k;
			
             #proxy_pass http://mape.shanghai-map.net/arcgis/;
            #index  index.html index.htm;
			 #   指定允许跨域的方法,*代表所有
			add_header Access-Control-Allow-Methods *;

			#   预检命令的缓存,如果不缓存每次会发送两次请求
			add_header Access-Control-Max-Age 3600;
			#   带cookie请求需要加上这个字段,并设置为true
			add_header Access-Control-Allow-Credentials true;

			#   表示允许这个域跨域调用(客户端发送请求的域名和端口) 
			#   $http_origin动态获取请求客户端请求的域   不用*的原因是带cookie的请求不支持*号
			add_header Access-Control-Allow-Origin $http_origin;

			#   表示请求头的字段 动态获取
			add_header Access-Control-Allow-Headers 
			$http_access_control_request_headers;
        }

方案二:

    server {
        listen       8083;
        server_name  127.0.0.1;
		
		location /geoserver {
			proxy_pass http://127.0.0.1:8080/geoserver;
			proxy_set_header Host $host:$server_port;  # 携带端口(如 localhost:8081)?:ml-citation{ref="1,5" data="citationList"}
			proxy_set_header X-Forwarded-Proto $scheme;  # 传递协议(http/https)?:ml-citation{ref="1" data="citationList"}
			proxy_set_header X-Forwarded-Port $server_port;  # 传递客户端访问的端口?:ml-citation{ref="1" data="citationList"}
			# 强制添加跨域响应头
			add_header 'Access-Control-Allow-Origin' '*' always;
			add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS' always;
			add_header 'Access-Control-Allow-Headers' 'DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range' always;
			add_header 'Access-Control-Expose-Headers' 'Content-Length,Content-Range' always;
		}
}

方案三

   location /geoserver {
        proxy_pass http://127.0.0.3:8088;
        proxy_set_header Host $http_host;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header Remote-Addr $remote_addr;
        proxy_set_header Remote-Port $remote_port;
        proxy_pass_header Server;

        add_header Access-Control-Allow-Credentials true;
        add_header Access-Control-Allow-Headers 'x-requested-with,authorization,Content-Type,Authorization,credential,X-XSRF-TOKEN,token,username,client,merchant';
        add_header Access-Control-Allow-Methods 'POST,PUT,GET,DELETE';
        add_header Access-Control-Allow-Origin *;

        if ($request_method = 'OPTIONS') {
            return 204;
        }
    }

  配置里有关于跨越的配置,可以认真看一下。

2、重启nginx服务,前端就可以调用了

3、测试是否解决跨域问题

curl -I -X OPTIONS http://localhost:8081/geoserver/wms \  
-H "Origin: http://your-frontend-domain.com" \  
-H "Access-Control-Request-Method: GET"  

预期输出:

HTTP/1.1 204 No Content  
Access-Control-Allow-Origin: *  
Access-Control-Allow-Methods: GET, POST, OPTIONS  
Access-Control-Allow-Headers: DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range  

或者命令

curl -I -X GET http://localhost:8081/geoserver/wms \  
-H "Origin: http://your-frontend-domain.com"  

 预期输出

HTTP/1.1 200 OK  
Access-Control-Allow-Origin: *  

二、配置tomcat

如果是采用war包形式部署的geoserver服务,那么tomcat容器是一个不错的选择。

1、配置web.xml

进入tomcat的conf/web.xml

<filter>
  <filter-name>CorsFilter</filter-name>
  <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
  <init-param>
    <param-name>cors.allowed.origins</param-name>
    <param-value>*</param-value>
  </init-param>
</filter>
<filter-mapping>
  <filter-name>CorsFilter</filter-name>
  <url-pattern>/*</url-pattern>
</filter-mapping>

三、修改配置geoserver服务

1、去掉相应注释

geoserver下的web.xml文件相应的CORS注释去掉

apache-tomcat-7.0.72\webapps\geoserver\WEB-INF\web.xml 路径

把此注释去掉。

2、引入jar包

在geoserver安装目录,打开lib文件夹:

apache-tomcat-7.0.72\webapps\geoserver\WEB-INF\lib

放入以下三个jar:

然后重启tomcat服务就OK了。

四、前端配置

前端配置跨越我不太专业,大家可以参考以下这些博客:
前端处理跨越

跨越问题解决参考

到此,geoserver跨域问题多种解决方案分享完成,下篇我们分享图层数据的多种样式配置方法,敬请期待!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

寅灯

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

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

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

打赏作者

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

抵扣说明:

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

余额充值