内网geoserver发布多层级影像数据,并实现调用(使用leaflet)_geoserver wms 多级-程序员宅基地

技术标签: java  leaflet  

公司近期会有项目需要实现在内网环境下调用高德、百度地图,但是内网与互联网又是物理隔离,无法直接调用各地图api,目前的方法是,将需要使用的地图下载到本地服务器上,并通过geoserver发布为服务,来实现调用。
步骤分为以下几步:

一、下载地图数据

在各种地图下载器中流连之后,发现还是“太乐地图下载器”好用些,下载下来直接就可以发布,只需要注册下就可以。【其他下载器:BIGEMAP下载器、水经注、sxearth等,只是繁琐程度不同,都可以使用】

‘太乐’下载步骤放在文章末尾,需要请移步(毕竟不是文章重点(0.。0))
第二种下载方式(python)
需要下载PyCharm 2021.1.2 x64程序,将python包丢进去进行下载
代码下载位置:
链接:https://pan.baidu.com/s/1tce6iEiVW5lLyFyr93asTg
提取码:a21k

#raw_input(“等待中…”)这句需要注释才能执行

二、发布服务(geoserver)

【新建工作区——新建数据存储——发布为图层——切片处理】
①新建工作区
在这里插入图片描述在这里插入图片描述②新建数据存储
在这里插入图片描述



接下来需要根据下载数据的类型选择数据存储的格式,我这里下载的地图是tif格式的影像数据,因此需要选择“栅格数据”中的"GeoTIFF"


在这里插入图片描述
在这里插入图片描述确定后自动跳转,点击“发布”按钮
在这里插入图片描述
一般需要调整的只有这两个选项卡中的内容,其中“数据”选项卡中需要确认图层边框、坐标参考系统、覆盖参数。覆盖参数默认为空,此时加载图层会有黑边,调整为“000000”(即纯黑色),可以去掉黑边。"Tile Caching"选项卡中需要调整网格集的坐标系统,只留下需要的就可以,我这边只留下“EPSG:3857”。【ps:如果是刚安装的geoserver,一般来说没有这个坐标系,需要手动添加,找页面最左侧“Gridsets”即可】
在这里插入图片描述完成后点击“保存”
在这里插入图片描述
在这里插入图片描述点击Tile Layers,在刚刚添加的图层后选择“Seed/Truncate”
在这里插入图片描述此时就做好了切片处理,切片存储在data_dir文件夹下的gwc文件夹里
在这里插入图片描述
多个图层发布服务就重复以上步骤即可。

三、调用服务地图

我这里使用的是leaflet,其他框架大同小异
对地图缩放做监听,每次地图缩放就调用对应级别的影像

//写给新手:“()=>”近似于function ***(),相当于不用写名称的方法
//具体差异自行百度
mymap.on('zoomend',()=>{
//wmsLayer提前定义了全局变量
					if(wmsLayer){
						mymap.removeLayer(wmsLayer);
					}
					//let是es6的用法,作用为定义局部变量
					let mm=mymap.getZoom();
					wmsLayer = L.tileLayer.wms("http://localhost:8080/geoserver/try/wms", {
						layers: 'try:L'+mm, //需要加载的图层
						format: 'image/png', //返回的数据格式
						transparent: true,
						//crs: L.CRS.EPSG4326
					});
					mymap.addLayer(wmsLayer);
				})

同一位置不同级别效果

在这里插入图片描述在这里插入图片描述在这里插入图片描述
看其他大佬采用方法为多图层切片后,把切片后的文件整理到一个文件夹下,然后就可以实现自动切换,但是我试过后发现只有在geoserver中预览时才会这样,实际调用的时候还是只显示其中一个图层的,百撕不得其姐,很奇怪,如果有大佬知道,烦请告知一二,或者日后我研究出来再更新本文。

下载地图(使用“太乐地图下载器”)

