113 lines
4.2 KiB
Markdown
113 lines
4.2 KiB
Markdown
|
---
|
|||
|
title: 发布PostGIS表
|
|||
|
date: 2021-01-02
|
|||
|
author: ac
|
|||
|
tags:
|
|||
|
- GeoServer
|
|||
|
- PostGIS
|
|||
|
categories:
|
|||
|
- GIS
|
|||
|
---
|
|||
|
|
|||
|
### 一、环境准备
|
|||
|
|
|||
|
> PostgreSQL 与 PostGIS 版本的对应关系:https://trac.osgeo.org/postgis/wiki/UsersWikiPostgreSQLPostGIS
|
|||
|
|
|||
|
data:image/s3,"s3://crabby-images/eba16/eba1674c155e5c5853322872d72284c64369b32e" alt="image-20210103112553404"
|
|||
|
|
|||
|
#### 1. 安装PostgreSQL
|
|||
|
|
|||
|
在决定好[PostgreSQL](https://www.postgresql.org/download/)和[PostGIS](http://postgis.net/install/)的版本后,去下载相应版本的安装包。(这里使用的是windows平台下的)
|
|||
|
|
|||
|
#### 2.安装PostGIS
|
|||
|
|
|||
|
data:image/s3,"s3://crabby-images/f911f/f911f35a1b61945f1b3d97c4aa45e2b1629cd38b" alt="image-20210103124629859"
|
|||
|
|
|||
|
安装完`PostgreSQL`后,开始安装空间数据的扩展模块`PostGIS`。
|
|||
|
|
|||
|
安装方式都比较简单,一直下一步就可以安装成功。安装PostGIS过程中可以选择创建空间数据库的模版数据库,勾选后会提示输入本地安装的`PostgreSQL`用户密码和被创建的模版数据库名称。
|
|||
|
|
|||
|
data:image/s3,"s3://crabby-images/bcdf2/bcdf2b491c0ba88e2c9a32f5afbb08e2a9a380db" alt="image-20210104193738153"
|
|||
|
|
|||
|
data:image/s3,"s3://crabby-images/5330c/5330c9bbec5ee412c421d85efc7fc6880a32df02" alt="image-20210104193553642"
|
|||
|
|
|||
|
data:image/s3,"s3://crabby-images/95a97/95a9741ba5bafe21be2d33207be29e41548621b3" alt="image-20210104193649416"
|
|||
|
|
|||
|
安装完 PostGIS 后,PostGIS 是作为一个可选的扩展模块,如果要使用它,除了模版数据库外,其他数据库必须在数据库中启用它。
|
|||
|
|
|||
|
```sql
|
|||
|
-启用PostGIS(从3.0版开始仅包含geometry/geography)
|
|||
|
CREATE EXTENSION postgis;
|
|||
|
```
|
|||
|
|
|||
|
启动成功后库中就会多一张`spatial_ref_sys`表。
|
|||
|
|
|||
|
data:image/s3,"s3://crabby-images/fb4e2/fb4e2ee7dbe0d91f83c9c7db185be929d1c7d0b1" alt="1614651456262"
|
|||
|
|
|||
|
### 二、示例
|
|||
|
|
|||
|
现在根据GeoServer官网上的教程走一遍:
|
|||
|
|
|||
|
#### 1.下载数据
|
|||
|
|
|||
|
[`nyc_buildings.zip`](https://docs.geoserver.org/2.13.2/user/_downloads/nyc_buildings.zip) 。
|
|||
|
|
|||
|
<img src="./images/1614651794891.png" alt="1614651794891" style="zoom: 67%;" />
|
|||
|
|
|||
|
#### 2.导入数据
|
|||
|
|
|||
|
将`nyc_buildings.sql`的内容粘贴到查询窗口中执行,刷新Tables就可以看到对应的表了;
|
|||
|
|
|||
|
data:image/s3,"s3://crabby-images/a7c0f/a7c0f9e2daa947a943e532b34f9682e9c0b37015" alt="1614653900504"
|
|||
|
|
|||
|
#### 3. 添加新的workspace
|
|||
|
|
|||
|
填写配置信息。
|
|||
|
|
|||
|
<img src="./images/1614654613622.png" alt="1614654613622" style="zoom:67%;" />
|
|||
|
|
|||
|
> 工作区名称是描述项目的标识符。不能超过10个字符,也不能包含空格。名称空间URI(统一资源标识符)通常可以是与项目关联的URL,并添加一个指示工作区的尾随标识符。文件中的名称空间URI不需要解析为实际有效的web地址。
|
|||
|
|
|||
|
#### 4. 新增数据存储
|
|||
|
|
|||
|
data:image/s3,"s3://crabby-images/37510/3751087b618284c2215023cc7b803daabec4e870" alt="1614654863978"
|
|||
|
|
|||
|
选择`PostGIS-PostGIS Database` 数据源。
|
|||
|
|
|||
|
<img src="./images/1614654957830.png" alt="1614654957830" style="zoom:80%;" />
|
|||
|
|
|||
|
<img src="./images/1614655151107.png" alt="1614655151107" style="zoom: 67%;" />
|
|||
|
|
|||
|
选择新建的工作区,配置数据源名称,填写刚导入数据的数据库的连接信息。
|
|||
|
|
|||
|
> 其中的`Expose primary keys` 是暴露主键,每张导入postgis的矢量数据表都会生成一个`gid`属性,作为矢量数据记录的标识。对于事务WFS,该表必须具有主键。没有主键的表被视为对 GeoServer 只读。
|
|||
|
>
|
|||
|
|
|||
|
#### 5. 创建图层
|
|||
|
data:image/s3,"s3://crabby-images/e25b4/e25b47a12ecccb543337135c2c19526f7cefb40f" alt="1614655648265"
|
|||
|
|
|||
|
在保存数据源后,系统会检测该数据源中存在的矢量数据。这里我点击“发布”就可以进入图层的配置界面:
|
|||
|
|
|||
|
主要的配置是【数据】tab页的 **坐标参考系统**、**边框** ,这里已经识别了数据的坐标参考系,点击"从数据中计算"和"Compute from native bounds"就会填充数据边框。
|
|||
|
|
|||
|
data:image/s3,"s3://crabby-images/8b7b9/8b7b9117abb2faf420a908e541fb5e662819a660" alt="1614655982617"
|
|||
|
|
|||
|
关于图层的样式,在【发布】tab页的WMS settings 中的Default Style 进行配置,这里我们选择了GeoServer自带的默认的面样式。选择完后点击“保存”,图层就发布完毕了。
|
|||
|
|
|||
|
<img src="./images/1614656321318.png" alt="1614656321318" style="zoom:80%;" />
|
|||
|
|
|||
|
#### 6.图层预览
|
|||
|
|
|||
|
返回主页,点击`layer Preview`,选择需要预览的图层的预览格式。也可以直接点击"Common Formats"中的`Openlayers`进行预览。
|
|||
|
|
|||
|
data:image/s3,"s3://crabby-images/776ba/776baaf12c28fa7e7f53684ad37d6c17c553125f" alt="1614656685144"
|
|||
|
|
|||
|
这里选择`PNG`图片格式查看。
|
|||
|
|
|||
|
<img src="./images/16146568142281.png" alt="16146568142281" style="zoom:67%;" />
|
|||
|
|
|||
|
### 参考文献
|
|||
|
|
|||
|
[1] `Publicshing a PostGIS Table` https://docs.geoserver.org/latest/en/user/gettingstarted/postgis-quickstart/index.html
|
|||
|
|