天天看點

GeoServer中WMS、WFS的請求規範

Web地圖服務(WMS)利用具有地理空間位置資訊的資料制作地圖。其中将地圖定義為地理資料可視的表現。這個規範定義了三個操作:GetCapabitities傳回服務級中繼資料,它是對服務資訊内容和要求參數的一種描述; GetMap傳回一個地圖影像,其地理空間參考和大小參數是明确定義了的;GetFeatureInfo(可選)傳回顯示在地圖上的某些特殊要素的資訊。

Web要素服務(WFS)傳回的是要素級的GML編碼,并提供對要素的增加、修改、删除等事務操作,是對Web地圖服務的進一步深入。OGC Web要素服務允許用戶端從多個Web要素服務中取得使用地理标記語言(GML)編碼的地理空間資料,這個遠東定義了五個操作:GetCapabilites傳回Web要素服務性能描述文檔(用XML描述);DescribeFeatureType傳回描述可以提供服務的任何要素結構的XML文檔;GetFeature為一個擷取要素執行個體的請求提供服務;Transaction為事務請求提供服務;LockFeature處理在一個事務期間對一個或多個要素類型執行個體上鎖的請求。

URL例子:

參數意義:

GeoServer中WMS、WFS的請求規範

傳回結果:

其傳回結果為一個描述性XML文檔,包含了以下三個要素:

GeoServer中WMS、WFS的請求規範
GeoServer中WMS、WFS的請求規範

這裡對傳回的格式(format)有如下選擇:

GeoServer中WMS、WFS的請求規範
GeoServer中WMS、WFS的請求規範

注意:此請求同樣支援XML格式請求,如下:

GeoServer中WMS、WFS的請求規範
GeoServer中WMS、WFS的請求規範

 這裡對傳回的文本格式(info_format)有如下選擇:

GeoServer中WMS、WFS的請求規範

傳回結果(忽略中文亂碼):

GeoServer中WMS、WFS的請求規範
GeoServer中WMS、WFS的請求規範

傳回的結果為描述性XML,包含以下五個主要部分:

GeoServer中WMS、WFS的請求規範
GeoServer中WMS、WFS的請求規範

 傳回結果:

GeoServer中WMS、WFS的請求規範

這裡首先給出一個例子:

GeoServer中WMS、WFS的請求規範

 傳回結果為:

 {"type":"FeatureCollection","features":[{"type":"Feature","id":"jianfudan.322","geometry":{"type":"MultiPolygon","coordinates":[[[[30.276436000822056,120.20021],[30.275750000822033,120.20021],[30.22768400082126,120.22562],[30.245537000821543,120.17343000000001],[30.276436000822056,120.20021]]]]},"geometry_name":"the_geom","properties":{"limitid":71,"displayorder":null,"regionid":3,"validfromdate":"2016-05-15Z","validtodate":"2016-06-14Z","validflag":1,"media":null,"shape_length":null,"shape_area":null,"graphicid":322,"regionname":"江幹區","eventtypes":null,"otherrequest":null,"limitname":"上報區域71"}},{"type":"Feature","id":"jianfudan.318","geometry":{"type":"MultiPolygon","coordinates":[[[[30.26407600082185,120.19668600000001],[30.26407600082185,120.196434],[30.262875000821833,120.20785],[30.24708200082157,120.203896],[30.255150000821704,120.187164],[30.26407600082185,120.19668600000001]]]]},"geometry_name":"the_geom","properties":{"limitid":72,"displayorder":null,"regionid":3,"validfromdate":"2016-05-04Z","validtodate":"2016-06-03Z","validflag":1,"media":"http://172.18.6.197:8081/MediaRoot/null/20160505/72/84989ee1-9bab-4640-8f24-4a7381f1c4e8/機票預訂.png","shape_length":null,"shape_area":null,"graphicid":318,"regionname":"江幹區","eventtypes":"亂搭亂建,暴露垃圾,積存垃圾渣土,路面不潔,河道不潔(含溝渠、湖面)","otherrequest":"測試","limitname":"上報區域72"}}],"crs":{"type":"EPSG","properties":{"code":"4490"}}}

<Filter xmlns:ogc="http://www.opengis.net/ogc" xmlns:gml="http://www.opengis.net/gml">

