shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境

这篇具有很好参考价值的文章主要介绍了shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言

   早就听闻大名鼎鼎的GeoTools,因为自己不搞Java,所以之前没用过,

背景

   最近有个需求,一个白模系统,具体是数据是用SDE导入到postgresql中,然后用arcgis server发布了矢量,最后用 arcgis api  for js 4.x拉伸,得到有高度的白模。以前的数据都是通过sde导入的,现在的需求是要通过前端,用户自己去更新矢量数据。本系列只涉及读取shp数据并插入到SDE连接的PostgreSQL已有表中。

  正常来说客户的数据量不大,可以用前端来做的,前端也有库解析shp文件,然后利用FeatureLayer.applyEdits() 实现跟数据库的操作,但是我还是想尝试下GeoTools,是个学习的机会,另外就是觉得前端不适合处理数据,

环境

  Windows 10

   IntelliJ IDE Ultimate 2021.3

  PostgreSql 9.4

  PostGIS Bundle 2.2 for PostgreSQL ×64 9.4

  ArcGIS 10.4.1

  ArcGIS Server 10.4.1

  ArcGIS API for JavaScript 4.24

  geotools 27.x

 步骤

一.找到GeoTools官网

  会看到给出了官网列出几种环境的搭建方式,我们选择在IntelliJ IDE搭建环境:

 

               shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境

  二.安装jdk

  jdk版本有很多,目前已经到Java20,但是感觉主流还是Java8,至少搭建GeoTools环境还是推荐用jdk1.8,尤其新手不要自找麻烦。下表展示了GeoTools与Java版本的对应关系(表格来源《GeoTools 地理信息系统开发》表2-1):

 

  

           shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境

     另外注意设置环境变量

三.新建工程

  1.顺序依次为:新建工程,选择Maven,单击"Create from archetype",选择“org.apache.maven.archetypes:maven-archetype-quickstart

          shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境

   2.单击Next,填写信息:

         shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境

    3.保持默认,单击Finish:

          shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境

    4.创建后的工程为(红可以看到色框在转圈像是下载包):

  

shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境

   5.完全结束后是这样子:

shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境

   6.运行下App文件,会打印处我们熟悉的“Hello World”:

shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境

 四.将Jar包添加到工程

  首先官方文档有个提示,启用离线模式。原文是“如果您按照本教程进行操作,则可能已经提供了预加载的 Maven 存储库。我们可以使用离线模式来确保 Maven 不会尝试下载任何依赖项”, 让设置里面把"Work offline”打个勾。但是我们根据官方教程操作,发现没有预加载库,所以这个选项务必不要打勾,否则依赖会下载失败!我们需要在线下载依赖。

 

 

shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境

 

 

  1.打开项目根目录下的 pom.xml 文件。您可以看到我们之前通过向导输入的一些信息。主要涉及到GeoTools的版本、依赖,存储库。不过为了加快速度,直接复制一份过去得了:

  

shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境
  1 <?xml version="1.0" encoding="UTF-8"?>
  2 
  3 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5   <modelVersion>4.0.0</modelVersion>
  6 
  7   <groupId>org.geotools</groupId>
  8   <artifactId>tutorial</artifactId>
  9   <version>1.0-SNAPSHOT</version>
 10 
 11   <name>tutorial</name>
 12   <!-- FIXME change it to the project's website -->
 13   <url>http://www.example.com</url>
 14 
 15   <properties>
 16     <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
 17     <maven.compiler.source>1.7</maven.compiler.source>
 18     <maven.compiler.target>1.7</maven.compiler.target>
 19     <geotools.version>28-SNAPSHOT</geotools.version>
 20     <maven.deploy.skip>true</maven.deploy.skip>
 21   </properties>
 22 
 23   <dependencies>
 24     <dependency>
 25       <groupId>junit</groupId>
 26       <artifactId>junit</artifactId>
 27       <version>4.11</version>
 28       <scope>test</scope>
 29     </dependency>
 30     <dependency>
 31       <groupId>org.geotools</groupId>
 32       <artifactId>gt-shapefile</artifactId>
 33       <version>${geotools.version}</version>
 34     </dependency>
 35     <dependency>
 36       <groupId>org.geotools</groupId>
 37       <artifactId>gt-swing</artifactId>
 38       <version>${geotools.version}</version>
 39     </dependency>
 40     <dependency>
 41       <groupId>org.geotools.jdbc</groupId>
 42       <artifactId>gt-jdbc-postgis</artifactId>
 43       <version>${geotools.version}</version>
 44     </dependency>
 45   </dependencies>
 46 
 47   <repositories>
 48     <repository>
 49       <id>osgeo</id>
 50       <name>OSGeo Release Repository</name>
 51       <url>https://repo.osgeo.org/repository/release/</url>
 52       <snapshots><enabled>false</enabled></snapshots>
 53       <releases><enabled>true</enabled></releases>
 54     </repository>
 55     <repository>
 56       <id>osgeo-snapshot</id>
 57       <name>OSGeo Snapshot Repository</name>
 58       <url>https://repo.osgeo.org/repository/snapshot/</url>
 59       <snapshots><enabled>true</enabled></snapshots>
 60       <releases><enabled>false</enabled></releases>
 61     </repository>
 62   </repositories>
 63 
 64 
 65   <build>
 66     <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
 67       <plugins>
 68         <!-- clean lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#clean_Lifecycle -->
 69         <plugin>
 70           <artifactId>maven-clean-plugin</artifactId>
 71           <version>3.1.0</version>
 72         </plugin>
 73         <!-- default lifecycle, jar packaging: see https://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_jar_packaging -->
 74         <plugin>
 75           <artifactId>maven-resources-plugin</artifactId>
 76           <version>3.0.2</version>
 77         </plugin>
 78         <plugin>
 79           <artifactId>maven-compiler-plugin</artifactId>
 80           <version>3.8.0</version>
 81         </plugin>
 82         <plugin>
 83           <artifactId>maven-surefire-plugin</artifactId>
 84           <version>2.22.1</version>
 85         </plugin>
 86         <plugin>
 87           <artifactId>maven-jar-plugin</artifactId>
 88           <version>3.0.2</version>
 89         </plugin>
 90         <plugin>
 91           <artifactId>maven-install-plugin</artifactId>
 92           <version>2.5.2</version>
 93         </plugin>
 94         <plugin>
 95           <artifactId>maven-deploy-plugin</artifactId>
 96           <version>2.8.2</version>
 97         </plugin>
 98         <!-- site lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#site_Lifecycle -->
 99         <plugin>
100           <artifactId>maven-site-plugin</artifactId>
101           <version>3.7.1</version>
102         </plugin>
103         <plugin>
104           <artifactId>maven-project-info-reports-plugin</artifactId>
105           <version>3.0.0</version>
106         </plugin>
107       </plugins>
108     </pluginManagement>
109   </build>
110 </project>
pom.xml

  复制完毕后发现会有报错现象:

shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境

   2.右键项目,选择Maven,选择"Reload project":

shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境

   3.我们发现可以了:

shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境

   4.可以到C盘相关文件夹里面看到相关的文件都下载完成(其它两个27和30版本是之前踩坑留下的,为了写博客重新用了28版本):

shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境

   搭建环境部分到此结束,到官网后面有个“Quickstart Application”根据1~6步进行操作,会显示出地图的。

shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境

 

后续 

2023.10.11更新

  最近要操作GeoJson, 所以pom.xml需要引入依赖,

<dependency>
      <groupId>org.geotools</groupId>
      <artifactId>gt-geojson</artifactId>
      <version>${geotools.version}</version>
</dependency>

  代码中需要添加

import org.geotools.geojson.geom.GeometryJSON;

   

 

  如果要查看历史版本的geotools文档,需要到官方文档右侧的blog页面右侧找到相应版本,然后在左侧找到userguide下载,解压后打开index.html即可,另外github仓库也有更新日志。

  关于版本选择,为何我用了27.x,因为目前Java主流还是Java8,或者说公司项目用的Java8:

shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境

 

参考资料

有些资料可能没参考,只是觉得不错,所以收藏一下

1.《GeoTools 地理信息系统开发》 王项 刘钧文 王新宁 孙运娟

2.  Getting started with geotools.org using IntelliJ IDEA 2020(油管视频)

3.Geotools简介以及quickstsrt加载shp文件并显示

4.geoTools18.4开发环境快速搭建,使用java可视化读取shapefile文件_idea配置geotools_GIS开发者的博客-CSDN博客(不使用Maven)

5.GeoTools, the Java GIS toolkit Files (geotools包离线下载)

6. Introduction to GeoTools (概要,及一些常用的用法)

7.IDEA运行时报错“类文件具有错误的版本 55.0, 应为 52.0”的解决方法

8.GeoTools应用:提取Shape文件属性列头信息(1)(本地导入依赖)文章来源地址https://www.toymoban.com/news/detail-435857.html

