GeoServer基础教程(五):使用OpenLayers调用GeoServer发布的地图服务
2018-01-29 14:58
567 查看
在前面几节的关于GeoServer的基础教程中,我们介绍了如何使用GeoServer发布地图数据等基本的服务器端的操作,这一节我们继续学习如何使用GeoServer和OpenLayers的结合来发布地图服务。
OpenLayers(http://openlayers.org)是一个专为Web GIS客户端开发提供的JavaScript类库包,用于实现标准格式发布的地图数据访问。OpenLayers 支持的地图来源包括Google Maps、Yahoo、
Map、微软Virtual Earth 等,用户还可以用简单的图片地图作为背景图,与其他的图层在OpenLayers 中进行叠加。除此之外,OpenLayers实现访问地理空间数据的方法都符合行业标准。OpenLayers 支持Open GIS 协会制定的WMS(Web Mapping Service)和WFS(Web Feature Service)等网络服务规范,可以通过远程服务的方式,将以OGC服务形式发布的地图数据加载到基于浏览器的OpenLayers客户端中进行显示。
使用开源的GeoServer和OpenLayers发布地图服务在Web GIS部署中比较常用。本文将结合GeoServer和OpenLayers发布一个地图服务示例。
大家可以下载我编写的示例程序文件作为学习参考。下载地址:http://pan.baidu.com/share/link?shareid=4130147131&uk=1746237888。下面是效果图:
要提供Web GIS服务,首要的是提供所需的地图数据,我们首先根据GeoServer基础教程(三):部署发布Shapefile地图数据一文所讲,部署好需要的地图数据。具体发布的地图数据大家可以使用文中提到的示例数据,也可以使用自己的地图数据。
发布地图数据完成之后修改所属工作区:
验证WMS是否发布成功,在浏览器中输入地址:http://localhost:8080/geoserver/wms,看到如下图所示内容表示发布成功。
我的示例数据使用的是同济大学校园地图,上文中的下载文件里并不包含地图数据,所以大家应该替换使用自己的地图数据。
创建一个web项目GisOpenlayersGeoserver,OpenLayers的包添加的时候很多注意不要加入不必要的包。
(不用在意是Java项目或者net项目,原理一样,引入openlayers后编写html。不想创建项目的可以在上面网盘上下载的基础上更改wms及其包含的要素图层为自己的)
网页的内容最终需要利用html展示出来,我们需要对html标记语言有基本的了解,如果需要对样式进行美化还需要css的相关知识,这里不再赘述,对次相关知识不熟悉的朋友,建议先阅读w3school提供的html基础教程和css基础教程。
此处对应index.html和style.css文件。
OpenLayers实际上是一个专为Web GIS客户端开发提供的JavaScript类库包。如果需要真正用好这个工具,我们必须具备熟练的JavaScript相关知识。考虑到我们的应用比较简单,大家可以直接学习OpenLayers的用户文档(http://docs.openlayers.org)来熟悉JavaScript的语法知识等。
此处对应config.js文件。
至此,使用GeoServer和OpenLayers发布地图服务已经圆满完成了,不出意外的话,我们已经可以通过浏览器来访问刚刚发布的地图服务页面了。随着对GeoServer和OpenLayers的应用能力提升,大家可以根据自身需求,继续美化或者增强此地图服务的功能。
到这里,GeoServer基础教程系列已经基本完成。
OpenLayers(http://openlayers.org)是一个专为Web GIS客户端开发提供的JavaScript类库包,用于实现标准格式发布的地图数据访问。OpenLayers 支持的地图来源包括Google Maps、Yahoo、
Map、微软Virtual Earth 等,用户还可以用简单的图片地图作为背景图,与其他的图层在OpenLayers 中进行叠加。除此之外,OpenLayers实现访问地理空间数据的方法都符合行业标准。OpenLayers 支持Open GIS 协会制定的WMS(Web Mapping Service)和WFS(Web Feature Service)等网络服务规范,可以通过远程服务的方式,将以OGC服务形式发布的地图数据加载到基于浏览器的OpenLayers客户端中进行显示。
使用开源的GeoServer和OpenLayers发布地图服务在Web GIS部署中比较常用。本文将结合GeoServer和OpenLayers发布一个地图服务示例。
大家可以下载我编写的示例程序文件作为学习参考。下载地址:http://pan.baidu.com/share/link?shareid=4130147131&uk=1746237888。下面是效果图:
发布地图数据
要提供Web GIS服务,首要的是提供所需的地图数据,我们首先根据GeoServer基础教程(三):部署发布Shapefile地图数据一文所讲,部署好需要的地图数据。具体发布的地图数据大家可以使用文中提到的示例数据,也可以使用自己的地图数据。发布地图数据完成之后修改所属工作区:
验证WMS是否发布成功,在浏览器中输入地址:http://localhost:8080/geoserver/wms,看到如下图所示内容表示发布成功。
我的示例数据使用的是同济大学校园地图,上文中的下载文件里并不包含地图数据,所以大家应该替换使用自己的地图数据。
创建一个web项目GisOpenlayersGeoserver,OpenLayers的包添加的时候很多注意不要加入不必要的包。
(不用在意是Java项目或者net项目,原理一样,引入openlayers后编写html。不想创建项目的可以在上面网盘上下载的基础上更改wms及其包含的要素图层为自己的)
编写网页html文件
网页的内容最终需要利用html展示出来,我们需要对html标记语言有基本的了解,如果需要对样式进行美化还需要css的相关知识,这里不再赘述,对次相关知识不熟悉的朋友,建议先阅读w3school提供的html基础教程和css基础教程。此处对应index.html和style.css文件。
引入使用OpenLayers控制发布地图数据
OpenLayers实际上是一个专为Web GIS客户端开发提供的JavaScript类库包。如果需要真正用好这个工具,我们必须具备熟练的JavaScript相关知识。考虑到我们的应用比较简单,大家可以直接学习OpenLayers的用户文档(http://docs.openlayers.org)来熟悉JavaScript的语法知识等。此处对应config.js文件。
继续美化或增强功能
至此,使用GeoServer和OpenLayers发布地图服务已经圆满完成了,不出意外的话,我们已经可以通过浏览器来访问刚刚发布的地图服务页面了。随着对GeoServer和OpenLayers的应用能力提升,大家可以根据自身需求,继续美化或者增强此地图服务的功能。到这里,GeoServer基础教程系列已经基本完成。
相关文章推荐
- 使用GeoServer+OpenLayers发布和调用WMTS、Vector Tile矢量切片服务 | Publishing and Calling WMTS, Vector Tile Service Using GeoServer + OpenLayers
- OpenLayers调用arcgis server发布的地图服务
- Openlayers调用 GeoWebcache 发布的ArcGIS切片服务或IIS发布的切片图片
- 使用openlayers 3 在线加载天地图及GeoServer发布的地图
- 使用GeoServer+QGIS发布WMTS服务 | Publishing WMTS Service Using GeoServer+QGIS
- PostGIS+QGIS+GeoServer+OpenLayers实现数据的存储、服务的发布以及地图的显示
- (转)PostGIS+QGIS+GeoServer+OpenLayers实现数据的存储、服务的发布以及地图的显示
- PostGIS+QGIS+GeoServer+OpenLayers实现数据的存储、服务的发布以及地图的显示
- 使用GeoServer发布shp数据为WMS服务和WFS服务(图文教程)
- 使用Geoserver(其实是Geowebcache) 发布本地的ArcGIS 切片地图
- 通过Java代码自动发布Geoserver的地图服务WMS
- GeoServer基础教程(六):使用GeoServer发布PostGIS表数据
- GeoServer基础教程(二):GeoServer的Web管理界面快速入门
- GeoServer基础教程(三):部署发布Shapefile地图数据
- Openlayers访问GeoServer发布的地图服务
- 在WCF中调用Server.MapPath 获取服务发布目录路径
- 在WCF中调用Server.MapPath 获取服务发布目录路径
- OpenLayers调用天地图在线服务
- 在WCF中调用Server.MapPath 获取服务发布目录路径
- Flex4.0+Blaseds+Spring+Hibernate实现地图服务发布平台(并结合GEOTOOLS)