WMS、WFS、WMTS服务接口说明

1 需求

最近在作一个地方标准时涉及到一些OGC的服务调用和具体传参问题,以此作为记录方便查阅。

2 TL;DR

可以直接查看福州天地图的文档
WMS: http://tdt.fuzhou.gov.cn/help/APIPfs/2.htm
WMTS: http://tdt.fuzhou.gov.cn/help/APIPfs/3.htm
WFS: http://tdt.fuzhou.gov.cn/help/APIPfs/4.htm

3 内容

3.1 WMS

WMS服务简介

Web Map Service(网络地图服务),简称WMS,由开放地理信息联盟(Open GeoSpatial Consortium,OGC)制定。该规范定义了Web客户端从网络地图服务器获取地图的接口标准。一个WMS可以动态地生成具有地理参考数据的地图,这些地图通常用GIF、JPEG或PNG等图像格式,或者SVG、KML、VML和WebCGM等矢量图形格式来表现。使用者通过指定的参数获取相应的地图图片。

服务操作列表

WMS实现规范由三个基础性操作协议(GetCapabilities,GetMap和GetFeatureInfo)组成,这些协议共同构成了利用WMS创建和叠加显示不同来源的远程异构地图服务的基础。WMS服务操作列表见下表所示。

操作实现要求描述
GetCapabilities强制实现获取WMS的能力文档(即元数据文档),里面包含服务的所有信息
GetMap强制实现获取地图图片。该操作根据客户端发出的请求参数在服务端进行检索,服务器端返回一个地图图像,其地理空间参数和大小参数是已经明确定义的,返回的地图图像可以是GIF、JPEG、PNG或SVG格式。
GetFeatureInfo选择实现该操作根据用户所请求的X、Y坐标或感兴趣的图层,返回地图上某些特殊要素的信息,信息以HTML,GML或ASCII的格式表示。
服务操作的参数列表
GetCapabilities操作请求方法实现参数
参数名称参数个数参数类型和值
service1个(必选)字符类型,服务类型值为“WMS”
request1个(必选)字符类型,请求的操作名称,值为“GetCapabilities”
version0或1个(可选)字符类型,值为请求的WMS的版本号
format0或1个(可选)MIME类型,值为服务元数据的输出格式
updateSequence0或1个(可选)字符类型,可取的值有none、any、equal、lower、higher,用来表示缓存数据更新的方式
GetMap操作请求方法实现参数
参数名称参数个数参数类型和值
service1个(必选)字符类型,服务类型标识值为“WMS”
request1个(必选)字符类型,值为“GetMap”
version1个(必选)字符类型,值为请求的WMS的版本号
layers1个(必选)字符类型,值为一个或多个地图图层列表,多个图层之间用”,”隔开
styles1个(必选)字符类型,值为请求图层的地图渲染样式
CRS1个(必选)字符类型,值为坐标参照系统
BBOX1个(必选)Wkt格式,值为某个CRS下的地图边界范围的坐标序列
width1个(必选)整型类型,值为地图图片的像素宽度
height1个(必选)整型类型,值为地图图片的像素高度
format1个(必选)字符类型,值为地图的输出格式
transparent0或1个(可选)字符类型,值为true或者false,用来表示地图图层是否透明(默认情况下是不透明的)
bgcolor0或1个(可选)值为十六进制的RGB值,表示地图的背景颜色
exceptions0或1个(可选)值为WMS的异常信息报告的格式(默认情况下是XML格式)
time0或1个(可选)时间类型,值为时间值,表示需要在图层中有时间信息
elevation0或1个(可选)数字类型,值为高程值,表示需要在图层中有高程信息
GetFeatureInfo操作请求方法实现参数
参数名称参数个数参数类型和值
service1个(必选)字符类型,服务类型标识值为“WMS”
request1个(必选)字符类型,值为“GetFeatureInfo”
version1个(必选)字符类型,值为请求的WMS的版本号
map request part1个(必选)字符类型,值为获得地图的部分操作参数
query_layers1个(必选)字符类型,值为查询的一个或多个地图图层列表,多个图层之间用”,”隔开
info_format1个(必选)MIME类型,值为请求信息的返回类型
I1个(必选)整型类型,值为待查询点的在地图图片上的像素列号
J1个(必选)整型类型,值为待查询点的在地图图片上的像素行号
feature_count0或1个(可选)整型类型,值为返回信息中的要素的个数(默认是1)
exceptions0或1个(可选)值为WMS的异常信息报告的格式(默认情况下是XML格式)

接口调用示例

操作调用示例
GetCapabilitieshttp://tdt.fuzhou.gov.cn/serviceaccess/WMS/DMDZ?version=1.1.1&request=GetCapabilities&service=WMS
GetMaphttp://tdt.fuzhou.gov.cn/serviceaccess/WMS/DMDZ?version=1.1.1&request=GetMap&service=WMS&mapservice=DMDZ&layers=1&styles=default&width=1164&height=371&format=png&transparent=true&srs=EPSG%3A4490&bbox=119.28758165903027,26.090243729688037,119.28914270467693,26.0907412794603

