Web 项目跨域问题及常见解决方法---以 Geoserver 跨域问题为例

本文开始介绍跨域的原因、解决跨域常用方法,最后以 Geoserver 为例,解决跨域问题。

跨域问题

跨域问题是经常遇到的问题,尤其是在地图开发中,本文以 geoserver 跨域为例,介绍一下工作中解决跨域问题的几种方法。

跨域简介

跨域问题解释:浏览器从一个域名的网页去请求另一个域名的资源时,域名、端口、协议任一不同,都是跨域。

这里其实简单理解就是:网址和端口不一致就会发生跨域,是浏览器的一种保护机制,比如:

页面地址为:localhost:8080

发起请求:localhost:8008(端口不一致)
或者 127.0.0.1 :8080 (IP不一致)
或者 127.0.0.1:8008(IP+端口不一致)

三种情况都会引起跨域。因此,只能发起 localhost:8080 请求。

以 geoserver 为例,比如本机 geoserver 服务端口为 8080,前端服务端口为8008(端口不允许重复),当前端使用地图加载 geoserver 图层的时候,请求一般为 http://localhost:8080/geoserver/工作区/wms?其他参数,由于前端端口为8008,跟 geoserver 不同,因此会发生跨域。

在这里插入图片描述


解决跨域常用方法

解决跨域方法一般分为:前端代理、后端处理、其他代理(nginx)、浏览器设置允许跨域(不推荐,不介绍),用的较多的主要是使用代理解决,也是主流比较推荐的。

前端代理

前端代理,其实就是利用 vue 框架或者 react 框架 来实现(实际由webpack完成),通过配置文件,添加代理,前端请求的时候直接发起 本地请求,由 代理转发至真实地址,浏览器显示的为本地地址。
vue 代理配置

后端处理

后端处理的话,分两种情况:

  1. 服务端开放允许跨域 ,大多数服务端为了安全性,也是不放开跨域。

    springboot 项目为例,只需要在需要开放允许跨域的 controller 类或者具体某方法上边,加上注解(@CrossOrigin(origins = “*”))即可。

    除此之外,还要注意权限问题,是否被拦截等等。

    其他框架跨域基本大同小异,可以根据框架搜索方法设置。
    在这里插入图片描述

  2. 服务端转发想跨域的服务接口

    如果是调用 其他项目的接口,接口提供方不允许开放跨域权限,可以通过 后台转发 的方式解决跨域,同时也隐藏了真实接口地址;不过坏处就是,转发会 增加延时,也增加了接口宕机的风险。

    具体操作可以搜索 HttpUtil 工具来实现,确认好格式、类型即可,比较简单。

    前端调用的话,直接调用转发服务即可(保持转发服务IP端口和前端请求一致)。
    在这里插入图片描述

其他代理(nginx)

笔者用的主要还是 nginx,现在主流的部署环境也是nginx居多,这里以 nginx 为例。

在现在前后端分离的环境下,前端项目一般是静态页面包,直接使用 nginx 代理发布即可(参考 nginx部署静态页面)。

启动 nginx 之后,直接访问本地服务的指定代理接口(比如:/geoserver),即可转发至正确的服务,浏览器端显示本地地址。

访问地址:localhost:8085/geoserver/其他参数

浏览器显示地址:localhost:8085/geoserver/其他参数

实际请求地址:127.0.0.1:8888/geoserver/其他参数

在这里插入图片描述


Geoserver 解决跨域

对于 geoserver 的跨域,以上方法均可解决,如果是 vue、react 等构建框架开发的话,直接通过前端代理设置即可。

但是,前端代理方式,正式部署的时候就不起作用了;此时可以通过 nginx 代理,可以解决跨域问题。


除了以上方法,还可以通过修改 geoserver 配置,来实现跨域(实际上就是服务端开放允许跨域),操作也不复杂,适合不擅长 nginx 和传统前端开发者。

具体步骤如下:(如果报错,可以去官网下载最新版本 jar 包)

  1. 首先需要两个 jar 包和一个类,如图
    在这里插入图片描述
  2. 将两个jar包文件放入geoserver目录下web容器的类库文件夹中,注意目录路径
    在这里插入图片描述
  3. 打开geoserver目录(或者其他服务端项目)下web容器的中的xml配置文件,增加过滤器
    在这里插入图片描述
<filter>
    <filter-name>cros</filter-name>
    <filter-class>com.mapsharp.server.SimpleCORSFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>cros</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>
  1. 添加过滤器代码和过滤器路由代码。将com文件夹放入classes中
    在这里插入图片描述
  2. 重启 geoserver
    在这里插入图片描述

免费解决跨域工具:geoserver解决跨域

参考博客均已放在文中链接。

解决过程遇到问题可以留言沟通。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

非科班Java出身GISer

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

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

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

打赏作者

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

抵扣说明:

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

余额充值