如果未注册的话,下载的地图会有水印,因此建议下载带注册机的“学习”版本。
在这里插入图片描述在这里插入图片描述
在这里插入图片描述然后会进入下载界面,下载完成后自动在屏幕右下角弹出窗口询问是否导出地图,
在这里插入图片描述下载完成后自动打开位置
在这里插入图片描述

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_42751928/article/details/106665094

智能推荐

SaltStack数据系统_comment: no top file or master_tops data matches f-程序员宅基地

文章浏览阅读69次。文章目录1SaltStack数据系统2 SaltStack数据系统组件2.1 SaltStack组件之Grains2.2 SaltStack组件之Pillar2.3 Grains与Pillar的区别1SaltStack数据系统SaltStack有两大数据系统,分别是GrainsPillar2 SaltStack数据系统组件2.1 SaltStack组件之GrainsGrains是SaltStack的一个组件,其存放着minion启动时收集到的信息。Grains是SaltStack组件中非_comment: no top file or master_tops data matches found. please see master lo

error C2668: “swap”: 对重载函数的调用不明确_swap对重载函数的调用不明确-程序员宅基地

文章浏览阅读3.4k次,点赞6次,收藏3次。当出现这个错误提示的时候,很有可能代码并没有问题,而是编译器的设定问题。测试代码如下:#include using namespace std;//函数模板templatevoid swap(T &a,T &b){ T temp; temp = a; a = b; b = temp;}int main(int ,char **){ int a = 1, b _swap对重载函数的调用不明确

ZYNQ PCIe EP实现DMA+Linux交互,非常简洁的程序_c++ 往pcie发送数据-程序员宅基地

文章浏览阅读1w次,点赞8次,收藏120次。ZYNQ PCIe-DMA源码 例程 PS-PL交互 linux/裸机 verilog C/C++ZYNQ PCIe-DMA的实现过程一、概述二、基础知识三、系统总框架四、工作原理与工作模式五、接口时序六、资源使用情况七、PS-PL交互以及测试程序ZYNQ PCIe-DMA的实现过程近期在网上淘来个源码,看了之后觉得还不错。完全刷新我对ZYNQ的认知啊,原来ZYNQ也可以这么玩的。PS-PL交..._c++ 往pcie发送数据

Python-Django毕业设计员工宿舍管理系统(程序+Lw)_用python设计一个宿舍管理系统,要求能实现寝室信息的增加、删除、修改、查询以及-程序员宅基地

文章浏览阅读173次。该项目含有源码、文档、程序数据库、配套开发软件、软件安装教程项目运行环境配置:Pychram社区版py项目技术:django + python+ Vue 等等组成,B/S模式 +pychram管理等等。环境需要1.运行环境:最好是python3.7.7,我们在这个版本上开发的。其他版本理论上也可以。2.pycharm环境:pycharm都可以。推荐pycharm社区版;3.mysql环境:建议是用5.7版本均可。_用python设计一个宿舍管理系统,要求能实现寝室信息的增加、删除、修改、查询以及

linux使用apache搭建http服务器(文件服务器)_linux怎么搭http apache服务器-程序员宅基地

文章浏览阅读8.4k次,点赞5次,收藏41次。一、安装Apache$ sudo apt-get install apache2二、修改服务器访问端口Apache2的默认访问端口为80,可修改为其他端口(当端口被占用时需要更改其访问端口)进入apache2的安装目录 /etc/apache2/,修改ports.conf文件$ cd /etc/apache2/$ sudo chmod 775 ports.conf$ vim po..._linux怎么搭http apache服务器

