WEBGIS:从创建空间数据库、发布数据到调用WMS服务全栈演示

WEBGIS:从创建空间数据库、发布数据到调用WMS服务全栈演示

一、将shp数据导入到postgis数据库

  1. 安装所需要的软件和环境,需要PostgreSQL数据库文件创建和存储软件和postgis空间数据导入工具软件:以下是我安装的相关软件的版本,安装的版本首选稳定性
Postgresql15:用于创建数据库和管理数据 下载网址(https://www.postgresql.org/download/)

Postgis-bundle-pg15:用于导入具有空间属性的数据到创建的数据库里面,根据Postgresql的版本来下载相对应的版本。
下载网址(https://www.postgresql.org/download/)
  1. 打开postgresql软件下面的pgmin模块,输入密码(该密码就是安装该软件的时候设置的密码)
  2. 刷新网址就可以看到软件界面都变成中文显示
  3. 创建数据库:右键左边栏的数据库然后创建一个新的数据库,数据库命名,然后选择数据库的用户(postgres),创建好数据库之后还没有结束
  4. 数据确定导入:设置好SRID后点击导入 ,导入成功之后就可以使用pgmin软件打开数据库然后进行SQL语句查询

连接数据库:点击最上方的【View connection details…】选项然后填写导入的目标数据库相关信息

在这里插入图片描述


图表 1:该表是一个示例,第一个是数据库拥有者的名字,第二个是数据库的密码,第三个是默认的,最后一个是自己创建的数据库的名字

空间数据导入到SQL数据库:首先打开安装的postgis软件中的(PostGIS Post Boundle 1 for PostgreSQL *64 15Shapefile and DBF Loader Exporter)模块,然后点击添加文件,将需要导入的矢量文件选中,然后就可以看到这个界面:

在这里插入图片描述


接下来要设置里面的SRID码,该代码就是指代该空间数据的地理或投影坐标系的编号,我们可以使用Arcmap软件打开该矢量数据,然后查看该数据属性(源)就可以获取该矢量数据的SRID码

创建数据库拓展服务:选中新建的数据库,然后点击:

在这里插入图片描述


该功能框进入到数据库查询界面,在该界面输入:create extension postgis;然后点击运行按钮(▶)就可以启动拓展服务

在这里插入图片描述

设置软件中文显示:

在这里插入图片描述


在这里插入图片描述

二、将postgis数据库中的数据发布成标准地图服务

  1. 需要安装的软件或者应用有:

1.1先安装Java的运行环境(安装可以存放到D盘),安装结束后可以配置运行路径,然后打开cmd(win + r)输入:java -version
1.2然后安装 Tomcat服务器,该安装路径要与Java的安装路径是一致的,安装过程中需要注意的是有一个安装用户和密码的设置,后续使用tomcat登录服务器访问geosever服务然后登陆使用的账号就是这个

在这里插入图片描述


访问localhost:8080端口查看是否可以成功访问

1.3安装geosever:将【geosever.war】压缩包文件裁剪然后粘贴到(./Tomcat7.0/webapps)的目录下就可以了,粘贴后会自动出现一个geosever文件夹(或者可以手动解压到该文件夹目录下)至于该安装包的下载可以直接访问

geosever官网https://geoserver.org/download/
在这里插入图片描述


在这里插入图片描述

Figure :以上是我下载的相应软件的版本安装包和压缩包2. 安装所需的软件之后我们可以基于以下两个步骤来访问到geosever网站

2.1步骤一:访问tomcat软件的端口localhost:8080,然后在该网页点击【ManageApp】输入账号和密码(这里的信息就是安装tomcat是设置的账号和密码,一般为admin和123456),进去管理员的界面,我们要点击启动geosever,启动服务。

在这里插入图片描述

2.2步骤二:直接输入网址:

http://localhost:8080/geoserver/web/

就可以跳转到geosever网址(当然这两种方法都是在已经启动tomcat服务器的前提下),进入网址之后也要登录用户(这里登录的与tomcat那里登录的用户和密码是一样的)

在这里插入图片描述

添加新的数据存储:点击【数据存储】,然后点击【添加新的数据存储】,在对话框里面选择要导入的数据类型的数据库,我们导入的是矢量数据,所以
将里面的数据库数据添加到新的数据工作区,这里选择postgis来导入矢量数据
接下来还要设置几个参数:

这一张示意截图不是我自己创建的,这个是我在网上学习的时候顺便截的,是B站的一名技术博主,如果有侵犯权益联系我删除

>这一张示意截图不是我自己创建的,这个是我在网上学习的时候顺便截的,是B站的一名技术博主,如果有侵犯权益联系我删除

Geosever创建新的工作区:点击左边菜单栏的【工作区】,然后点击【添加新的工作区】,给新建的工作命名,命名空间也是随便(有一定格式),除此之外还要选择服务(这里选择WMS和WFS服务,WFS服务开启方便后续进行数据动态更新和修改与序列化),最后可以点击【提交】

在这里插入图片描述


在这里插入图片描述

4.1工作区:选择刚刚新建的工作区
4.2数据源名称:这里是自己新命名一个新的名称(建议英文)
4.3database:选择要导入的数据库(本次在postgreSQL 15新建的数据库名称)
4.4user:数据库的拥有者,一般为posgres
4.5passwd:数据库的密码(就是在pgmin那里新建的数据库的密码123456)

在这里插入图片描述
  1. 出现问题:通过导入数据库的形式来发布数据库的空间数据但是没有自动跳转到发布的界面,这时候你需要确定新建的工作区是否选择服务,确定选择服务了之后就点击左边菜单栏的【服务】里面的【WMS】,然后再此界面选择新建的工作区,就可以发布连接的数据库里面的数据表作为新图层了

数据预览:点击左边菜单栏的【layer view】,然后找到自己的工作区,点击添加的图层名称就可以预览数据啦

在这里插入图片描述


在这里插入图片描述

如果没有发布选项,我们可以点击左边菜单栏下的【数据】目录下的【图层】选项,然后再点击【添加新的资源】,再选择新建的工作区导入的数据库作为新的图层,就可以看到成功导入的postgis数据库下面的数据表,然后依次点击发布即可(发布里面的设置按照上面的示例)

在这里插入图片描述

设置好之后就可以点击【保存】,然后点击【发布】,点击发布还会进入到设置阶段,在这里需要设置边框数据(一般是自动计算出来),计算出来之后就可以点击保存了

在这里插入图片描述

三、使用OpenLayers调用wms服务加载发布地图

  1. 具体实现效果:可以使用open layers地图框架在浏览器应用上面调用Geosever发布的地图服务。
  2. 打开geosever管理客户端:localhost:8080/geosever/web,点击图层栏然后先选择要导入的图层(这些图层都是已经提前发布好的了)
  3. 调用WMS数据源的语法结构:
//WMS图层 - ImageLayer类型(先增加数据源然后增加数据图层)const WMSsource =newImageWMS({url:'http://localhost:8080/geoserver/WEBsevse/wms',params:{'LAYERS':'WEBsevse:bou2_4p','VERSION':'1.1.0','FORMAT':'image/png','TRANSPARENT':true,'SRS':'EPSG:4326','STYLE':''},serverType:'geoserver',crossOrigin:'anonymous',ratio:1});const WMSLayer =newImageLayer({source:WMSsource,opacity:0.7,visible:true})
  1. crossOrigin是跨域配置:anonymous表示任何人都可以访问

自有数据加载成功界面:

在这里插入图片描述


点击【切换为城市矢量地图】按钮切换图层

在这里插入图片描述

如果出现报错:由于跨域问题(编译器是localhost:5432,浏览器是localhost:8080)无法加载数据,我们可以采用以下解决方案(可以选择添加服务,如果源文件有对应的代码,只是被注释掉了,我们取消注释即可,该文件位于tomcat/conf/web.xml)

在这里插入图片描述


说明:如果源web.xml文件里面没有对应的跨域服务,我们可以自己添加对应的代码,但是一定要好好检查,一般是有的,只是被注释掉了

params里面的参数设置是数据源信息的设置,没有规律可言,要在geosever数据查询的网页那里查看:

在这里插入图片描述


说明:差不多是这样(不重要,可以继续往下做)

注意参数设置:第一个参数是url,geosever地图服务的地址,这个地址可以直接在geosever里面的数据浏览那里的网页复制,或者可以在该浏览器页面然后点击【检查】来实现请求来查看url码:
方法一:直接复制浏览器界面的头顶位置上面的网址,里面有url需要的信息

在这里插入图片描述


方法二:

在这里插入图片描述


在这里插入图片描述


以上三张查看url码的截图也是我在B站学习时直接截取的(只是一个方法和途径说明的作用)

结语:创作不易,给个赞吧🥺。文章如有不对的地方或者对文章有疑问的欢迎私信or联系小编,交流乐意至极。如果需要小编的完整web地图项目(or只需要代码)的欢迎留言。

Read more

WebGIS视角下基孔肯雅热流行风险地区分类实战解析

WebGIS视角下基孔肯雅热流行风险地区分类实战解析

目录 前言 一、关于基孔肯雅热 1、病原学特征 2、流行病学特征 3、疫情处置 4、预防措施 二、流行风险地区空间可视化 1、流行风险地区分类标准 2、空间查询基础 3、Leaflet空间可视化 三、流行风险地区WebGIS展示 1、Ⅰ类地区 2、Ⅱ类地区 3、Ⅲ类地区 4、Ⅳ类地区 四、总结 前言         在全球化与城市化进程不断加速的当下,传染病的传播范围与速度呈现出前所未有的态势,给公共卫生安全带来了严峻挑战。基孔肯雅热作为一种由基孔肯雅病毒引起的急性传染病,近年来在多个地区引发疫情,其传播速度快、感染范围广,且易与其他蚊媒传染病叠加流行,严重威胁着人类健康和社会稳定。准确划分基孔肯雅热流行风险地区,对于制定科学合理的防控策略、优化医疗资源配置以及提高公众防范意识具有至关重要的意义。         本研究旨在通过系统梳理 WebGIS 技术在传染病流行风险评估中的应用现状与优势,结合基孔肯雅热的流行特点和防控需求,构建一套基于

【Tauri框架学习】Tauri 与 React 前端集成:通信机制与交互原理详解

【Tauri框架学习】Tauri 与 React 前端集成:通信机制与交互原理详解

Tauri 与 React 前端集成:通信机制与交互原理详解 * Tauri 与 React 前端集成:通信机制与交互原理详解 * **一、Tauri 与 React 的集成基础** * **1. 项目结构** * **2. 环境准备** * **二、Tauri 与 React 的通信机制** * **1. 核心机制:命令调用(Command)** * **2. 事件驱动:事件监听(Event)** * **3. 通信流程** * **三、具体示例:React 与 Rust 交互** * **场景1:React 调用 Rust 命令(文件读取)** * **Step 1:Rust 后端定义命令*

《C#上位机开发从门外到门内》3-5:基于FastAPI的Web上位机系统

《C#上位机开发从门外到门内》3-5:基于FastAPI的Web上位机系统

文章目录 * 一、项目概述 * 二、系统架构设计 * 三、前后端开发 * 四、数据可视化 * 五、远程控制 * 六、系统安全性与稳定性 * 七、性能优化与测试 * 八、实际应用案例 * 九、结论 随着互联网技术的快速发展,Web上位机系统在工业自动化、智能家居、环境监测等领域的应用日益广泛。基于FastAPI或Flask的Web上位机系统,凭借其高效、灵活和易于扩展的特点,成为当前研究和应用的热点。本文将详细探讨基于FastAPI和Flask的Web上位机系统的设计与实现,涵盖系统架构、前后端开发、数据可视化、远程控制、安全性、性能优化以及实际应用案例等方面,旨在为相关领域的研究人员和工程技术人员提供参考和借鉴。 一、项目概述 Web上位机系统是一种通过网络实现对远程设备或环境进行实时监控和控制的系统。其核心目标是通过高效的数据传输和处理,确保监控的实时性和准确性,从而实现对远程设备的有效管理和控制。基于FastAPI或Flask的Web上位机系统利用Python的Web框架,通过互联网或局域网实现数据的传输和通信,具有广泛的应用前景。 Fa

[Trea]-AI编辑器核心功能

[Trea]-AI编辑器核心功能

下载安装 国内版: 官网地址:https://www.trae.cn 国际版: 官网地址:https://www.trae.ai 安装 (傻瓜安装) 注册登录 编辑器配置 1. 点击齿轮图标,进入Trae Settings 1. 左侧选择是支持的配置 1. 配置项说明 * 通用: 包括基础设置和偏好设置,比如使用什么主题,编辑器的设置,快捷键的设置等 * 开发环境: 对开发的项目设置相关的环境,比如jdk、maven、node.js等 * 智能体: 智能体是Trae中独立执行特定任务的“虚拟代理”,核心作用是按需配置工具与协作策略 * MCP: MCP是Trae中模型与开发环境的交互协议,核心作用是驱动AI自动执行开发任务 * 对话流: 对话流是Trae中AI与用户交互的“流程化设计”,核心作用是优化上下文理解与多轮交互体验 * CUE: Cue(context