简析服务端通过geotools导入SHP至PG的方法
2016-11-24 16:57
246 查看
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/
Geotools用到的两个较重要的开源GIS工具包是JTS和GeoAPI。前者主要是实现各种GIS拓扑算法,也是基于GeoAPI的。但是由于两个工具包的GeoAPI分别采用不同的Java代码实现,所以在使用时需要相互转化。Geotools又根据两者定义了部分自己的GeoAPI,所以代码显得臃肿,有时容易混淆。由于GeoAPI进展缓慢,Geotools自己对其进行了扩充。另外,Geotools现在还只是基于2D图形的,缺乏对3D空间数据算法和显示的支持。
Geotools The Open Source Java GIS
Toolkit的相关学习网站如下:
http://geotools.org/ Geotools官方网站
http://docs.geotools.org/latest/javadocs/
Geotools API在线文档
http://docs.codehaus.org/display/GEOTDOC/Home Geotools用户指南
http://repo.opengeo.org Geotools的maven仓库
http://download.osgeo.org/webdav/geotools/
maven仓库地址
org.geotools.data包负责地理数据的读写(如:ShapefileReader用于读取shpfile数据)。
org.geotools.geometry包负责提供对JTS的调用接口,以将地理数据封装成JTS中定义的几何对象(Geometry)。
org.geotools.feature包负责封装空间几何要素对象(Feature),对应于地图中一个实体,包含:空间数据(Geometry)、属性数据(Aitribute)、参考坐标系(Refereneedsystem)、最小外包矩形(EnveloPe)等属性,是GlS操作的核心数据模型。
其中红色的包含了要素定义、SHP读取、EPSG获取等相关方法的jar。
b.hsqldb
需要配合gt-epsg-hsql来使用,可以查询对应的epsg编码。
c. Image I/O-Ext
支持跟GIS有关的图片格式。
d.jts
JTS提供了这些空间数据类Point、MultiPointLineString、LinearRing(封闭的线条)、MultiLineString (多条线)、PolygonMultiPolygon 、 GeometryCollection(包括点,线,面)。JTS包结构为计算交点(noding包)、几何图形操作(operation包)、平面图(planargraph包)、多边形化(polygnize包)、精度(precision)、工具(util包)。
e.jsr、vecmath
做投影相关运算时需要这两个jar: jsr-275-1.0-beta-2.jar和vecmath-1.3.1.jar。
f. opengis库
h.其他各类jar
包含数据库驱动的jar,log4j,XML解析的jar等等。可以实现读取不同数据库的数据,对xml格式的文件比如SLD的解析等等。
主文件是一个直接存取,变量记录长度文件,其中每个记录描述一个有它自己的vertices列表的shape。
索引文件中,每个记录包含对应主文件记录离主文件头开始的偏移。
dBASE表包含记录的feature的特征。几何和属性间的一一对应关系是基于记录数目的。在dBASE文件中的属性记录必须和主文件中的记录是相同顺序的。
Oracle中安装了SDE后,能支持ST_Geometry函数。Oracle Spatial版本则有其自带的SDO_Geometry相关函数。这里,我们在PostgreSQL上安装了PostGIS,使其支持ST_Geometry函数。对于空间数据的描述,PG中支持标准的OpenGIS的两种空间数据组织格式:Well-Known Text (WKT) 和 Well-Known Binary (WKB) 。
PostGIS在线文档:http://postgis.net/docs/manual-1.4/
空间函数文档:http://postgis.net/docs/manual-1.4/ch04.html
-----欢迎转载,但保留版权,请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/
如果您觉得本文确实帮助了您,可以微信扫一扫,进行小额的打赏和鼓励,谢谢 ^_^
1.背景
项目中需要在浏览器端直接上传SHP后服务端进行数据的自动入PG库以及发布至geoserver。本方法是以geotools为开发工具实现入库,以geoserver manager来实现服务的自动发布。这里着重描述geotools编写SHP入库的方法。2.Geotools介绍
2.1总体介绍
Geotools是Java语言编写的开源GIS工具包,其功能涵盖了地理信息数据读写、处理、坐标转换、查询分析、格式化输出等多个方面。该项目已有十多年历史,生命力旺盛,代码非常丰富,包含多个开源GIS项目,并且基于标准的GIS接口。Geotools主要提供各种GIS算法,各种数据格式的读写和显示。在显示方面要差一些,只是用Swing实现了地图的简单查看和操作。但是用户可以根据Geotools提供的算法自己实现地图的可视化。OpenJump和udig就是基于Geotools的。Geotools用到的两个较重要的开源GIS工具包是JTS和GeoAPI。前者主要是实现各种GIS拓扑算法,也是基于GeoAPI的。但是由于两个工具包的GeoAPI分别采用不同的Java代码实现,所以在使用时需要相互转化。Geotools又根据两者定义了部分自己的GeoAPI,所以代码显得臃肿,有时容易混淆。由于GeoAPI进展缓慢,Geotools自己对其进行了扩充。另外,Geotools现在还只是基于2D图形的,缺乏对3D空间数据算法和显示的支持。
Geotools The Open Source Java GIS
Toolkit的相关学习网站如下:
http://geotools.org/ Geotools官方网站
http://docs.geotools.org/latest/javadocs/
Geotools API在线文档
http://docs.codehaus.org/display/GEOTDOC/Home Geotools用户指南
http://repo.opengeo.org Geotools的maven仓库
http://download.osgeo.org/webdav/geotools/
maven仓库地址
2.2整体架构
org.geotools.data包负责地理数据的读写(如:ShapefileReader用于读取shpfile数据)。
org.geotools.geometry包负责提供对JTS的调用接口,以将地理数据封装成JTS中定义的几何对象(Geometry)。
org.geotools.feature包负责封装空间几何要素对象(Feature),对应于地图中一个实体,包含:空间数据(Geometry)、属性数据(Aitribute)、参考坐标系(Refereneedsystem)、最小外包矩形(EnveloPe)等属性,是GlS操作的核心数据模型。
2.3geotools中的核心Jar说明
a.GT核心库其中红色的包含了要素定义、SHP读取、EPSG获取等相关方法的jar。
b.hsqldb
需要配合gt-epsg-hsql来使用,可以查询对应的epsg编码。
c. Image I/O-Ext
支持跟GIS有关的图片格式。
d.jts
JTS提供了这些空间数据类Point、MultiPointLineString、LinearRing(封闭的线条)、MultiLineString (多条线)、PolygonMultiPolygon 、 GeometryCollection(包括点,线,面)。JTS包结构为计算交点(noding包)、几何图形操作(operation包)、平面图(planargraph包)、多边形化(polygnize包)、精度(precision)、工具(util包)。
e.jsr、vecmath
做投影相关运算时需要这两个jar: jsr-275-1.0-beta-2.jar和vecmath-1.3.1.jar。
f. opengis库
h.其他各类jar
包含数据库驱动的jar,log4j,XML解析的jar等等。可以实现读取不同数据库的数据,对xml格式的文件比如SLD的解析等等。
3.SHP各文件的简介
shape文件由ESRI开发,一个ESRI(Environmental Systems Research Institute)的shape文件包括一个主文件,一个索引文件,和一个dBASE表,其中主文件的后缀就是.shp。主文件是一个直接存取,变量记录长度文件,其中每个记录描述一个有它自己的vertices列表的shape。
索引文件中,每个记录包含对应主文件记录离主文件头开始的偏移。
dBASE表包含记录的feature的特征。几何和属性间的一一对应关系是基于记录数目的。在dBASE文件中的属性记录必须和主文件中的记录是相同顺序的。
4.ST_Geometry函数
ST_Geometry SQL 数据类型用于存储在 DB2、Informix、Oracle 和 PostgreSQL 的地理数据库中。此数据类型可在地理数据库中使用,另外还可通过 SQL 访问第三方应用程序的简单要素类几何。ST_Geometry 执行空间的 OGC 和 ISO SQL 多媒体规范。Oracle中安装了SDE后,能支持ST_Geometry函数。Oracle Spatial版本则有其自带的SDO_Geometry相关函数。这里,我们在PostgreSQL上安装了PostGIS,使其支持ST_Geometry函数。对于空间数据的描述,PG中支持标准的OpenGIS的两种空间数据组织格式:Well-Known Text (WKT) 和 Well-Known Binary (WKB) 。
PostGIS在线文档:http://postgis.net/docs/manual-1.4/
空间函数文档:http://postgis.net/docs/manual-1.4/ch04.html
5.具体实现
5.1读取所有格式SHP并入库
5.2读取SHP的DBF文件
-----欢迎转载,但保留版权,请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/
如果您觉得本文确实帮助了您,可以微信扫一扫,进行小额的打赏和鼓励,谢谢 ^_^
相关文章推荐
- 使用geotools导入shp文件到Oracle数据库时表名带下划线问题的解决方法
- 使用geotools导入shp文件到Oracle数据库时表名带下划线问题的解决方法
- geotools导入shp文件到Oracle数据库时表名带下划线的问题解决
- 基于geotools的(两个)SHP要素变化提取方法预研
- shp文件导入mysql的方法总结
- sqlserver导入sql文件 sqlserver中通过osql/ocmd批处理批量执行sql文件的方法
- geotools 在eclipse中的导入
- geotools 在eclipse中的导入
- GeoTools支持中文的解决方法
- HTTPclient通过soap协议访问cxf写的webservice服务端的方法。
- [导入]使用GEOTOOLS(2.3)读取POSTGIS内容
- sharepoint通过excel导入list时报错:导入数据时(方法'Post'作用于对象'IOWSPostData'时失败)
- 通过命令行导入到mysql数据库时出现乱码的解决方法
- ice调通过iceReplica用所有server instance的方法---客户端控制服务端的负载均衡
- Geotools之“Hello World”——打开本地shp文件并显示
- sqlserver导入sql文件 sqlserver中通过osql/ocmd批处理批量执行sql文件的方法
- 通过WEB ADI将Excel文件的Item导入到库存的方法
- [导入]使用GeoTools 2.3M连接到POSTGIS数据库
- MYSQL大数据库通过cPanel导入的方法
- ArcMap把shp文件导入到mdb中的方法