到了这里,关于shp数据插入sde连接的PostgreSQL库(一)----基于 IntelliJ IDE的GeoTools快速搭建环境的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 基于shp数据制作3DTiles建筑白膜

             经纬管网建模系统MagicPipe3D,本地离线参数化构建地下管网、建筑三维模型,输出标准3DTiles服务、Obj模型等格式,支持Cesium、Unreal、Unity、Osg等引擎加载进行三维可视化、语义查询、专题分析。欢迎下载试用:http://www.magic3d.net           MagicPipe3D新增基于shp数据制

    2024年02月20日
    浏览(36)
  • C++ 连接、操作postgreSQL(基于libpq库)

      使用libpq库来链接postgresql数据库,主要用到的头文件是这个:

    2024年02月07日
    浏览(25)
  • IntelliJ IDE 使用 Codeium 注意项(坑)

    在插件商店下载 Codeium 登录 - 需要科学 重启后有登录弹窗就直接登录 否则,ctrl + shift + a,在活动里搜 Codeium,找到通过 token 登录选项,之后按提示操作即可完成登录 在使用时候需要下载 language_server,正常全局科学上网能顺利下载,但是一般较慢。可以找到插件对应的目录

    2024年02月10日
    浏览(30)
  • 基于.net 4.5 使用VS连接PostgreSQL

    1、VS 2019(或者支持.net 4.5的任意版本) 2、Npgsql组件包部分依赖项 附下载地址:.net4.5链接PostgreSQL-PostgreSQL文档类资源-CSDN下载 1、新建窗体框架选择.net 4.5 2、安装Npgsql组件包 在 解决方案管理器  中右击项目,选择 在文件资源管理器中打开文件夹 ,依次打开bin/debug,将安装

    2024年02月14日
    浏览(43)
  • IntelliJ IDEA插件——可用的IDE Eval Reset

    IDEA版本说明: 如果你是最新版本或者比 2021.2.2 版本高的话,就可能存在失效或者不可用的情况,可以尝试降低版本使用。 在 idea- settings- plugins 里搜索 IDE Eval Reset (注意:是在Marketplace栏目下搜索,Installedl栏目下是你已经安装好的插件),然后点击 Install 进行安装,安装完

    2024年02月07日
    浏览(42)
  • IntelliJ IDE 插件开发 | (五)VFS 与编辑器

    IntelliJ IDE 插件开发 |(一)快速入门 IntelliJ IDE 插件开发 |(二)UI 界面与数据持久化 IntelliJ IDE 插件开发 |(三)消息通知与事件监听 IntelliJ IDE 插件开发 |(四)来查收你的 IDEA 使用报告吧 IntelliJ IDE 插件开发 |(五)VFS 与编辑器 在前几篇文章中主要介绍了关于 IntelliJ IDE 插

    2024年01月25日
    浏览(53)
  • Eclipse、IntelliJ IDEA、PyCharm三种IDE的区别

    Eclipse、IntelliJ IDEA和PyCharm是三种流行的集成开发环境(IDE),每个都有其特性和优点。 1.Eclipse:Eclipse是一款开源的Java IDE,由Eclipse基金会开发。它具有许多功能,包括代码自动完成、调试、源代码控制等。另外,Eclipse有许多插件可以安装,以扩展其功能。它的优点包括免费

    2024年01月22日
    浏览(45)
  • IntelliJ IDEA插件IDE Eval Reset怎么有效试用

    IDEA版本说明: 如果你是最新版本或者比 2021.2.2 版本高的话,就可能存在失效或者不可用的情况,可以尝试降低版本使用。 在 idea- settings- plugins 里搜索 IDE Eval Reset (注意:是在Marketplace栏目下搜索,Installedl栏目下是你已经安装好的插件),然后点击 Install 进行安装,安装完

    2024年01月16日
    浏览(47)
  • 在IntelliJ IDEA IDE中添加jar包的步骤

    在IntelliJ IDEA IDE中添加jar包的步骤如下: 打开IntelliJ IDEA,打开需要添加jar包的项目。 在IntelliJ IDEA右侧的项目导航器中,找到项目。 右键单击项目,选择\\\"Open Module Settings\\\"(也可以使用快捷键F4)。 在弹出的\\\"Project Structure\\\"窗口中,选择\\\"Modules\\\"。 在\\\"Modules\\\"选项卡中,选择模块。

    2024年02月06日
    浏览(37)
  • 【Java】IDE集成开发环境工具IntelliJ安装和使用

    欢迎来到《小5讲堂》 大家好,我是全栈小5。 这是《Java》序列文章,每篇文章将以博主理解的角度展开讲解, 特别是针对知识点的概念进行叙说,大部分文章将会对这些概念进行实际例子验证,以此达到加深对知识点的理解和掌握。 温馨提示:博主能力有限,理解水平有限

    2024年01月18日
    浏览(71)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包