首页 > 其他分享 >WebGIS|使用Openlayers获取Geoserver发布的WFS和WCS服务

WebGIS|使用Openlayers获取Geoserver发布的WFS和WCS服务

时间:2023-04-09 19:14:47浏览次数:44  
标签:WCS ol WebGIS new js Openlayers import WFS 图层

1、发布WFS和WCS服务

发布WFS服务

Web 要素服务(WFS)

支持对地理要素的插入,更新,删除,检索和发现服务。该服务根据HTTP客户请求返回GML数据。

其基础接口是:GetCapabilities,DescribeFeatureType,GetFeature

  • GetCapabilities同上。
  • DescribeFeatureType返回要素结构,以便客户端进行查询和其他操作。
  • GetFeature可根据查询要求返回一个符合GML规范的数据文档。GetFeature是最重要的接口。

其它接口如Transaction 它不仅能提供要素读取,同时支持要素在线编辑和事务处理。

WFS对应于常见桌面程序中的条件查询功能,WFS通过OGC Filter构造查询条件,支持基于空间几何关系的查询,基于属性域的查询,当然还包括基于空间关系和属性域的共同查询。

在Web上,WFS的请求不是以SQL实现的,而是通过Filter XML来实现,可扩展性更强。WFS所返回的是查询的结果集,从某种程度上说,区别于WMS的数据的表现,WFS的结果集是由完整的Schema定义和约束的结果集,以GML为载体。这个结果集,类似于桌面程序查询结果的数据表。

命名和启用

输入图层名称等基本信息,将图层勾选为启用

image-20230312155722907

配置坐标系和边框

选择坐标系,这里选择的是EPSG: 4326,即WGS84。

image-20230312160316995

下方边框,主要是用于每次初始化加载时,显示的边界范围,即在web页面里面,默认缩放到能够刚好放下本数据的范围。直接点击从数据中读取即可,下面也是点击从数据中计算。

image-20230312160855585

配置shp文件style

style文件主要是对发布出来的文件,进行样式的调整,本次不做详细讲解,只要能使用即可,后续系列文章中可能会做讲解。
上面的步骤完成后返回最上方,点击发布按钮,下方default style 就是本次数据默认的样式,如果有已经配置好的其他style可以选择其他央视,但一般style要与shp文件本身几何特征匹配,例如:polygon特征的要素,只能使用polygon的style文件,同理还有point和line。

image-20230312161117523

配置文件的缓存服务

点击上方Tile caching 按钮,进入文件缓存配置,通过这个配置可以使geoserver开启被动切片,把Tile cache configuration的两个选项勾选上,即可开启被动缓存。

image-20230312161215482

发布完成

点击保存,发布图层,之后会自动跳转至图层管理,这里能够看到我们发布的数据图层,但是浏览需要通过其他位置来浏览。

image-20230312161453751

发布WCS服务

上传栅格数据至Geoserver,并发布WCS服务

Web地理覆盖服务(WCS)

提供的是包含了地理位置信息或属性的空间栅格图层,而不是静态地图的访问。

根据HTTP客户端要求发送相应数据,包括影像,多光谱影像和其它科学数据.

有二个重要操作GetCapabilities,GetCoverage

  • GetCapabilities返回一个描述服务和XML文档,从中可获取覆盖的数据集合。
  • GetCoverage是在GetCapabilities确定查询方案和需要获取的数据之后执行,返回覆盖数据。

还有可选操作DescribeCoverageType。

命名和启用

输入图层名并启用图层

image-20230329210345176

配置坐标系和边框

配置图层的坐标系等信息:

image-20230401150716437

查看图层的波段信息:

image-20230329210500165

发布完成

点击保存,发布图层,之后会自动跳转至图层管理,这里能够看到我们发布的数据图层,但是浏览需要通过其他位置来浏览。

image-20230401150926047

2、在物理机中使用任意支持WCS和WFS客户端访问其中数据

使用OpenLayers访问数据

加载WFS服务

查看api可知,调用wfs有两种方式,一种是采用loader加载,另一种是通过url加载,前者可设置为jsonp的方式可直接解决跨域的问题,后一种需要在服务器端设置跨域。这里选择第一种方式加载WFS服务。

2023432317_4

HTML代码

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <title>WFS - GetFeature</title>
  <link rel="stylesheet" href="node_modules/ol/ol.css">
  <style>
    .map {
      width: 100%;
      height: 400px;
    }
  </style>
</head>

<body>
  <div id="map" class="map"></div>
  <!-- Pointer events polyfill for old browsers, see https://caniuse.com/#feat=pointer -->
  <script src="https://cdn.jsdelivr.net/npm/elm-pep@1.0.6/dist/elm-pep.js"></script>
  <script type="module" src="main.js"></script>
</body>

</html>

js代码

import Map from 'ol/Map.js';
import VectorSource from 'ol/source/Vector.js';
import View from 'ol/View.js';
import {Circle as CircleStyle, Fill, Style} from 'ol/style.js';
import {GeoJSON, WFS} from 'ol/format.js';
import {Vector as VectorLayer} from 'ol/layer.js';
import {getCenter} from 'ol/extent';

const vectorSource = new VectorSource();
const vector = new VectorLayer({
  source: vectorSource,
  style: new Style({
    image: new CircleStyle({
      radius: 5,
      fill: new Fill({
        color: 'orange',
      }),
    }),
  }),
});

const extent = [109.6475, 29.495, 115.9675, 33];
const map = new Map({
  layers: [vector],
  target: document.getElementById('map'),
  view: new View({
    extent: extent,
    projection: 'EPSG:4326',
    center: getCenter(extent),
    maxZoom: 19,
    zoom: 12,
  }),
});

