使用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

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定