geoserver发布wms服务和wmts服务,并在cesium上进行调用

本文详细介绍如何使用Geoserver发布TIFF影像为WMS及WMTS服务,并在Cesium中加载显示。从创建工作区、数据存储到发布服务,再到切片生成与前端调用,提供完整步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近的业务需求要求将一张tiff影像加载到cesium的地形上,网上查阅了很多资料,有很多的方法。结合我的业务需求需要使用开源软件,所以我考虑用geoserver发布wms以及wmts服务,然后cesium来调用。
首先我需要在geoserver上将tiff影像发布为wms服务,进而将wms服务通过切片生成wmts服务。网上给了很多解决方案,发现都是搬的GIS之家的文章,但是这篇文章写的真的不是太清楚。
链接:https://www.cnblogs.com/giserhome/p/7774548.html
下面我就我的经验进行详细的介绍。
1.首先是根据tiff发布wms服务。
第一步:进入geoserver后,点击工作区,然后选择“添加新的工作区”
在这里插入图片描述
新建工作区:
在这里插入图片描述
新建完成
在这里插入图片描述
第二步:添加数据存储,导入我们要发布的tiff影像
在这里插入图片描述
选择GeoTIFF数据源
在这里插入图片描述
在这里插入图片描述
第三步:发布数据
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
第四步:预览图层及参数获取
在这里插入图片描述
在layer preview中找到发布的图层,选择用openlayes进行预览。
进入后,打开f12,刷新看network下的请求,随意点击一个wms请求,查看详细信息。

在这里插入图片描述
在这里插入图片描述
第五步:cesium加载wms服务。
记住上一步几个参数后,在cesium中用如下代码调用:

var provider = new Cesium.WebMapServiceImageryProvider({ 
              url: 'http://112.***.**.**2:8080/geoserver/gwc/service/wms',   //第一个url参数
              layers: 'kj:kjtiff2',   //参数集合2 ,这里填充
              parameters: { 
                  service : 'WMS', 
                  format: 'image/png', 
                  transparent: true
              } 
          }); 
     viewer.imageryLayers.addImageryProvider(provider); 

调用结果:
在这里插入图片描述
我自己的亚太地区tiff影像就加上去了,其他地区的用了cesium默认的影像。
a------------------------------------------------------------

发布wmts服务

在“Tile layer”下,找到发布的切片选项。选择一种坐标系比例尺进行预览。在这里插入图片描述
预览wmts服务,表示wtms服务可用。不过此时看到的瓦片服务是geowebcache动态生成的,并没有生产全套的瓦片集合。
在这里插入图片描述
在想要生产瓦片的条目上点击“seed/Truncate”,意为以种子生产瓦片。
在这里插入图片描述
进入切图配置页面,对当前选择的地图服务进行瓦片生产参数的配置。
在这里插入图片描述
点击提交后,会跳转到对应的生产瓦片进程页面。如果没有出现这个,要不是瓦片生产数过少,瞬间完成了,要不就是geoserver报错了,如果你是在tomcat中部署的,请查看Catalina.out检查日志信息。
在这里插入图片描述
生产完成后,在geoserver数据目录的gwc目录下,找到对应服务命名的文件夹,查看生成的瓦片。
在这里插入图片描述
至此,wmts服务的瓦片生产已经完成了。
另外,在配置生产瓦片的时候有一个切片策略的参数,上面是用了默认的EPSG:900913。如果你需要,可以自己设置切图策略(自定义切图比例尺)
在这里插入图片描述
打开gridset,可以看到已系统已经内置了五种切片策略。点击Create a copy,配置自己的切片策略。 在这里插入图片描述
在这里插入图片描述
配置完成并保存后,在Caching defaults中,将你刚刚配置的新切片策略加入默认切片集,下次再切图就可以选择你自定义的切片策略了。在这里插入图片描述
a------------------------------------------------------------------------------------------------
wmts瓦片生产完了,如何在前端进行调用?

使用cesium加载wmts服务

要加载发布图层的切片地图服务,我们首先要找到几个重要参数:
工作空间:图层名称
在这里插入图片描述
服务地址:

http://192.168.213.202:8080/geoserver/gwc/service/wmts/rest/sichuan:sv1-03_20181210_l2a0000808046_1103190005003_011/{style}/{TileMatrixSet}/{TileMatrix}/{TileRow}/{TileCol}?format=image/png