<Intersects>

<PropertyName>the_geom</PropertyName>

<gml:Envelope srsName="EPSG:4326">     

<gml:lowerCorner>120.15336460382575 30.2743621901609</gml:lowerCorner>

<gml:upperCorner>120.167097513982 30.28809510031715</gml:upperCorner>

</gml:Envelope>

</Intersects>

</Filter>

<Filter xmlns:ogc="http://www.opengis.net/ogc" xmlns:gml="http://www.opengis.net/gml">

<Intersects> 

<gml:MultiPolygon srsName="EPSG:4326"> 

<gml:polygonMember> 

<gml:Polygon> 

<gml:outerBoundaryIs> 

<gml:LinearRing>

<gml:coordinates xmlns:gml="http://www.opengis.net/gml" decimal="." cs="," ts="">

120.15677,30.2557 120.15677,30.26351 120.16833,30.26351 120.16833,30.2557 120.15677,30.2557

</gml:coordinates>  

</gml:LinearRing>  

</gml:outerBoundaryIs>  

</gml:Polygon>  

</gml:polygonMember>  

</gml:MultiPolygon>

因為GET請求的資料量大小在4kb以内,是以Post為更常用的方法。以下為一個具體的例子:

GeoServer中WMS、WFS的請求規範

其中直接發送的為一個XML檔案,其Filter中可以填寫的内容和GET中的Filter一樣。

具體内容如下:

<?xml version='1.0' encoding='GBK'?><wfs:GetFeature service='WFS' version='1.0.0' outputFormat='JSON'

xmlns:wfs='http://www.opengis.net/wfs'

xmlns:ogc='http://www.opengis.net/ogc'

<wfs:Query typeName='cell'>

<wfs:PropertyName>the_geom</wfs:PropertyName>

<wfs:PropertyName>test1</wfs:PropertyName>

<ogc:Filter>

<Or>

<PropertyIsEqualTo><PropertyName>test1</PropertyName><Literal>valuetest1</Literal></PropertyIsEqualTo>

<PropertyIsEqualTo><PropertyName>test2</PropertyName><Literal>valuetest2</Literal></PropertyIsEqualTo>

</Or>

</ogc:Filter>

</wfs:Query>

</wfs:GetFeature>

該方法支援對要素的增删改。這裡直接給出Post請求中發送的XML組織格式:

<wfs:Transaction service="WFS" version="1.0.0"  

       outputFormat="GML2"  

       <wfs:Insert handle="someprj1">

          <opengis:someprj>

             <opengis:the_geom>

                             <gml:coordinates decimal="." cs="," ts="">13404701.212,3850391.781</gml:coordinates>

                </gml:Point>

             </opengis:the_geom>

             <opengis:ssds>13</opengis:ssds>

             <opengis:qqybh>12</opengis:qqybh>

             <opengis:status>0</opengis:status>

          </opengis:someprj>

       </wfs:Insert>  

    </wfs:Transaction>

       <wfs:Update typeName="opengis:qqyproject">

     <wfs:Property>  

       <wfs:Name>qqybh</wfs:Name>

       <wfs:Value>12</wfs:Value>

     </wfs:Property>

      <ogc:Filter>   

      <ogc:PropertyIsEqualTo>

      <ogc:PropertyName>qqybh</ogc:PropertyName>

      <ogc:Literal>0</ogc:Literal>

      </ogc:PropertyIsEqualTo>

     </ogc:Filter>   

       </wfs:Update>   

       <wfs:Delete typeName="opengis:qqyproject">

      <ogc:PropertyIsLessThan>

      <ogc:Literal>12</ogc:Literal>

      </ogc:PropertyIsLessThan>

      <ogc:PropertyIsGreaterThan>

      </ogc:PropertyIsGreaterThan>

       </wfs:Delete>   

a.動态出圖可以使用WMS中的GetMap請求。

b.矢量查詢可以使用WFS中的GetFeature請求。

c.要素編輯可以使用WFS中的Transaction請求。

                                                                           如果您覺得本文确實幫助了您,可以微信掃一掃,進行小額的打賞和鼓勵,謝謝 ^_^

                                      

GeoServer中WMS、WFS的請求規範