逆转广义表_将广义表(a,( (b, c),( ) ),( ( ( d ), e ),f) 逆转为 ((f,(e-程序员宅基地

文章浏览阅读898次。题目请编写递归算法, 逆转广义表中的数据元素。例如: 将广义表:(a,((b,c),()),(((d),e),f))逆转为:((f,(e,(d))),((),(c,b)),a)。代码#include <iostream>#include <cstring>#include <algorithm>using namespace std;void reverse_str(char *s, int l, int r){ int n = r-l; _将广义表(a,( (b, c),( ) ),( ( ( d ), e ),f) 逆转为 ((f,(e ,( d)),( ( ),(c,b), a)的代码

随便推点

HTC硬件介绍_htc是什么硬件-程序员宅基地

文章浏览阅读399次。其中最重要的是头盔中两个屏幕,用的是比较高端的三星AMOLED屏幕,屏幕尺寸对角线为91.8mm,PPI(每英寸集成的像素)达到了447(像素密度越高表现出来的画面就更细腻)。体验者可以在一个小范围的空间中行走,体验制作好的内容。是通过摄像头不停的采集周围环境的图像来达到设备的姿态估计(比如噪音等一些没用的信息也会影响到它的准确性)。是通过计算机视觉,以及设备自身自带的传感器比如陀螺仪、加速器来实现位置的追踪。不需要外部硬件来定位。由LED阵列和横向纵向的两个马达,马达以非常高的频率扫描场景中的定位。_htc是什么硬件

基于 Python 深度学习的车辆特征分析系统,附源码_pycharm实时检测车辆及源码-程序员宅基地

文章浏览阅读1.7k次,点赞25次,收藏29次。而在机动车的自动识别过程中,通过利用深度学习的算法来让计算机通过不断地获取信息要素形成信息库,可以更好的提升计算机对于车辆的识别能力。本次就是通过利用了深度学习技术结合Python开发工具来设计一款能够在线通过图片分析来识别车辆的品牌的软件。_pycharm实时检测车辆及源码

matlab采样点数傅里叶变换,【 MATLAB 】模拟信号采样及离散时间傅里叶变换(DTFT)案例分析...-程序员宅基地

文章浏览阅读1.1k次。中使用的模拟信号: 为了研究在频域数量上的采样效果,对该信号使用两种不同的采样频率采样。a. 在 fs = 5000 对信号进行采样,求出并画出其离散时间傅里叶变换;b. 在 fs = 1000 对信号采样,求出并画出其离散时间傅里叶变换。题解:上篇博文也分析了,信号的带宽为2kHz,奈奎斯特频率就为 4000 样本/s,它小于第一问给出的采样频率,所以频谱混叠几乎不存在。我们通过MATLAB验证..._采样点时间轴变换matlab

程序员的选择-程序员宅基地

文章浏览阅读117次。程序员的15种选择前端程序员后端程序员全栈工程师运维工程师移动端开发工程师自由职业程序员测试工程师图像处理工程师游戏开发工程师交互体验工程师量化交易工程师数据科学家& 数据工程师研究型工程师创业公司程序员持续学习程序员转载于:https://www.cnblogs.com/huameixiao/p/11571598.html..._c程序员刚入门接触闭源和开源

vue 图片:src字符串拼接路径无效问题_vue 图片 字符串 拼接-程序员宅基地

文章浏览阅读2.1k次。无效代码:<img :src="'../../../../static/Hongkong1/img/commodity/' + oneArticleData.icon_name" />改为使用require获取图片编码即可<img :src="require('../../../../static/Hongkong1/img/commodity/' + oneArticl..._vue 图片 字符串 拼接

Notes Sixth day-渗透攻击-红队-打入内网_打入目标内网-程序员宅基地

文章浏览阅读3.5k次,点赞4次,收藏23次。**Notes Sixth day-渗透攻击-红队-信息收集(dayu)**作者:大余时间:2020-09-22请注意:对于所有笔记中复现的这些终端或者服务器,都是自行搭建的环境进行渗透的。我将使用Kali Linux作为此次学习的攻击者机器。这里使用的技术仅用于学习教育目的,如果列出的技术用于其他任何目标,我概不负责。我必须再重申一遍:务必不要做未授权测试!不要未经授权在真实网络环境中复现任何本书中描述的攻击。即使是出于好奇而不是恶意,你仍然会因未授权测试行为而陷入很多麻烦。为了个人能更好的继_打入目标内网

推荐文章

热门文章

相关标签