[Java] 利用Axis库调用C#的Web Service

简介:

[Java] 利用Axis库调用C#Web Service

编写者

日期

关键词

郑昀@ultrapower

2005-8-2

Java Web Service Axis C#

 

概述

试图从Java调用C#编写的Web Service,借用了王咏刚的wsCaller源代码中DynamicInvoker类。

开始不清楚DynamicInvoker类的portName的含义,望文生义,以为是8080之类的端口号,实际上是下面wsdl中的wsdl:port 节点的“name”属性值“ReadWordSoap”:

wsdl提示:

<wsdl:service name="ReadWord">

  <documentation xmlns="http://schemas.xmlsoap.org/wsdl/">提供Office文档的有选择性地读取文本服务.</documentation>

<wsdl:port name="ReadWordSoap" binding="tns:ReadWordSoap">

  <soap:address location="http://192.168.1.113/ReadOffice/ReadWord.asmx" />

  </wsdl:port>

  </wsdl:service>

 

需要特别引入的7jar包如下所示:

Jar

对应的库

用途

Axis.jar

org.apache.axis.*

 

wsdl4j-1.5.1.jar

javax.wsdl.*

wsdl操作

jaxrpc.jar

javax.xml.rpc.*

xml.rpc

commons-discovery-0.2.jar

 

discovery

log4j-1.2.11.jar

 

Axis需要log4net

commons-logging.jar

 

Axis需要LogFactory

saaj.jar

 

引入SOAP

 

演示代码

请求一个C#编写的Web Service,利用DynamicInvoker遍历web service每一个方法,获取serverName、参数列表以及类型

代码演示:

import java.util.Map;

import java.util.Vector;

import java.util.Iterator;

import java.util.Arrays;

 

import org.apache.axis.wsdl.symbolTable.*;

 

public class wsCaller {

 

      /**

       * @param args

       */

      public static void main(String[] args) {

          

           String wsdlLocation =

            "http://192.168.1.113/ReadOffice/ReadWord.asmx?wsdl";

           String serviceName = "ReadWord";

        String operationName = "read";

        String strFirstParam = "c:\\nlb.log";

           String strSecondParam = "0";

           String strThirdParam = "200";

       

        String portName = "ReadWordSoap";

 

           /*

            添加web service方法的输入参数到Vector

            */

           Vector parameterValues = new Vector();

           parameterValues.addElement(strFirstParam);

           parameterValues.addElement(strSecondParam);

           parameterValues.addElement(strThirdParam);

          

           try

           {

              DynamicInvoker invoker = new DynamicInvoker(wsdlLocation);

                

                 /*

                  遍历web service每一个方法,获取serverName、参数列表以及类型的过程

                  */

                 Vector vServices = invoker.enumServiceNames();

                 Object[] Services = vServices.toArray();

                 Arrays.sort(Services);

                 for (int i = 0; i < Services.length; i++)

                 {

                      String strServiceName = (String) Services[i];

                      System.out.println("ServiceName=" + serviceName);

                                            

                      Vector V = invoker.enumPortNames(strServiceName);

                      String strPortName = (String) V.elementAt(0);

                      System.out.println("PortName=" + strPortName);

                     

                      V = invoker.enumOperationNames(strServiceName, strPortName);

                      Object[] OperationNames = V.toArray();

                      Arrays.sort(OperationNames);

                      for (int j = 0; j < OperationNames.length; j++)

                     {

                            String strOperationName = (String) OperationNames[j];

                            System.out.println("\t" + (String) OperationNames[j]);

                            Parameters parameters = invoker.enumParameters(strServiceName, strPortName, strOperationName);

                            Vector v = parameters.list;

                            Vector vParameterValues = new Vector();

                            for (int k = 0; k < v.size(); k++)

                            {

                                  Parameter para = (Parameter) v.elementAt(k);

                                  System.out.print("\t\t" + para.getQName().getLocalPart());

                                  if (para.getType().getQName().getLocalPart().equals("string"))

                                  {

                                       vParameterValues.addElement("asdasdas");

                                  }

                                 else

                                 {

                                        vParameterValues.addElement(null);

                                 }

                                 System.out.print("\t" + para.getType().getQName().getLocalPart());

                                 System.out.println("\t" + invoker.getParameterModeString(para));

                            }

                    }

                 }

                  

// 最后一个参数是调用web service的超时时间,这个原来是固化在类里面的

// 但其实应该暴露出来

              Map map = invoker.invoke(serviceName,

                            portName, operationName, parameterValues,

                            new Integer(60 * 1000));

     

              // print result

              System.out.println("Result:");

              for (Iterator it = map.keySet().iterator(); it.hasNext();)

                 {

                  String name = (String) it.next();

                      System.out.println(name + "=" + map.get(name));

              }

              System.out.println("\nDone!");

           }

           catch (Exception exc) {

                 exc.printStackTrace();

        }

      }

 

}

 

