简介与下载

GeoServer-Manager是使用Java编写的面向GeoServer的客户端库,通过GeoServer的REST管理接口与GeoServer交互。提供了访问GeoServer并管理(增删改查)其中工作区、数据存储、图层、图层组、样式等的接口函数。

其为github上的开源项目,最近一次更新在五年前。

项目源码: https://github.com/geosolutions-it/geoserver-manager.

jar库:http://maven.geo-solutions.it/it/geosolutions/geoserver-manager/1.7.0/geoserver-manager-1.7.0.jar

依赖

在maven项目的pom.xml中配置依赖。

依赖库除了geoserver-manager以外,还需要geoserver-manager用到的一些外部依赖。

   <repositories>
<repository>
<id>GeoSolutions</id>
<url>http://maven.geo-solutions.it/</url>
</repository>
</repositories> <dependencies>
<dependency>
<groupId>it.geosolutions</groupId>
<artifactId>geoserver-manager</artifactId>
<version>1.7.0</version>
</dependency> <dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.30</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-nop</artifactId>
<version>1.7.30</version>
</dependency>
<dependency>
<groupId>commons-codec</groupId>
<artifactId>commons-codec</artifactId>
<version>1.11</version>
</dependency>
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>1.4</version>
</dependency>
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
<version>1.1.1</version>
</dependency>
<dependency>
<groupId>commons-httpclient</groupId>
<artifactId>commons-httpclient</artifactId>
<version>3.1</version>
</dependency>
<dependency>
<groupId>org.jdom</groupId>
<artifactId>jdom</artifactId>
<version>1.1.3</version>
</dependency>
</dependencies>

编码发布矢量数据

此处以shp格式为例。

import it.geosolutions.geoserver.rest.GeoServerRESTManager;
import it.geosolutions.geoserver.rest.GeoServerRESTPublisher;
import it.geosolutions.geoserver.rest.decoder.RESTDataStore;
import it.geosolutions.geoserver.rest.encoder.datastore.GSShapefileDatastoreEncoder; import java.io.File;
import java.net.URL; public class shpTest {
public static void main(String[] args) throws Exception {
//GeoServer连接配置
String url = "http://localhost:8080/geoserver";
String userName = "admin";
String passWord = "geoserver"; String workSpace = "test"; //创建的工作区名称
String storeName = "shpTest"; //创建的数据存储名称 //与GeoServer连接,进行管理
GeoServerRESTManager manager = new GeoServerRESTManager(new URL(url), userName, passWord);
GeoServerRESTPublisher publisher = manager.getPublisher();
//创建工作区
boolean createWorkSpace = publisher.createWorkspace(workSpace);
System.out.println("create ws " + createWorkSpace); //待发布shp数据路径与矢量数据包路径
String filePath = "F:\\GeoServerDatabase\\Community\\Community.shp";
String zipPath = "F:\\GeoServerDatabase\\Community\\Community.zip"; //创建shp数据存储
GSShapefileDatastoreEncoder gsShapefileDatastoreEncoder= new GSShapefileDatastoreEncoder(storeName,new URL("file:" + filePath));
boolean createStore = manager.getStoreManager().create(workSpace, gsShapefileDatastoreEncoder);
System.out.println("create shp store " + createStore); //发布shp图层(如果没有目标数据存储则会先自动创建该命名数据存储再发布)
boolean publish = manager.getPublisher().publishShp(workSpace, storeName, "Community",new File(zipPath));
System.out.println("publish shp " + publish); //读取目标矢量数据存储
//RESTDataStore restDataStore = manager.getReader().getDatastore(workSpace, storeName);
}
}

编码发布栅格数据

此处以GeoTiff格式为例。

