Skip to content

anylogic/alogic-xscript-rest

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

alogic-xscript-rest

Overview

alogic-xscript-rest是基于xscript2.0的rest插件,提供了调用rest服务所需的相关指令。

Getting started

按照以下步骤,您可轻松在您的项目中使用alogic-xscript-rest.

不过开始之前,我们希望您了解xscript的相关知识。

增加maven依赖

您可以在中央仓库上找到alogic-xscript-rest的发布版本。

    <dependency>
        <groupId>com.github.anylogic</groupId>
        <artifactId>alogic-xscript-rest</artifactId>
        <version>4.5.2-20160825</version>
    </dependency>   	

alogic-xscript-rest版本号前面的4.5.2是其所依赖的HttpClient的版本号,后面的20160825是其发布的日期。

引入Namespace

在您的脚本中,你需要引入rest作为Namespace,比如:

	
	<using xmlTag="rest" module="com.alogic.xscript.rest.Domain"/>
	
	<rest>
		<!--
			在这里你可以使用alogic-xcript-rest提供的语句
		-->
	</rest>

Example

调用www.weather.com.cn的天气服务接口,查询广州的天气情况。

	<script>
		<using xmlTag="rest" module="com.alogic.xscript.rest.Domain"/>
		
		<!-- 城市:广州 -->
		<set id="city" value="101280101"/>
		
		<rest base="http://www.weather.com.cn/data">
			<mGet path="/sk/${city}.html">
				<response>
					<result/>
					<switch value="${httpCode}">
						<asJson case="200">
							<copy tag="city" path="$.weatherinfo"/>
						</asJson>
						<throw case="default" code="core.rest_failed" msg="远程服务调用错误."/>
					</switch>
				</response>
			</mGet>
		</rest>
	</script>

您可以参考我们的Demo代码来测试您的脚本。我们的Demo非常简单:

	public class Demo {
	
		/**
		 * to run the script.
		 */
		public static void run(String src,Properties p){
			Script script = Script.create(src, p);
			if (script == null){
				System.out.println("Fail to compile the script");
				return;
			}
			long start = System.currentTimeMillis();
			Map<String,Object> root = new HashMap<String,Object>();
			LogicletContext ctx = new LogicletContext(p);
			script.execute(root, root, ctx, new ExecuteWatcher.Quiet());
			
			System.out.println("Script:" + src);
			System.out.println("Duration:" + (System.currentTimeMillis() - start) + "ms");
			
			JsonProvider provider = JsonProviderFactory.createProvider();
			System.out.println("#########################################################");
			System.out.println(provider.toJson(root));				
			System.out.println("#########################################################");
		}
		
		public static void main(String[] args) {
			Settings settings = Settings.get();		
			settings.addSettings(new CommandLine(args));		
			settings.addSettings("java:///conf/settings.xml#Demo",null,Settings.getResourceFactory());
			
			run("java:///xscript/Helloworld.xml#Demo",settings);
			run("java:///xscript/weather.gz.xml#Demo",settings);
			run("java:///xscript/weather.sz.xml#Demo",settings);
		}	
	}

您可以发现,你只要简单的告诉Demo,你的脚本在哪儿,Demo就能够帮你运行,上面的java:///xscript/weather.gz.xml#Demo就是案例中的脚本。

当然,您的脚本最终都是要作为一个服务或者批处理集成在应用中,您可以参考基于xscript的together

Reference

参见alogic-xscript-rest参考.

History

  • 4.5.2 [20160726 duanyy]
    • 初次发布
  • 4.5.2.1 [20160825 duanyy]
    • 发布20160825版本
  • 4.5.2.2 [20170315 duanyy]
    • 基于alogic-1.6.7,发布20170315版本
  • 4.5.2.3 [20170512 duanyy]
    • 基于alogic-1.6.8发布新版本
    • 解决1.6.8中xscript的兼容性问题

About

基于xscript2.0的REST插件

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages