利用Geoserver的wfs BBOX范围查询及Openlayers解析GML,添加Marker
2009-01-19 17:57
501 查看
在经历了无数实验摸索及相关大侠的耐心收终于对Geoserve的wfs查询有了一定了解,现写出一点总结。
以下方法描述了对Geoserver进行范围查询,并将查询结果在用OpenLayers在地图上画出的实现方法。
首先wfs查询分为1.0.0和1.1.0两个版本,这两个版本的查询filter格式是不一样的,我是以1.0的格式写的,各位朋友可以研究一下1.1写法。
另外向Geoserver服务器发送请求,这里用到了prototype,在这里的prototype只是简单的发送了一个ajax请求。
比如要进行一个简单的范围查询,这里需要两个点来确定一下矩形,如:116.374614,39.949336和116.391498,39.955299
还要指定一个图层,比如:MyGis下的type图层,还有就是确定要返回的字段,如:NAME和TYPE,
整个的查询xml字符串如下:
<wfs:GetFeature service='WFS' version='1.0.0' outputFormat='GML2'
xmlns:topp='http://www.openplans.org/topp' xmlns:wfs='http://www.opengis.net/wfs'
xmlns:ogc='http://www.opengis.net/ogc' xmlns:gml='http://www.opengis.net/gml'
xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance'
xsi:schemaLocation='http://www.opengis.net/wfs http://schemas.opengis.net/wfs/1.0.0/WFS-basic.xsd'>
<wfs:Query typeName='MyGis:type'>
<wfs:PropertyName>MyGis:NAME</wfs:PropertyName>
<wfs:PropertyName>MyGis:TYPE</wfs:PropertyName>
<ogc:Filter><ogc:BBOX><ogc:PropertyName>the_geom</ogc:PropertyName>
<gml:Box srsName='http://www.opengis.net/gml/srs/epsg.xml#4326'>
<gml:coordinates>116.374614,39.949336 116.391498,39.955299</gml:coordinates>
</gml:Box></ogc:BBOX></ogc:Filter>
</wfs:Query></wfs:GetFeature>
Geoserver wfs查询的地址为:http://localhost:8080/geoserver/wfs
于是用Ajax.Request,发送一个ajax请求,代码如下:
var myAjax = new Ajax.Request(
GIS_SERVER_URL,
{contentType: "application/xml", method: 'post', postBody: xmlPara, onComplete: showResponse}
);
以上参数中: GIS_SERVER_URL为Geoserver wfs查询的地址,xmlPara为查询的xml字符串,showResponse为查询返回后的处理函数,
showResponse函数如下:
function showResponse(req){
//openlayers的GML解析器
var gmlParse = new OpenLayers.Format.GML();
var features = gmlParse.read(req.responseText);
var icon = new OpenLayers.Icon('images/pp.gif');
var feature, lonlat, marker;
for(var feat in features){
feature = features[feat];
lonlat = new OpenLayers.LonLat(feature.geometry.x,feature.geometry.y);
marker = new OpenLayers.Marker(lonlat,icon.clone());
//此处注册了鼠标的点击事件,可以在mousedown中做些事情
marker.events.register("mousedown", marker, mousedown);
//markers为OpenLayers.Layer.Markers 画点的层
markers.addMarker(marker);
}
}
以上便完成wfs查询并用openlayers标画结果的任务。
另外wfs的GetFeature还有许多查询功能,在Geoserver的样例查询中,有一些例子,比如主键查询,Between查询,更全面的功能就要看OGC WFS的白皮书了,filter可以实现如sql语句中的功能,不过白皮书中的讲解也不是很详细(可能是自己E文不够好吧~~),朋友们可以互相讨论一下~~
大家顺便可以看看我的这个网站
以下方法描述了对Geoserver进行范围查询,并将查询结果在用OpenLayers在地图上画出的实现方法。
首先wfs查询分为1.0.0和1.1.0两个版本,这两个版本的查询filter格式是不一样的,我是以1.0的格式写的,各位朋友可以研究一下1.1写法。
另外向Geoserver服务器发送请求,这里用到了prototype,在这里的prototype只是简单的发送了一个ajax请求。
比如要进行一个简单的范围查询,这里需要两个点来确定一下矩形,如:116.374614,39.949336和116.391498,39.955299
还要指定一个图层,比如:MyGis下的type图层,还有就是确定要返回的字段,如:NAME和TYPE,
整个的查询xml字符串如下:
<wfs:GetFeature service='WFS' version='1.0.0' outputFormat='GML2'
xmlns:topp='http://www.openplans.org/topp' xmlns:wfs='http://www.opengis.net/wfs'
xmlns:ogc='http://www.opengis.net/ogc' xmlns:gml='http://www.opengis.net/gml'
xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance'
xsi:schemaLocation='http://www.opengis.net/wfs http://schemas.opengis.net/wfs/1.0.0/WFS-basic.xsd'>
<wfs:Query typeName='MyGis:type'>
<wfs:PropertyName>MyGis:NAME</wfs:PropertyName>
<wfs:PropertyName>MyGis:TYPE</wfs:PropertyName>
<ogc:Filter><ogc:BBOX><ogc:PropertyName>the_geom</ogc:PropertyName>
<gml:Box srsName='http://www.opengis.net/gml/srs/epsg.xml#4326'>
<gml:coordinates>116.374614,39.949336 116.391498,39.955299</gml:coordinates>
</gml:Box></ogc:BBOX></ogc:Filter>
</wfs:Query></wfs:GetFeature>
Geoserver wfs查询的地址为:http://localhost:8080/geoserver/wfs
于是用Ajax.Request,发送一个ajax请求,代码如下:
var myAjax = new Ajax.Request(
GIS_SERVER_URL,
{contentType: "application/xml", method: 'post', postBody: xmlPara, onComplete: showResponse}
);
以上参数中: GIS_SERVER_URL为Geoserver wfs查询的地址,xmlPara为查询的xml字符串,showResponse为查询返回后的处理函数,
showResponse函数如下:
function showResponse(req){
//openlayers的GML解析器
var gmlParse = new OpenLayers.Format.GML();
var features = gmlParse.read(req.responseText);
var icon = new OpenLayers.Icon('images/pp.gif');
var feature, lonlat, marker;
for(var feat in features){
feature = features[feat];
lonlat = new OpenLayers.LonLat(feature.geometry.x,feature.geometry.y);
marker = new OpenLayers.Marker(lonlat,icon.clone());
//此处注册了鼠标的点击事件,可以在mousedown中做些事情
marker.events.register("mousedown", marker, mousedown);
//markers为OpenLayers.Layer.Markers 画点的层
markers.addMarker(marker);
}
}
以上便完成wfs查询并用openlayers标画结果的任务。
另外wfs的GetFeature还有许多查询功能,在Geoserver的样例查询中,有一些例子,比如主键查询,Between查询,更全面的功能就要看OGC WFS的白皮书了,filter可以实现如sql语句中的功能,不过白皮书中的讲解也不是很详细(可能是自己E文不够好吧~~),朋友们可以互相讨论一下~~
大家顺便可以看看我的这个网站
相关文章推荐
- 利用Geoserver的wfs BBOX范围查询及Openlayers解析GML,添加Marker
- GIS的学习(二十)基于Geoserver的WFS服务与Openlayers实现地理查询
- GIS的学习(二十)基于Geoserver的WFS服务与Openlayers实现地理查询
- 使用openlayers3自带的功能,使用WFS对geoserver服务器进行空间查询
- 基于Geoserver的WFS服务与Openlayers实现地理查询
- Openlayers3 请求Geoserver带Filter的WFS查询
- OpenLayers-添加Marker
- 利用内容观察者操作系统的联系人(查询,添加)
- 基于OpenLayers 的WFS模糊查询优化
- html angular+route:模糊查询+限定年龄范围+全部删除+批量删除+修改密码+添加用户
- 练习题——Gson解析、利用JDBC连接数据库进行数据的存取及查询等的综合
- OpenLayers WFS指定地理范围查询
- 解析Oracle数据扫描 Oracle SQL查询优化 引导局部范围数据扫描的方法(3)
- openlayers中利用vector实现marker的方式
- OpenLayers项目分析(五) 数据解析以GML为例
- Openlayers3 加载 GeoServer WFS的实现
- 《JavaWeb---简单应用---练习JDBC,JSTL》---上传Excel文件,利用工具包解析,将数据储存到数据库中,可以查询删除
- 基于OpenLayers 的WFS模糊查询优化
- 关于利用日期范围查询的My97DatePicker插件应用
- 用OpenLayers解析GML文件