最后输出的结果如下所示:

ServiceName=ReadWord

PortName=ReadWordSoap

    read

        >read>DocumentFilePath  string  [IN]

        >read>begin int [IN]

        >read>end   int [IN]

Result:

>readResponse>readResult=0018

 

立此存照。

 

编写者

日期

关键词

郑昀@ultrapower

2005-8-2

Java Web Service Axis C#

 

目录
相关文章
|
5月前
【Azure 应用服务】Web App Service 中的 应用程序配置(Application Setting) 怎么获取key vault中的值
【Azure 应用服务】Web App Service 中的 应用程序配置(Application Setting) 怎么获取key vault中的值
|
2月前
【Azure App Service】PowerShell脚本批量添加IP地址到Web App允许访问IP列表中
Web App取消公网访问后,只允许特定IP能访问Web App。需要写一下段PowerShell脚本,批量添加IP到Web App的允许访问IP列表里!
|
3月前
|
Java 程序员 测试技术
Java|让 JUnit4 测试类自动注入 logger 和被测 Service
本文介绍如何通过自定义 IDEA 的 JUnit4 Test Class 模板,实现生成测试类时自动注入 logger 和被测 Service。
37 5
|
4月前
|
SQL C# 数据库
EPPlus库的安装和使用 C# 中 Excel的导入和导出
本文介绍了如何使用EPPlus库在C#中实现Excel的导入和导出功能。首先,通过NuGet包管理器安装EPPlus库,然后提供了将DataGridView数据导出到Excel的步骤和代码示例,包括将DataGridView转换为DataTable和使用EPPlus将DataTable导出为Excel文件。接着,介绍了如何将Excel数据导入到数据库中,包括读取Excel文件、解析数据、执行SQL插入操作。
EPPlus库的安装和使用 C# 中 Excel的导入和导出
|
3月前
|
存储 消息中间件 NoSQL
Redis 入门 - C#.NET Core客户端库六种选择
Redis 入门 - C#.NET Core客户端库六种选择
76 8
|
3月前
|
Java 数据库
基于java的汽车服务管理系统(Car Service Management System)
基于java的汽车服务管理系统(Car Service Management System)
30 0
|
4月前
|
SQL 开发框架 安全
并发集合与任务并行库:C#中的高效编程实践
在现代软件开发中,多核处理器普及使多线程编程成为提升性能的关键。然而,传统同步模型在高并发下易引发死锁等问题。为此,.NET Framework引入了任务并行库(TPL)和并发集合,简化并发编程并增强代码可维护性。并发集合允许多线程安全访问,如`ConcurrentQueue&lt;T&gt;`和`ConcurrentDictionary&lt;TKey, TValue&gt;`,有效避免数据不一致。TPL则通过`Task`类实现异步操作,提高开发效率。正确使用这些工具可显著提升程序性能,但也需注意任务取消和异常处理等常见问题。
60 1
|
3月前
|
API C#
异步轮询 Web API 的实现与 C# 示例
异步轮询 Web API 的实现与 C# 示例
96 0
|
5月前
|
前端开发 JavaScript C#
C#开发者的新天地:Blazor如何颠覆传统Web开发,打造下一代交互式UI?
【8月更文挑战第28天】Blazor 是 .NET 生态中的革命性框架,允许使用 C# 和 .NET 构建交互式 Web UI,替代传统 JavaScript。本文通过问答形式深入探讨 Blazor 的基本概念、优势及应用场景,并指导如何开始使用 Blazor。Blazor 支持代码共享、强类型检查和丰富的生态系统,简化 Web 开发流程。通过简单的命令即可创建 Blazor 应用,并利用其组件化和数据绑定特性快速搭建界面。无论对于 .NET 还是 Web 开发者,Blazor 都是一个值得尝试的新选择。
208 1
|
5月前
|
关系型数据库 MySQL Linux
【Azure 应用服务】在创建Web App Service的时候,选Linux系统后无法使用Mysql in App
【Azure 应用服务】在创建Web App Service的时候,选Linux系统后无法使用Mysql in App
【Azure 应用服务】在创建Web App Service的时候,选Linux系统后无法使用Mysql in App