获取方式:
在这里插入图片描述
打开wmts能力文档后,搜索对应的工作空间名称和图层名
在这里插入图片描述
向下查找找到对应的服务链接
在这里插入图片描述
另外还需要找到style,坐标系等参数,我这里的服务没有设置那么多,用默认值就可以了。
选择获取tile对象的ResourceURL,style是图层样式,TileMatrixSet是采用瓦片坐标系格式,TileMatrix(url需要将{TileMatrix}改为{TileMatrixSet}:{TileMatrix})代表该坐标系下的缩放级别,TileRow和TileCol代表着瓦片行列坐标。

var wmtsImageryProvider = new Cesium.WebMapTileServiceImageryProvider({
            url: 'http:///192.168.213.201:9090/geoserver/gwc/service/wmts/rest/sichuan:sv1-03_20181210_l2a0000808046_1103190005003_011/{style}/{TileMatrixSet}/{TileMatrixSet}:{TileMatrix}/{TileRow}/{TileCol}?format=image/png',
            layer: 'sichuan:sv1-03_20181210_l2a0000808046_1103190005003_011',
            style: '',
            format: 'image/png',
            tileMatrixSetID: 'EPSG:900913'      //一般使用EPSG:3857坐标系
        });
 viewer.imageryLayers.addImageryProvider(wmtsImageryProvider);

效果
在这里插入图片描述
打开控制台,查看请求,可以看到每次请求发送的具体参数,其中一个例子是:

http://192.168.213.201:9090/geoserver/gwc/service/wmts/rest/sichuan:sv1-03_20181210_l2a0000808046_1103190005003_011//EPSG%3A900913/EPSG%3A900913:13/3199/6698?format=image%2Fpng

这个链接的意思就是访问这个wmts瓦片服务在EPSG:900913坐标系下第13级,3199行,6698列的一个瓦片数据。

### 集成Cesium自定义坐标系与GeoServer服务 #### 定义配置自定义坐标系 为了使Cesium能够识别来自GeoServer的数据所使用的特定坐标参照系统(CRS),需要先确保该CRS被正确定义配置于GeoServer中。这通常涉及到在GeoServer内注册新的EPSG代码或创建本地投影定义文件[^1]。 对于某些特殊情况下未预设的坐标系,可以通过编辑`webapps/geoserver/WEB-INF/classes/proj.properties`来添加自定义的PROJ.4字符串描述新坐标系[^2]。完成此操作后重启GeoServer以应用更改。 #### 设置WMS/WMTS请求参数 当通过Cesium加载由GeoServer发布的Web地图服务(WMS)或Web地图切片服务(WMTS)时,需指定正确的SRS(空间参考系统)参数以便服务器返回适当坐标系统的图像瓦片或要素数据。例如,在构建ImageryProvider实例时设置`srsName`属性指向所需的坐标系: ```javascript const imageryLayer = new Cesium.WebMapServiceImageryProvider({ url : 'http://localhost:8080/geoserver/wms', layers : 'workspace:named_layer', parameters : { srsName : 'EPSG:900913' // 替换为实际使用的EPSG码 } }); viewer.imageryLayers.addImageryProvider(imageryLayer); ``` 如果要处理的是矢量数据,则可以利用Cesium Ion中的`Cesium.GeoJsonDataSource.fromUrl()`方法,同样传递相应的SRS名称作为查询参数之一[^3]。 #### 处理坐标转换问题 由于浏览器端默认采用Web Mercator (EPSG:3857)或其他标准地理坐标系显示地球模型,因此可能遇到客户端服务端之间存在坐标差异的情况。此时应考虑使用第三方库如Proj4js来进行必要的坐标变换,确保两者间的一致性[^4]。 ```javascript // 假定已引入proj4.js库 proj4.defs('EPSG:YOUR_CUSTOM_EPSG_CODE', '+proj=your_proj_definition'); function transformCoordinates(lonLatArray){ var sourceProjection = "EPSG:YOUR_CUSTOM_EPSG_CODE"; var destinationProjection = "EPSG:4326"; // 或者其他目标坐标系 return proj4(sourceProjection ,destinationProjection ,[lonLatArray[0], lonLatArray[1]]); } ```
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值