import it.geosolutions.geoserver.rest.GeoServerRESTManager;
import it.geosolutions.geoserver.rest.GeoServerRESTPublisher;
import it.geosolutions.geoserver.rest.decoder.RESTCoverageStore;
import it.geosolutions.geoserver.rest.encoder.coverage.GSCoverageEncoder;
import static it.geosolutions.geoserver.rest.encoder.GSResourceEncoder.ProjectionPolicy.REPROJECT_TO_DECLARED; import java.io.File;
import java.net.URL; public class tiffTest {
public static void main(String[] args) throws Exception {
//GeoServer连接配置
String url = "http://localhost:8080/geoserver";
String userName = "admin";
String passWord = "geoserver"; String workSpace = "test"; //创建的工作区名称
String storeName = "tiffTest"; //创建的数据存储名称 //与GeoServer连接,进行管理
GeoServerRESTManager manager = new GeoServerRESTManager(new URL(url), userName, passWord);
GeoServerRESTPublisher publisher = manager.getPublisher(); //创建工作区
boolean createWorkSpace = publisher.createWorkspace(workSpace);
System.out.println("create ws " + createWorkSpace); //初始化和构造栅格数据储存
String srs = "EPSG";//SRS空间参考系统 crs坐标参考系统
GSCoverageEncoder gsCoverageEncoder = new GSCoverageEncoder();
gsCoverageEncoder.setName("test");
gsCoverageEncoder.setTitle("test");
gsCoverageEncoder.setSRS(srs);
gsCoverageEncoder.setNativeFormat("GeoTIFF");
gsCoverageEncoder.addSupportedFormats("GEOTIFF");
gsCoverageEncoder.addKeyword("geoTiff");
gsCoverageEncoder.addKeyword("WCS");
gsCoverageEncoder.setNativeCRS(srs);
gsCoverageEncoder.setRequestSRS(srs);
gsCoverageEncoder.setResponseSRS(srs);
gsCoverageEncoder.setProjectionPolicy(REPROJECT_TO_DECLARED);
gsCoverageEncoder.setLatLonBoundingBox(-180, -90, 180, 90, "EPSG:4326");
//创建栅格数据存储
boolean createStore = manager.getPublisher().createCoverage(workSpace,storeName,gsCoverageEncoder);
System.out.println("Coverage store " + createStore); //待发布GeoTIFF数据路径
String filePath = "F:\\GeoServerDatabase\\test.tif";
//发布GeoTIFF(如果没有目标数据存储则会先自动创建该命名栅格数据存储再发布)
boolean publish = manager.getPublisher().publishGeoTIFF(workSpace, storeName,new File(filePath));
System.out.println("publish Coverage " + publish); //读取目标栅格数据存储
//RESTCoverageStore restCoverageStore = manager.getReader().getCoverageStore(workSpace, storeName); }
}

GeoServer-Manager应用:java编码实现发布矢量数据或栅格数据至GeoServer的更多相关文章

  1. Java编码安全

    目录 Java编码安全 数据校验 规则1.1:校验跨信任边界传递的不可信数据 规则1.2:禁止直接使用不可信数据来拼接SQL语句 规则1.4:禁止直接使用不可信数据来记录数据 规则1.6:验证路径前将 ...

  2. 10个精妙的Java编码最佳实践

    这是一个比Josh Bloch的Effective Java规则更精妙的10条Java编码实践的列表.和Josh Bloch的列表容易学习并且关注日常情况相比,这个列表将包含涉及API/SPI设计中不 ...

  3. 你知道吗?10个精妙的 Java 编码最佳实践

    这是一个比Josh Bloch的Effective Java规则更精妙的10条Java编码实践的列表.和Josh Bloch的列表容易学习并且关注日常情况相比,这个列表将包含涉及API/SPI设计中不 ...

  4. docker swarm实现java项目的发布/滚动更新/回滚/镜像管理

    使用docker swarm滚动更新java项目,部署集群,这一切的前提是使用Jenkins+maven进行项目打包,分发等功能 具体可以参考我的另外三篇文章 https://www.cnblogs. ...

  5. Java 13 即将发布,新特性必须抢先看!

    作者:h4cd 本文转载自开源中国(ID:oschina2013) 由于 Java 现在采取"半年发布一次新版本"的模式,所以 Java 12 的下一个版本 Java 13/JDK ...

  6. java编码过滤器

    1.java编码过滤器的作用: java过滤器能够对目标资源的请求和响应进行截取,过滤信息执行的优先级高于servlet. 2.java过滤器的使用: (1)编写一个普通的java类,实现Filter ...

  7. Web Service 的创建简单编码、发布和部署

    最近,老大准备将已有的C/S架构项目中的通信部分做成通用,需要将其支持WebService为以后项目向着B/S架构升级做好铺垫,为此身为屌丝的我去各种百度WebService是个什么卵玩意,然后逐渐搭 ...

  8. java中文乱码解决之道(四)-----java编码转换过程

    前面三篇博客侧重介绍字符.编码问题,通过这三篇博客各位博友对各种字符编码有了一个初步的了解,要了解java的中文问题这是必须要了解的.但是了解这些仅仅只是一个开始,以下博客将侧重介绍java乱码是如何 ...

  9. 资料推荐--Google Java编码规范

    之前已经推荐过Google的Java编码规范英文版了: http://google-styleguide.googlecode.com/svn/trunk/javaguide.html 虽然这篇文章的 ...

随机推荐

  1. 最全Windows版本jemalloc库(5.2.1)及其使用:包含动态库和静态库、x86版本和x64版本、debug版本和release版本

    编写服务器程序时,需要频繁的申请和释放内存,长时间运行会产生大量的内存碎片,这就导致即使当前系统中的闲置内存还足够多,但也无法申请到大的连续可用的内存块,因为此时的物理内存已经千疮百孔像个马蜂窝.此外 ...

  2. [PhpStorm]解决Cannot find declaration to go to

    1.问题重现 使用单例模式访问类方法,PhpStorm提示类方法Cannot find declaration to go to 2.解决方法 加一句代码注释 注意:注释不能省略变量名 注:成员变量实 ...

  3. 前端常用场景总结CSS/JS/插件(实用篇更新中...)

    <div class="box box1"> <span>垂直居中</span> </div> .box1{ display: ta ...

  4. Java基础系列(37)- 数组下标越界及小结

    数组的四个基本特点 其长度是确定的,数组一旦被创建,它的大小就是不可以改变的 其元素必须是相同类型,不允许出现混合类型 数组中的元素可以是任何数据类型,包括基本类型和引用类型 数组变量属于引用类型,数 ...

  5. Java基础系列(34)- 什么是数组

    数组的定义 数组是相同类型数据的有序集合 数组描述的是相同类型的若干个数据,按照一定的先后次序排列组合而成 其中,每一个数据称作一个数组元素,每个数组元素可以通过一个下标来访问它们

  6. Docker系列(22)- DockerFile指令说明并构建自己的centos

    DockerFile常用指令 实战测试 DockerHub中99%镜像都是从这个基础镜像过来的FROM scratch,然后配置需要的软件和配置来进行构建 #创建一个自己的centos # 1.编写D ...

  7. Groovy系列(1)- Groovy简述

    Groovy简述 前言 由于性能测试的JSR223 Sampler取样器需要用到 Groovy 语言,这两天对其进行了粗略的学习,本文是对学习做的一个简单总结,主要内容参考于官方文档(Groovy 的 ...

  8. Jmeter监控技术实战

    性能测试中监控的意义 为性能分析提供依据 监控方案 serverAgent jmeter的插件,监控颗粒度不高,界面简陋 服务器中启动 jmeter中添加插件 Nmon Grafana 优秀监控方案所 ...

  9. 网站优化之mysql优化

    一,网站优化之mysql优化:1.前缀索引,可以通过前缀去识别唯一性,把这个前缀作为索引内容,可以节省存储索引的空间,从而提高索引的查询速度.distinct 排重操作2,2.in条件索引使用同时查询 ...

  10. CF757F-Team Rocket Rises Again【最短路,DAG支配树】

    正题 题目链接:https://www.luogu.com.cn/problem/CF757F 题目大意 \(n\)个点\(m\)条边的一张无向图,求删除\(s\)以外的一个点改变\(s\)到最多点的 ...