Java使用AXIS调用webService接口

Java使用AXIS调用webService接口

通用方法-直接上代码

/**
 * @param methodname 调用的方法名
 * @param o 参数
 * @return String 
 */
private String getCallResult(String methodname, Object[] o) {
	String serverpath ="http://localhost:8080/platform-service/settlementServiceImpl?wsdl"
	Service service = new Service();
	try {
		// 通过Service实例创建Call的实例
		Call call = (Call) service.createCall();
		// 将WebService的服务路径加入到call实例之中
		call.setTargetEndpointAddress(serverpath);
		Object a = call.invoke(methodname, o);
		if (a != null) {
			return a.toString();
		} else {
			return null;
		}
	} catch (Exception e) {
		e.printStackTrace();
		System.out.println("调用接口失败", e);
	}
	return null;
}

如果返回值是自定义的bean,在使用通用方法会报错:org.xml.sax.SAXException: Deserializing parameter ‘getAccountInfomantionReturn’: could not find deserializer for type {urn:BeanService}CardUserDTO
无法找到类型的反序列化器,这时需要我们设置返回的参数类型

自定义返回实体类

public CardUserDTO getBalance(String[] paramBalance) {
	try {
		String serverpath = "http://localhost:8080/platform-service/settlementServiceImpl?wsdl";
		Service service = new Service();
		Call call = (Call) service.createCall();
		call.setTargetEndpointAddress(serverpath);
		//设置出参,参数1:参数的命名空间,在http://localhost:8080/platform-service/settlementServiceImpl?wsdl中找到你锁调用的方法的xxxxxRespon,参数2:返回的实体类
		QName outType = new QName("http://webService.wst.synjones.com", "CardUserDTO");
		call.registerTypeMapping(CardUserDTO.class, outType, BeanSerializerFactory.class,
				BeanDeserializerFactory.class);
		// 调用的服务接口方法名
		call.setOperationName("getAccountInfomantion");
		// 传递的参数名,参数类型,入参
		call.addParameter("account", XMLType.XSD_STRING, ParameterMode.IN);
		// 设置服务方法返回类型实体类
		call.setReturnClass(CardUserDTO.class);
		//call.setReturnType(XMLType.XSD_STRING); 
		// Long[] paramBalance = new Long[] { Long.valueOf("1759") };
		String[] paramBalance = new String[] { "1759" };
		CardUserDTO aa = (CardUserDTO) call.invoke("getAccountInfomantion", paramBalance);
		System.out.println(aa.toString());
	} catch (Exception e) {
		e.printStackTrace();
	}
}

当然不能少了包

maven引入:

<!-- WSDL -->
<dependency>
	<groupId>org.apache.axis</groupId>
	<artifactId>axis</artifactId>
	<version>1.4</version>
</dependency>
<dependency>
	<groupId>commons-discovery</groupId>
	<artifactId>commons-discovery</artifactId>
	<version>0.5</version>
</dependency>
<dependency>
	<groupId>org.apache.axis</groupId>
	<artifactId>axis-jaxrpc</artifactId>
	<version>1.4</version>
</dependency>
<dependency>
	<groupId>axis</groupId>
	<artifactId>axis-wsdl4j</artifactId>
	<version>1.5.1</version>
</dependency>

遇到的问题,记录下来,防止再次遇到后的茫然…ლ(´ڡ`ლ)

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用 Java Axis2 调用 WebService 接口可以通过以下步骤实现: 1. 下载并安装 Axis2。你可以从官方网站下载安装包,或者从 Maven 中央仓库获取依赖。 2. 创建一个 Java 项目,并将 Axis2 WebService 客户端库添加到项目依赖中。 3. 根据 WebService WSDL 文件生成客户端代码。你可以使用 Axis2 自带的 wsdl2java 工具,在命令行中运行以下命令: ``` wsdl2java -uri <wsdl-url> -p <package-name> -d <output-directory> ``` 其中,`<wsdl-url>` 是 WebService 的 WSDL 文件地址,`<package-name>` 是你想要生成代码的 Java 包名,`<output-directory>` 是生成代码的输出目录。 4. 在你的 Java 代码中创建 WebService 客户端对象,并调用 WebService 方法。例如: ``` MyWebServiceStub stub = new MyWebServiceStub(); MyWebServiceStub.MyWebServiceRequest request = new MyWebServiceStub.MyWebServiceRequest(); request.setParameter("value"); MyWebServiceStub.MyWebServiceResponse response = stub.myWebServiceMethod(request); System.out.println(response.getResult()); ``` 这里的 `MyWebServiceStub` 是在第三步中生成的客户端代码中的类名,`myWebServiceMethod` 是 WebService 的方法名,`MyWebServiceRequest` 和 `MyWebServiceResponse` 是方法的请求和响应对象。 以上就是使用 Java Axis2 调用 WebService 接口的基本步骤。需要注意的是,在实际项目中,你可能还需要处理异常、设置 WebService 的认证和安全等问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值