geoserver上传数据自动发布服务python代码

geoserver上传数据自动发布服务python代码

目录

0.目的

1.python代码实现

2.缺点


0.目的

        像arcgis portal那样,从浏览器中选择本地数据上传,数据会自动上传到数据库中,然后再自动发布服务!

        geoserver能否也像portal那样呢?geoserver可以连接postgis的数据源,但是没有从本地上传数据到数据库的选项!参考geonode实现geoserver数据上传数据库,发布服务的代码。geonode-win10安装教程

1.python代码实现

        python geoserver rest api库包:geoserver-restconfig(这里采用)、geoserver-rest

# pip install geoserver-restconfig
# example: https://github.com/GeoNode/geoserver-restconfig/blob/master/examples/postgis_import.py

from geoserver.catalog import Catalog

cat = Catalog("http://localhost:8080/geoserver/rest", "admin", "geoserver")
dsname = "postgis"  # 数据源-数据存储名称
workspace = "postgis"  # 工作区

ds = cat.create_datastore(dsname, workspace=workspace)
# 缺失部分信息
# ds.connection_parameters.update(
#     host="localhost",
#     port="5432",
#     database="test_postgis",  # 需要提前建立
#     user="postgres",
#     passwd="123",
#     dbtype="postgis")

ds.connection_parameters.update({'Evictor run periodicity': 300,
    'Estimated extends': 'true',
    'schema': "public",
    'fetch size': 100000,
    'encode functions': 'false',
    'Expose primary keys': 'true',
    'validate connections': 'true',
    'Support on the fly geometry simplification': 'false',
    'Connection timeout': 10,
    'create database': 'false',
    'Batch insert size': 30,
    'preparedStatements': 'true',
    'min connections': 10,
    'max connections': 100,
    'Evictor tests per run': 3,
    'Max connection idle time': 300,
    'Loose bbox': 'true',
    'Test while idle': 'true',
    'host': "localhost",         # 重要参数
    'port': "5432",              # 重要参数
    'database': "test_postgis",  # 重要参数 数据库名称 需要提前建立database
    'user': "postgres",          # 重要参数
    'passwd': "123",             # 重要参数
    'dbtype': "postgis"})

cat.save(ds)
ds = cat.get_store(dsname, workspace=workspace)
components = dict((ext, f"D:\Program_Files\geoserver-2.20.4\data_dir\data\shapefiles\states.{ext}") for ext in ["shp", "prj", "shx", "dbf"])
cat.add_data_to_store(ds, "states", components)  # 第2个参数为 写入zip内的名字

2.缺点

        (1)geoserver无法自己从本地上传数据,自动存储到数据库,发布服务!只能通过geoserver rest api调用实现!!!

        (2)目前,仅探索了单个shp文件上传geoserver,保存数据库,发布服务的试验。对于多个图层-实现图层组 or 批量导入的操作,暂时还未探索。

        TODO 更多的探索!

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现 Python 自动发布 Geoserver 的功能,可以使用 Geoserver REST API。以下是一个基本的 Python 脚本,可以通过 REST API 发布一个 GeoTIFF 文件: ```python import requests # 设置 Geoserver 的地址和用户名密码 geoserver_url = "http://localhost:8080/geoserver" username = "admin" password = "geoserver" # 发布的图层名和工作区 workspace = "myworkspace" layer_name = "mylayer" # GeoTIFF 文件的路径 file_path = "/path/to/myfile.tif" # 构建 REST API 的请求 URL url = f"{geoserver_url}/rest/workspaces/{workspace}/coveragestores/{layer_name}/file.geotiff" # 发送 POST 请求并上传 GeoTIFF 文件 with open(file_path, "rb") as f: headers = {"Content-type": "image/tiff"} r = requests.post(url, auth=(username, password), headers=headers, data=f) # 如果上传成功,会返回 201 状态码 if r.status_code == 201: print("Layer published successfully.") else: print("Failed to publish layer.") ``` 上述代码中,我们首先设置了 Geoserver 的地址和用户名密码,然后指定了发布的图层名、工作区和 GeoTIFF 文件的路径。接下来,我们使用 requests 库发送一个 POST 请求,并在请求头中指定上传的文件类型为 image/tiff。最后,根据响应的状态码来判断发布是否成功。 需要注意的是,如果你的 GeoTIFF 文件包含了地理信息,那么你需要在上传之前先设置该图层的坐标参考系和范围。你可以使用 Geoserver 的 REST API 来完成这项工作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值