3.2 WMTS

WMTS服务简介

Web Map Tile Service(网络地图瓦片服务),简称WMTS,由开放地理信息联盟(Open GeoSpatial Consortium,OGC)制定,是和WMS并列的重要OGC规范之一。WMTS不同于WMS,它最重要的特征是采用缓存技术能够缓解WebGIS服务器端数据处理的压力,提高交互响应速度,大幅改善在线地图应用客户端的用户体验。WMTS是OGC主推的缓存技术规范,是目前各种缓存技术相互兼容的一种方法。

服务操作列表

WMTS服务支持RESTful访问,其接口包括GetCapabilities、GetTile和GetFeatureInfo3个操作,这些操作允许用户访问切片地图。

操作操作描述
GetCapabilities强制实现获取WMTS的能力文档(即元数据文档),里面包含服务的所有信息
GetTile强制实现获取地图瓦片。该操作根据客户端发出的请求参数在服务端进行检索,服务器端返回地图瓦片图像。
GetFeatureInfo选择实现通过在WMTS图层上指定一定的条件,返回指定的地图瓦片内容对应的要素信息
服务操作的参数列表
GetCapabilities操作请求方法实现参数
参数名称参数个数参数类型和值
service1个(必选)字符类型,服务类型值为“WMTS”
request1个(必选)字符类型,请求的操作名称,值为“GetCapabilities”
acceptVersions0或1个(可选)字符类型,值为请求的WMTS的版本号
sections0或1个(可选)字符类型,请求元数据文档0或多个节的名称,多个名称之间用“,”隔开,不须按顺序排列。值为空默认返回整个元数据文档
updateSequence0或1个(可选)字符类型,值为increased,为空时默认返回最新的元数据文档
acceptFormat0或1个(可选)MIME类型,值为服务元数据的输出格式
GetTile操作请求方法实现参数
参数名称参数个数参数类型和值
service1个(必选)字符类型,服务类型标识值为“WMTS”
request1个(必选)字符类型,请求的操作值为“GetTile”
version1个(必选)字符类型,值为请求的WMTS的版本号
layer1个(必选)字符类型,值为请求的图层名称
style1个(必选)字符类型,值为请求图层的渲染样式
format1个(必选)字符类型,值为瓦片地图的输出格式
tileMatrixSet1个(必选)字符类型,瓦片矩阵数据集,其值在服务的元数据文档中指定
tileMatrix1个(必选)字符类型,瓦片矩阵,其值在服务的元数据文档中指定
tileRow1个(必选)整型类型,值为大于0的整数,表示瓦片矩阵的行号
tileCol1个(必选)整型类型,值为大于0的整数,表示瓦片矩阵的列号
Other sample dimensions0或1个(可选)字符类型,其他允许的参数
GetFeatureInfo操作请求方法实现参数
参数名称参数个数参数类型和值
service1个(必选)字符类型,服务类型值为“WMTS”
request1个(必选)字符类型,请求的操作值为“GetFeatureInfo”
version1个(必选)字符类型,值为请求的WMTS的版本号
J1个(必选)整型类型,值为大于0的整数,表示瓦片上一指定像素点的行号
I1个(必选)整型类型,值为大于0的整数,表示瓦片上一指定像素点的列号
info_format1个(必选)MIME类型,值为请求信息的返回类型
layer, style, format, Sample dimension, tileMatrixSet, tileMatrix, tileRow, tileCol1个(必选)这些参数的值应与请求GetTile的相应参数保持一致

接口调用示例

实例名称调用实例
GetCapabilities操作http://tdt.fuzhou.gov.cn/serviceaccess/wmts/Vector2012CGCS2000?service=WMTS&request=GetCapabilities
GetTile操作http://tdt.fuzhou.gov.cn/serviceaccess/wmts/Vector2012CGCS2000?service=WMTS&request=GetTile&layer=0&style=default&tileMatrixSet=sss&tileMatrix=10&tileRow=93074&tileCol=435872&format=image/png

3.3 WFS

WFS服务简介

Web Feature Service(网络要素服务),简称WFS,由开放地理信息联盟(Open GeoSpatial Consortium,OGC)制定。该规范主要对OpenGIS简单要素的数据编辑操作进行规范,从而使服务器端和客户端能够在要素层面进行“通讯”。其返回结果的是XML格式的WFS服务元数据文档,通过该文档用户能够了解:WFS服务器支持的所有操作操作列表,GetFeature操作返回的数据格式,可用的坐标参照系统列表,操作异常信息的列表,WFS服务提供商的相关信息,WFS服务器的可用要素类列表等。

服务操作列表

WFS服务接口规范定义了GetCapabilities,DescribeFeatureType、GetFeature、Transaction、GetGmlObject和LockFeature一共6种操作。其中,前三个GetCapabilities,DescribeFeatureType和GetFeature为必须实现的操作,也即只要实现了这三个操作的服务均可称为WFS服务。WFS的操作见下表所示。