// generate a GetFeature request
const featureRequest = new WFS().writeGetFeature({
  srcName: 'EPSG:4326',
  featureNS: 'http://8.130.73.89:8080/geoserver/tjl_webgis/wfs',
  featureTypes: ['tjl_webgis:point'],
  outputFormat: 'application/json',
});

// then post the request and add the received features to a layer
fetch('http://8.130.73.89:8080/geoserver/tjl_webgis/wfs', {
  method: 'POST',
  body: new XMLSerializer().serializeToString(featureRequest),
})
  .then(function (response) {
    return response.json();
  })
  .then(function (json) {
    const features = new GeoJSON().readFeatures(json);
    vectorSource.addFeatures(features);
    map.getView().fit(vectorSource.getExtent());
  });

调用WFS服务结果

image-20230402235350320

加载WCS服务

openlayer调用wcs服务是通过wms来实现的。

image-20230402211134993

HTML代码

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>Single Image WMS</title>
    <link rel="stylesheet" href="node_modules/ol/ol.css">
    <style>
      .map {
        width: 100%;
        height: 400px;
      }
    </style>
  </head>
  <body>
    <div id="map" class="map"></div>
    <!-- Pointer events polyfill for old browsers, see https://caniuse.com/#feat=pointer -->
    <script src="https://cdn.jsdelivr.net/npm/elm-pep@1.0.6/dist/elm-pep.js"></script>
    <script type="module" src="main.js"></script>
  </body>
</html>

js代码

import ImageWMS from 'ol/source/ImageWMS.js';
import Map from 'ol/Map.js';
import Projection from 'ol/proj/Projection.js';
import View from 'ol/View.js';
import {Image as ImageLayer} from 'ol/layer.js';
import {getCenter} from 'ol/extent';

const layers = [
  new ImageLayer({
    extent: [
      398708.62925706623, 3462872.5714283627, 497798.62925706623,
      3525422.5714283627,
    ],
    source: new ImageWMS({
      url: 'http://8.130.73.89:8080/geoserver/tjl_webgis/wms',
      params: {
        'LAYERS': 'tjl_webgis:tdly_2015',
        'ratio': 1,
        'serverType': 'geoserver',
        'exceptions': 'application/vnd.ogc.se_inimage',
        'FORMAT': 'image/png',
        'VERSION': '1.1.0',
      },
    }),
  }),
];
const projection = new Projection({
  code: 'EPSG:32649',
  extent: [
    398708.62925706623, 3462872.5714283627, 497798.62925706623,
    3525422.5714283627,
  ],
});

const extent = [
  398708.62925706623, 3462872.5714283627, 497798.62925706623,
  3525422.5714283627,
];
const map = new Map({
  layers: layers,
  target: 'map',
  view: new View({
    projection: projection,
    center: getCenter(extent),
    zoom: 4,
  }),
});

调用WCS服务结果

image-20230402164941301

标签:WCS,ol,WebGIS,new,js,Openlayers,import,WFS,图层
From: https://www.cnblogs.com/tangjielin/p/17300811.html

相关文章

  • web开发报错合集(基于openlayers)
    1、UncaughtTypeError:Cannotreadpropertiesofundefined(reading'getViewport')  代码:(位于代码页最上面)1//添加一个按钮,用于触发样式函数2......
  • Openlayers中使用Cluster实现点位元素重合时动态聚合与取消聚合
    场景Openlayers中使用Cluster实现缩放地图时图层聚合与取消聚合:Openlayers中使用Cluster实现缩放地图时图层聚合与取消聚合_BADAO_LIUMANG_QIZHI的博客-上面实现缩放地图时......
  • OpenLayers change 事件获取当前值
    这里有个change:resolution事件但是事件的内容没有value,只有oldValueZc {type:'change:resolution',target:F,key:'resolution',oldValue:9786.603971778399......
  • WebGIS|GML简介
    GML介绍GML是基于XML的空间信息编码标准,由OpenGISConsortium(OGC)提出,得到了许多公司的大力支持,如Oracle、Galdos、MapInfo、CubeWerx等。运用GML,封装的地理数据和图形......
  • Vue+Openlayers实现绘制线段并测量距离显示
    场景在上面已经实现交互式绘制线段基础上,怎样实现测量距离。注:关注公众号霸道的程序猿获取编程相关电子书、教程推送与免费下载。实现1、页面上添加按钮与map<template>......
  • Openlayers中设置定时绘制和清理直线图层
    场景Openlayers中实现地图上添加一条红色直线:在上面实现绘制一条红色直线的基础上,怎样对该红线进行清除。在某些条件下进行绘制和清除直线,下面通过定时器来反复实现绘制和清......
  • Openlayers中点击地图获取坐标并输出
    场景Openlayers中加载Geoserver切割的EPSG:900913离线瓦片地图并显示:在上面加载离线瓦片地图显示的基础上怎样在地图上点击并能获取到坐标。实现效果如下:注:​​关注公众号......
  • Openlayers中实现地图上添加一条红色直线
    场景Openlayers中加载Geoserver切割的EPSG:900913离线瓦片地图并显示:在上面加载离线瓦片地图显示的基础上,需要根据起点和终点两个坐标实现添加一条红色直线。实现效果如下 ......
  • WebGIS|阿里云服务器配置Geoserver并发布服务
    前期准备购买阿里云的ECS服务器,创建实例,进入实例概述,查看这个实例的基本情况,这里我的实例的操作系统为系统为Ubuntu20.04。内存为4G,这里要注意的是公网IP,这时之后我们访......
  • WebGIS|OpenLayers加载Geoserver发布的图层数据
    OpenLayers加载WMS服务总的来说有两种方式:ol.layer.Image+ol.source.ImageWMS和ol.layer.Tile+ol.source+TileWMS这两种方式加载都需要设定bounds(bbox)和projection。openl......