使用iServer JAVA API访问iServer数据服务进行数据操作示例

本文主要是介绍使用iServer JAVA API访问iServer数据服务进行数据操作示例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作者:MR

    之前一篇博客(SuperMap iServer JAVA API介绍)介绍了SuperMap iServer JAVA API(以下简称JAVA API)用处、用法,本篇介绍JAVA API访问iServer数据服务的具体应用,并提供工程源码下载。作为示例,这里使用eclipse创建一个控制台应用。
###一、创建JAVA工程&主类
    创建一个Java工程,工程下新建lib文件夹,复制%iServerROOT%\WEB-INF\lib\iserver-all-8.1.1-14511.jarlib文件夹里,并将iserver-all-8.1.1-14511.jar右键添加到Build Path里。
    本文新建一个包,命名dataSample,其下创建一个类,命名DataSample,添加main方法。工程结构如图(JDK1.8):

目录

###二、获取数据服务提供者
    本文访问的数据服务REST资源根目录如下:

http://support.supermap.com.cn:8090/iserver/services/data-world/rest

    创建/释放RestDataProvider方法如下:

	/*** @param RootURL*            数据服务REST资源根目录* @return*/private static RestDataProvider getDataProvider( String rootURL ){// 服务提供者设置RestDataProviderSetting ProviderSetting = new RestDataProviderSetting( );ProviderSetting.restServiceRootURL = rootURL;// 创建服务提供者return new RestDataProvider( ProviderSetting );}/*** @param provider*            待释放资源的服务提供者对象*/private static void dispose( RestDataProvider provider ){if ( provider != null ){provider.clearCache( );provider.dispose( );}}

    RestDataProvider类参考最新在线地址如下(建议使用CHM格式):

http://support.supermap.com.cn:8090/iserver/help/html/mergedProjects/iServerJavadoc/com/supermap/services/providers/RestDataProvider.html

###三、业务逻辑实现

    接下来就可以使用服务提供者对象提供的方法实现各种业务逻辑了,本文实现创建一个点数据集并添加点。main方法如下:

private static final String DATAURL = "http://support.supermap.com.cn:8090/iserver/services/data-world/rest";/*** @param args*/public static void main( String[ ] args ){long start = System.currentTimeMillis( );RestDataProvider dataProvider = getDataProvider( DATAURL );final String datasourceName = "World";final String copyDSName = "Capitals";final String newDSName = "TESTPoints";// 新建数据集(这里就不new完挨着赋值了,复制一个,目前通过REST API创建数据集不支持设置字段)Boolean flag = true;try{if ( dataProvider.copyDataset( datasourceName, copyDSName, datasourceName, newDSName ) ){System.out.println( copyDSName + " 数据集已复制,新数据集为 " + newDSName );} else{flag = false;}} catch ( Exception e ){System.out.println( newDSName + " 数据集已存在" );}if ( flag && dataProvider.clearFeatures( datasourceName, newDSName ) ){System.out.println( newDSName + "数据集已清空" );int[ ] ids = new int[ ] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };List< Feature > targetFeatures = dataProvider.getFeature( datasourceName, copyDSName, ids, null );// 未指定全部字段及对应字段值Feature pt1 = new Feature( );pt1.fieldNames = new String[ ] { "CAPITAL" };pt1.fieldValues = new String[ ] { "零零" };pt1.geometry = new Geometry( );pt1.geometry.parts = new int[ ] { 1 };pt1.geometry.points = new Point2D[ ] { new Point2D( 0.0, 0.0 ) };targetFeatures.add( pt1 );EditResult result = dataProvider.addFeatures( datasourceName, newDSName, targetFeatures );System.out.println( newDSName + "数据集增加要素是否成功:" + result.succeed );System.out.println( newDSName + "数据集增加要素数量:" + result.ids.length );}// // 数据集信息// DatasetInfo tempif = dataProvider.getDatasetInfo( datasourceName,// copyDSName );// DatasetVectorInfo dsvctif = new DatasetVectorInfo(// (DatasetVectorInfo) tempif );// dsvctif.name = newDSName;//// // 创建点数据集// if ( dataProvider.createDataset( datasourceName, dsvctif ) )// {// System.out.println( "创建数据集 " + newDSName + "成功!所有数据集如下:" );// List< String > dtnms = dataProvider.getDatasetNames( datasourceName// );// for ( String s : dtnms )// {// System.out.println( s );// }// System.out.println( "-------------------" );// // 创建成功添加点// int[ ] ids = new int[ ] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };// List< Feature > targetFeatures = dataProvider.getFeature(// datasourceName, copyDSName, ids, null );// EditResult result = dataProvider.addFeatures( datasourceName,// newDSName, targetFeatures );// System.out.println( newDSName + "数据集添加要素是否成功?" + result.succeed );// System.out.println( newDSName + "数据集添加要素数量" + result.ids.length );// System.out.println( newDSName + "数据集删除结果: " +// dataProvider.deleteDataset( datasourceName, newDSName ) );// }dispose( dataProvider );System.out.println( "done,cost:" + ( System.currentTimeMillis( ) - start ) );}

    运行时会有报错**java.lang.NoClassdeFoundError,这是因为我们虽然都只使用了iserver-all-8.1.1-14511.jar包里的方法,但是该包还会import别的包,所以编译没错,运行时就会报错了,目前暂无便捷的依赖管理工具去自动列出需要的依赖项,只能手动和根据报错添加依赖的包;反编译查看import也不是很好用,需要反编译你使用的类,找到它的依赖、依赖的依赖…,所以本文建议排除法,JAVA API所有的依赖都在%iServerROOT%\WEB-INF\lib目录下,把这些jar包都加到Build Path就行了,并且,已知本文使用的方法不涉及SuperMap iObjects Java**,所以可以去掉com.supermap开头的(即Java组件的)的jar包,也不需要配置Java组件环境,剩下的jar先通过文件名排除一部分,然后一个一个去掉看运行结果来排除剩下的。

###结果

结果

###其他&下载
    可以输出工程为jar,使用java命令运行(可以写成批处理脚本或shell脚本)即可,本文不再介绍。
    排除无用jar包后的工程如下,使用eclipse打开工程即可运行查看结果。

使用iServer JAVA API访问iServer数据服务进行数据操作示例工程
http://download.csdn.net/detail/supermapsupport/9833944

这篇关于使用iServer JAVA API访问iServer数据服务进行数据操作示例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/745216

相关文章

如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件

《如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件》本文介绍了如何使用Docker部署FTP服务器和Nginx,并通过HTTP访问FTP中的文件,通过将FTP数据目录挂载到N... 目录docker部署FTP和Nginx并通过HTTP访问FTP里的文件1. 部署 FTP 服务器 (

MySQL 日期时间格式化函数 DATE_FORMAT() 的使用示例详解

《MySQL日期时间格式化函数DATE_FORMAT()的使用示例详解》`DATE_FORMAT()`是MySQL中用于格式化日期时间的函数,本文详细介绍了其语法、格式化字符串的含义以及常见日期... 目录一、DATE_FORMAT()语法二、格式化字符串详解三、常见日期时间格式组合四、业务场景五、总结一、

C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)

《C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)》本文主要介绍了C#集成DeepSeek模型实现AI私有化的方法,包括搭建基础环境,如安装Ollama和下载DeepS... 目录前言搭建基础环境1、安装 Ollama2、下载 DeepSeek R1 模型客户端 ChatBo

mysql线上查询之前要性能调优的技巧及示例

《mysql线上查询之前要性能调优的技巧及示例》文章介绍了查询优化的几种方法,包括使用索引、避免不必要的列和行、有效的JOIN策略、子查询和派生表的优化、查询提示和优化器提示等,这些方法可以帮助提高数... 目录避免不必要的列和行使用有效的JOIN策略使用子查询和派生表时要小心使用查询提示和优化器提示其他常

Spring Cloud Hystrix原理与注意事项小结

《SpringCloudHystrix原理与注意事项小结》本文介绍了Hystrix的基本概念、工作原理以及其在实际开发中的应用方式,通过对Hystrix的深入学习,开发者可以在分布式系统中实现精细... 目录一、Spring Cloud Hystrix概述和设计目标(一)Spring Cloud Hystr

Qt实现发送HTTP请求的示例详解

《Qt实现发送HTTP请求的示例详解》这篇文章主要为大家详细介绍了如何通过Qt实现发送HTTP请求,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、添加network模块2、包含改头文件3、创建网络访问管理器4、创建接口5、创建网络请求对象6、创建一个回复对

Python中配置文件的全面解析与使用

《Python中配置文件的全面解析与使用》在Python开发中,配置文件扮演着举足轻重的角色,它们允许开发者在不修改代码的情况下调整应用程序的行为,下面我们就来看看常见Python配置文件格式的使用吧... 目录一、INI配置文件二、YAML配置文件三、jsON配置文件四、TOML配置文件五、XML配置文件

Go使用pprof进行CPU,内存和阻塞情况分析

《Go使用pprof进行CPU,内存和阻塞情况分析》Go语言提供了强大的pprof工具,用于分析CPU、内存、Goroutine阻塞等性能问题,帮助开发者优化程序,提高运行效率,下面我们就来深入了解下... 目录1. pprof 介绍2. 快速上手:启用 pprof3. CPU Profiling:分析 C

MySQL InnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据

《MySQLInnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据》mysql的ibdata文件被误删、被恶意修改,没有从库和备份数据的情况下的数据恢复,不能保证数据库所有表数据... 参考:mysql Innodb表空间卸载、迁移、装载的使用方法注意!此方法只适用于innodb_fi

Spring Boot整合消息队列RabbitMQ的实现示例

《SpringBoot整合消息队列RabbitMQ的实现示例》本文主要介绍了SpringBoot整合消息队列RabbitMQ的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录RabbitMQ 简介与安装1. RabbitMQ 简介2. RabbitMQ 安装Spring