操作实现要求描述
GetCapabilities强制实现GetCapabilities请求用于查询WFS服务的能力信息,包括支持的操作、支持的格式、空间坐标、包含的资源等。它主要的目的是使客户端在使用GetFeature请求前可以对WFS服务有一个基本的了解,从而可以设置正确的参数。
DescribeFeatureType强制实现用于生成一个 Schema 描述,该 Schema 描述了 WFS 服务提供的要素类型(Feature Type),以及要素类型的结构信息。该 Schema 还定义了 WFS 服务所期望的要素实例在输入时如何编码以及输出时如何生成要素实例。
GetFeature强制实现GetFeature用于向WFS的客户端程序提供查询特定地理信息的能力,通过GetFeature操作可以由指定的属性条件、空间条件或者两者叠加的条件进行空间查询。
Transaction选择实现允许Transaction操作,使客户端可对服务器端所提供的地图要素类执插入,更新,删除等命令
GetGmlObject选择实现通过XLink获取GML对象
LockFeature选择实现在事务过程中锁定要素
服务操作的参数列表
GetCapabilities操作请求方法实现参数
参数名称参数个数参数类型和值
service1个(必选)字符类型,服务类型值为“WFS”
request1个(必选)字符类型,请求的操作名称,值为“GetCapabilities”
versions0或1个(可选)字符类型,值为请求的WFS的版本号
DescribeFeatureType操作请求方法实现参数
参数名称参数个数参数类型和值
service1个(必选)字符类型,服务类型值为“WFS”
request1个(必选)字符类型,请求的操作名称,值为“DescribeFeatureType”
typeName0或1个(可选)字符类型,值为要素类型的列表,多个值之间用“,”隔开,默认解析包括的全部要素类型
outputFormat0或1个(可选)MIME类型,值为输出格式
GetFeature操作请求方法实现参数
参数名称参数个数参数类型和值
service1个(必选)字符类型,服务类型标识值为“WFS”
request1个(必选)字符类型,请求的操作值为“GetFeature”
typeName1个(必选)字符类型,值为请求的要素类型的名称,多个名称之间用“,”隔开
version0或1个(可选)字符类型,值为请求的WFS的版本号
outputFormat0或1个(可选)MIME类型,值为输出格式
resultType0或1个(可选)字符类型,值为请求的结果类型
propertyName0或1个(可选)字符类型,值为请求要素的属性名,多个值之间用“,”隔开
featureVersion0或1个(可选)字符类型,值为要素的版本,值为ALL返回请求的要素的所有版本,没有值默认为返回请求要素的最新版本
maxFeature0或1个(可选)整型类型,值为请求要素的最大数,默认值为满足查询的所有结果集
expiry0或1个(可选)数字类型,要素被锁定的时间
SRSName0或1个(可选)字符类型,值为坐标系统名
featureID0或1个(可选)字符类型,值为要素的ID,多个ID之间用“,”隔开
filter0或1个(可选)请求要素的过滤条件
bBox0或1个(可选)Wkt格式,请求指定要素查询范围,可以替代featureId和filter参数
sortby0或1个(可选)字符类型,查询结果属性值的排序依据

接口调用示例

操作调用示例
GetCapabilitieshttp://tdt.fuzhou.gov.cn/serviceaccess/WFS/DMDZ_WFS-G?service=WFS&request=GetCapabilities&version=1.0.0
DescribeFeatureTypehttp://tdt.fuzhou.gov.cn/serviceaccess/WFS/DMDZ_WFS-G?service=WFS&request=DescribeFeatureType&typename=DMDZ:地名&version=1.0.0
GetFeaturehttp://tdt.fuzhou.gov.cn/serviceaccess/WFS/DMDZ_WFS-G?service=WFS&request=GetFeature&typename=DMDZ:地名&version=1.0.0&maxFeature=20
GeoServer是一个开源的地理空间数据服务器,它支持网络要素服务WFS)的多个版本。根据引用,GeoServer提供了对WFS 1.0.0、1.1.0和2.0.0三个版本的支持。 WFS是一种用于通过网络传输地理空间数据的协议。根据引用,GeoServer对每种支持的GML格式可以选择不同的SRS格式。SRS格式可以影响返回数据的轴顺序和几何字段的坐标。GeoServer支持使用EPSG Code和URN来格式化地理坐标。EPSG Code以经度/纬度(x/y)的顺序格式化数据,而URN以地理和制图系统的传统轴顺序(即纬度/经度(y/x))格式化数据。具体的格式化方式取决于不同的WFS版本和GML格式。 对于操作示例,根据引用,可以使用KVP格式的URL来访问GeoServer的WFS服务。例如,可以使用类似"http://localhost:8080/geoserver/wfs?service=wfs&version=2.0.0&request=DescribeFeatureType&typeNames=topp:states"的URL来请求描述特征类型。 总之,GeoServer是一个开源的地理空间数据服务器,支持多个版本的WFS。它可以根据不同的GML格式选择不同的SRS格式,并使用KVP格式的URL来访问其WFS服务。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Geoserver学习笔记-3、服务标准(WFS)](https://blog.csdn.net/weixin_38670190/article/details/104908524)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值