分布环境下Tuscany webservice 客户端的调用

微笑以计算器为例

1、Tuscany

如图1,References代表需要注入的对象,Services代表提供的接口供外部调用,这些可以通过Java版本中的Annotation:@Service(XX.class)、@Reference定义,也可以通过以下XML文档(.composite后缀)中定义。

 

图1 Tuscany组件

<component>
  <implementation />
  <service />
  <reference />
  </component>
</composite>

 

图2 Tuscany结构

2、分析

服务端采用webservice绑定,提供wsdl接口,客户端除了使用Tuscany访问之外,还可以使用一切支持webservice的技术,包括Axis2、JAX-WS、C#等,如图3

 

图3 Tuscany ws和客户端分析图

3、服务端略

WSDL http://localhost:8081/CalService(下面客户端要用到)

4、客户端

Axis2:

 使用Eclipse生成的一些本地代理(Stub),调用其中的XXLocator类

try{  
    CalService cal = new CalServiceComponent_CalServiceLocator().getCalServiceSOAP11Port(); 
    System.out.println(cal.add(10, 5)+cal.subtract(10, 5));
}catch(Exception e){  
    e.printStackTrace();
}

 

C#

使用windows SDK wsdl.exe生成客户端代理类CalSericeComponent_CalService,调用其中的方法

wsdl.exe /language:C# http://localhost:8081/CalService?wsdl

using System;
using System.IO;
public class CalClient{
    public static void Main(){
	CalServiceComponent_CalService calService = new CalServiceComponent_CalService ();
	add add1 = new add();
	add1.arg0 = 10;
	add1.arg1 = 5;
        Console.WriteLine(calService.add(add1).@return);
    }
}


 

参考:http://tuscany.apache.org/quick-guide-to-sca.html

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值