裁剪WMS服务
正常的WMS服务加载的图层,要么是全要素渲染,要么是子集要素渲染(通过CQL_FILTER参数)。裁剪WMS服务就是只显示给定范围内的要素,范围外的要素不显示,比如只渲染一个矩形范围内,矩形外无渲染。
实现方式
1.采用SQL视图的方式发布一个图层:
原理就是根据pg表定义一个视图,视图的作用是重新计算数据源,通过%param%定义参数,接收外部传入的显示区域,然后通过pg的函数将区域范围转换成geometry,然后再通过pg的函数st_intersection对pg表中的几何字段进行裁剪,形成一个动态的数据源。
其中参数值可以是geojson,wkt,wkb等等,不同的参数值需要对应的函数转成geometry,比如:geojson -> st_geomgromgeojson,wkt -> st_geomfromtext,wkb -> st_geomfromwkb。
最后需要给参数设置默认值(可以采用中国四至范围),以支持默认情况下,与正常的WMS服务请求一致。
2.请求示例:
对于SQL视图,geoserver支持在WMS、WFS等OGC标准服务中,通过viewparams参数来定义SQL视图的参数,官方描述如下:
所以完整裁剪WMS服务请求如下:
那么作为对比,默认情况下的结果如下:
注意事项:
1.传入的区域范围坐标系要与pg表中的几何字段坐标系一致,如果pg中的几何字段坐标系不是0,那么在使用st_geomfeomtext转换几何时,需要指定srid,否则会报错 mix srid。
2.如果区域范围的值很长,建议使用POST请求,GET的请求URL有大小限制。
3.如果请求的是一个面图层,那么区域范围的坐标精度要与面图层的坐标精度保持一致,否则在裁剪时会出现鲁棒性错误,无法裁剪而报错。
4.当前使用的版本时2.15.3,在geoserver的高版本中,WMS请求多了一个clip参数,支持使用WKT裁剪图层:
5.当然,这种方式对性能肯定会有影响的,因为需要大量计算裁剪,所以如果数据量比较打,请谨慎使用。
结语:
geoserver的sql视图是一个很灵活的发布服务方式,满足一些特殊的需求,不止是pg,mysql同样可以,简直是屡试不爽。