`
seawavenews
  • 浏览: 230081 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

Web Service 开发(VBA连接Tomcat)

阅读更多

一、 java-java实现WebService访问(来自网络)

一、axis安装
1.环境
J2SE SDK 1.5
Servlet Container: 我使用Tomcat 6.0
2.到 http://ws.apache.org/axis/
          网站下载axis安装包
3.解压缩安装包,将axis-version\webapps下的axis包拷贝到TOMCAT_HOME\webapps\下,
以下约定AXIS_HOME为该TOMCAT_HOME\webapps\axis目录
4.启动tomcat,访问http://localhost:8080/axis 检查安装是否成功
5.以上步骤执行成功,可以开发webservice例子了

axis支持三种web service的部署和开发,分别为:
1。Dynamic Invocation Interface ( DII)
2。 Stubs方式
3。Dynamic Proxy方式

二、编写DII(Dynamic Invocation Interface )方式web服务
1.编写服务端程序HelloClient
public class HelloClient {
public String getName(String name)
{
return "hello "+name;
}
}

2.将源码拷贝到AXIS_HOME下,重命名为 HelloClient.jws
3.访问连接http://localhost:8080/axis/HelloClient.jws?wsdl,页面显示axis自动生成的wsdl
4.编写访问服务的客户端 TestHelloClient.java

import org.apache.axis.client.Call;
import org.apache.axis.client.Service;
import javax.xml.namespace.QName;
import javax.xml.rpc.ServiceException;
import java.net.MalformedURLException;
import java.rmi.RemoteException;

public class SayHelloClient2 {
public static void main(String[] args) {
try {
String endpoint = "http://localhost:8080/axis/HelloClient.jws";

Service service = new Service();
Call call = null;

call = (Call) service.createCall();

call.setOperationName(new QName(
"http://localhost:8080/axis/HelloClient.jws", "getName"));
call.setTargetEndpointAddress(new java.net.URL(endpoint));

String ret = (String) call.invoke(new Object[] {"zhangsan"});
System.out.println("return value is " + ret);
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
三、编写Dynamic Proxy方式访问服务
1.编写部署服务端程序,同上边DII方式,本次仍使用上边部署的HelloClient
2.编写代理接口
public interface HelloClientInterface extends java.rmi.Remote {
public String getName(String name) throws java.rmi.RemoteException;
}
3.编写并执行客户端程序TestHelloClient.java

import javax.xml.rpc.Service;
import javax.xml.rpc.ServiceFactory;
import java.net.URL;
import javax.xml.namespace.QName;

public class TestHelloClient {
public static void main(String[] args) {
try
{
String wsdlUrl = "http://localhost:8080/axis/HelloClient.jws?wsdl";
String nameSpaceUri = "http://localhost:8080/axis/HelloClient.jws";
String serviceName = "HelloClientService";
String portName = "HelloClient";

ServiceFactory serviceFactory = ServiceFactory.newInstance();
Service afService = serviceFactory.createService(new URL(wsdlUrl),
new QName(nameSpaceUri, serviceName));
HelloClientInterface proxy = (HelloClientInterface)
afService.getPort(new QName(
nameSpaceUri, portName), HelloClientInterface.class);
System.out.println("return value is "+proxy.getName("john") ) ;
}catch(Exception ex)
{
ex.printStackTrace() ;
}
}
}

四、编写wsdd发布web服务,编写stub client访问web服务

1.编写服务端程序server,SayHello.java,编译server.SayHello.java  
package server;
public class SayHello {
public String getName(String name)
{
return "hello "+name;
}
}
2.编写LogHandler.java
import org.apache.axis.AxisFault;
import org.apache.axis.Handler;
import org.apache.axis.MessageContext;
import org.apache.axis.handlers.BasicHandler;

import java.util.Date;

public class LogHandler extends BasicHandler {
public void invoke(MessageContext msgContext) throws AxisFault
{
/** Log an access each time we get invoked.
*/
try {
Handler serviceHandler = msgContext.getService();

Integer numAccesses =
(Integer)serviceHandler.getOption("accesses");
if (numAccesses == null)
numAccesses = new Integer(0);

numAccesses = new Integer(numAccesses.intValue() + 1);

Date date = new Date();
String result = date + ": service " +
msgContext.getTargetService() +
" accessed " + numAccesses + " timeMoon.";
serviceHandler.setOption("accesses", numAccesses);

System.out.println(result);
} catch (Exception e) {
throw AxisFault.makeFaultEnvelope;
}
}
}
3..编写wsdd文件
deploy.wsdd
<deployment xmlns="http://xml.apache.org/axis/wsdd/"
xmlns:java="http://xml.apache.org/axis/wsdd/providers/java">
  
<handler name="print" type="java:LogHandler"/>
<service name="sayhello" provider="java:RPC">
<requestFlow>
<handler type="print"/>
</requestFlow>
<parameter name="className" value="server.SayHello"/>
<parameter name="allowedMethods" value="*"/>
</service>
</deployment>

3.将编译后的文件拷贝到AXIS_HOME/WEB-INF/classes下,如:D:\tomcat\webapps\axis\WEB-INF\classes
4.发布服务:
java org.apache.axis.client.AdminClient deploy.wsdd
5.生成client stub文件
a:方式1
将SayHello.java拷贝到AXIS_HOME/下,重命名为SayHello.jws,执行下面的命令生存client stub
java org.apache.axis.wsdl.WSDL2Java -p client http://localhost:8080/axis/services/SayHello.jws?wsdl
b:方式2
  执行如下命令生成SayHello.wsdl
java org.apache.axis.wsdl.Java2WSDL -oSayHello.wsdl -lhttp://localhost:8080/axis/services/SayHello -nsayhello server.SayHello
执行如下命令生成client stub
   java org.apache.axis.wsdl.WSDL2Java SayHello.wsdl -p client
生成的stub client文件列表为:
1。SayHello.java
2。SayHelloService.java。
3。SayHelloServiceLocator.java
4。SayHelloSoapBindingStub.java
6.编写客户端程序,编译并执行
public class SayHelloClient {
public static void main(String[] args) {
try {

SayHelloService service = new client.
SayHelloServiceLocator();
client.SayHello_PortType client = service.getSayHello();
String retValue=client.getName("zhangsan");
System.out.println(retValue);


} catch (Exception e) {
System.err.println("Execution failed. Exception: " + e);
}
}
}

二、 VBA-java实现WebService访问(TOMCAT上Web Service开发攻略)
 

首先,要搭建一个环境, 笔者搭建的环境是: Windows2000 Server(中文版)+TOMCAT4<o:p></o:p>

1 http://jakarta.apache.org/下载TOMCAT4,安装,并且配置好。启动TOMCAT4,在浏览器中输入http://localhost:8080。可以看到首页面,表示TOMCAT4已经配置好了。

2 http://xml.apache.org/dist/axis/1_1RC1/下载AXIS,解压缩到$TOMCAT_HOME/webapps/axis下面去。<o:p></o:p>

在浏览器中运行http://localhost:8080/axis/index.html ,测试是否可以运行。

接下来,我们开始开发一个Web Service应用。编辑一个java文件

CalcService.java

public class CalcService {<o:p></o:p>

  public int add(int p1, int p2) {<o:p></o:p>

  <o:p></o:p>

    return p1 + p2;<o:p></o:p>

  }<o:p></o:p>

 <o:p></o:p>

  public int subtract(int p1, int p2) {<o:p></o:p>

 <o:p></o:p>

    return p1 - p2;<o:p></o:p>

  }<o:p></o:p>

}

复制CalcService.java文件到$TOMCAT_HOME/webapps/axis目录下,改名为CalcService.jws。在浏览器中,输入http://localhost:8080/axis/CalcService.jws,得到提示信息如下:

AxisCalcService.jws包装后,提供了一个WSDL的接口外露信息。可以输入http://localhost:8080/axis/CalcService.jws?WSDL 察看WSDL的接口信息。通过WSDL接口,我们可以遍写一个VB程序来调用。

测试步骤如下:

1 http://www.microsoft.com上下载SOAP TOOLKIT 3.0,安装。

2 VB6中新建一个工程,添加一个FORM,FROM的界面如下。

3 分别在两个按钮cmdAddcmdMinus中写上如下代码

Private Sub cmdAdd_Click()<o:p></o:p>

    '测试add方法<o:p></o:p>

    On Error Resume Next<o:p></o:p>

    Dim SoapClient As Object<o:p></o:p>

    <o:p></o:p>

    Set SoapClient = CreateObject("MSSOAP.SoapClient30")<o:p></o:p>

    Call SoapClient.MSSoapInit2(Text1.Text, "", "", "CalcService", "")<o:p></o:p>

    If Err.Number <> 0 Then<o:p></o:p>

        MsgBox SoapClient.FaultString, vbExclamation<o:p></o:p>

        Exit Sub<o:p></o:p>

    End If<o:p></o:p>

    ' Now the client can call an operation listed in the portType element<o:p></o:p>

    ' specified when calling mssoapinit().<o:p></o:p>

    Text4.Text = CStr(SoapClient.Add(Val(Text2.Text), Val(Text3.Text)))<o:p></o:p>

    <o:p></o:p>

    If Err.Number <> 0 Then<o:p></o:p>

        MsgBox SoapClient.FaultString, vbExclamation<o:p></o:p>

        Exit Sub<o:p></o:p>

    End If<o:p></o:p>

End Sub<o:p></o:p>

 <o:p></o:p>

Private Sub cmdMinus_Click()<o:p></o:p>

    '测试substract方法<o:p></o:p>

    On Error Resume Next<o:p></o:p>

    Dim SoapClient As Object<o:p></o:p>

    <o:p></o:p>

    Set SoapClient = CreateObject("MSSOAP.SoapClient30")<o:p></o:p>

    Call SoapClient.MSSoapInit2(Text1.Text, "", "", "CalcService", "")<o:p></o:p>

    If Err.Number <> 0 Then<o:p></o:p>

        MsgBox SoapClient.FaultString, vbExclamation<o:p></o:p>

        Exit Sub<o:p></o:p>

    End If<o:p></o:p>

    ' Now the client can call an operation listed in the portType element<o:p></o:p>

    ' specified when calling mssoapinit().<o:p></o:p>

    Text7.Text = CStr(SoapClient.subtract(Val(Text5.Text), Val(Text6.Text)))<o:p></o:p>

    <o:p></o:p>

    If Err.Number <> 0 Then<o:p></o:p>

        MsgBox SoapClient.FaultString, vbExclamation<o:p></o:p>

        Exit Sub<o:p></o:p>

    End If<o:p></o:p>

End Sub

其中需要注意的是,MSSoapInit2方法简单地说明如下:

HRESULT MSSoapInit2(<o:p></o:p>
          [in] VARIANT par_WSDLFile, <o:p></o:p>
          [in] VARIANT par_WSMLFile, <o:p></o:p>
          [in] BSTR par_ServiceName, <o:p></o:p>
          [in] BSTR par_Port, <o:p></o:p>
          [in] BSTR par_Namespace);<o:p></o:p>
 <o:p></o:p>
par_WSDLFile                  WSDL文件的位置,本例中为
http://localhost:8080/axis/CalcService.jws?wsdl
par_WSMLFile                  本例中为空
par_ServiceName              本例中为空
par_Port                     服务端口号,可以从wsdl文件中找到。<o:p></o:p>
par_Namespace                本例中为空

关于Microsoft SOAP TOOLKIT 3.0的详细说明,我会以后,专门写文章介绍。

4 运行,并且测试。

总结,应用Web Service技术,我们已经看到了,用VB编写的程序一样可以享用JAVA技术,当然也可以享用.NET技术,当然java编写的应用一样可以享用VB6或.NET开发的WebService。这项技术的应用必将给信息系统的结构模式带来全新的改变。

 


分享到:
评论

相关推荐

    VBA Call WebService

    3. **SoapToolkit的使用**:在VBA中,通常会创建一个SoapClient对象,然后设置其属性,如URL指向Web服务的WSDL(Web Service Description Language)文件,定义服务的命名空间和方法名。接着,通过调用对象的方法,...

    Excel通过VBA连接Oracle数据库

    在Excel中通过Visual Basic for Applications (VBA) 连接Oracle数据库是一种强大的自动化工具,能够让你轻松地从大型数据库中提取、处理和分析数据。VBA是Excel内置的编程环境,允许用户创建自定义功能和宏,以实现...

    vba连接各种数据库字符串

    VBA 连接各种数据库字符串 VBA 连接各种数据库字符串是指使用 VBA 语言连接不同的数据库类型,例如 OLE DB Provider for ODBC、SQL Server、Oracle、Microsoft Jet 等。为了实现数据的互通和交换,VBA 提供了多种...

    vba连接DB2的方法(ODBC)

    VBA 连接 DB2 数据库使用 ODBC 的方法 DB2 是 IBM 公司开发的关系数据库管理系统,广泛应用于大型企业和政府机构中。连接 DB2 数据库是许多企业应用系统的关键步骤,而 VBA 则是 Excel、Word 等 Office 软件的编程...

    VBA连接SQLSERVER数据库实例.doc

    在本文中,我们将深入探讨如何使用VBA(Visual Basic for Applications)通过ADO(ActiveX Data Objects)连接到SQL Server数据库并执行数据查询。这个过程在Excel中尤其常见,因为VBA是Excel内置的编程环境,允许...

    VBA连接SQL数据库的代码

    ### VBA连接SQL数据库的代码知识点解析 #### 一、VBA与SQL数据库连接的基本原理 在本案例中,我们探讨的是如何通过VBA(Visual Basic for Applications)来实现与SQL Server数据库的有效连接及数据查询操作。对于...

    EXCEL VBA 连接SAP实例

    EXCEL VBA 连接SAP,并通过BAPI读取数据

    vba连接访问数据库(access)

    在“vba连接访问数据库(access)”这个主题中,我们将探讨如何通过VBA代码与Access数据库进行交互,这对于数据处理、报告生成以及自动化工作流程非常有用。 首先,我们需要了解Access数据库的基本结构。Access...

    AutoCAD2013二次开发VBA插件.zip

    2. **数据交换**:利用VBA可以连接外部数据库,将设计数据导入或导出到AutoCAD,方便项目管理和协同工作。 3. **自定义界面**:创建自定义工具栏和菜单,使常用功能触手可及,提高工作效率。 4. **定制对象行为**...

    ArcGIS二次开发VBA

    **ArcGIS二次开发VBA**是GIS(地理信息系统)领域中的一个重要话题,它涉及使用Visual Basic for Applications(VBA)编程语言来扩展和定制Esri的ArcGIS平台。VBA是一种脚本语言,广泛用于自动化任务,创建自定义...

    Excel VBA 连接MySQL

    使用Excel中的VBA连接MySQL数据库,并进行增删查找等基本操作!很详细的资料,希望能够帮助大家。

    AutoCAD 2014 二次开发 VBA 基础与实例.zip

    本教程"AutoCAD 2014 二次开发 VBA 基础与实例"专注于利用VBA进行AutoCAD的二次开发,适合初学者入门。VBA在AutoCAD中的应用主要体现在以下几个方面: 1. **基本概念与环境设置**:首先,你需要了解VBA的基本概念,...

    VBA开发,连接mysql数据库

    根据给定的信息,本文将详细解释如何通过VBA(Visual Basic for Applications)连接MySQL数据库进行数据操作,并基于示例代码具体分析其实现方法。 ### VBA连接MySQL数据库的知识点 #### 1. VBA与MySQL简介 - **...

    excel 调用barTender打印条码 VBA 调用BarTender打印标签BarTender二次开发 VBA 条码打印

    excel 调用barTender打印条码 VBA 调用BarTender打印标签BarTender二次开发 VBA 条码打印 VBA二维码打印 Excel条码打印 Excel二维码打印 1. 商品跟踪:二维码标签可让制造商和供应商跟踪货物的生产和出货情况。...

    word vba 如何连接sql数据库

    VBA(Visual Basic for Applications)是微软公司开发的一种编程语言,广泛应用于 Office 软件中,如 Word、Excel、PowerPoint 等。VBA 可以与数据库集成,实现数据交互和处理。本文将详细介绍如何使用 VBA 连接 SQL...

    vba数据库连接文件

    vba数据库连接文件

    EXCEL VBA连接数据库查询示例代码.txt

    一个简易的vba连接数据库并根据sql语句进行查询的excel报表,对刚入门的新手是入门教程

    cs_VBA连接NC数据库的周物料需求_

    例如,对于NetSuite,可能需要使用Web服务接口或者通过ODBC数据源连接。连接字符串可能类似于: ``` connStr = "Provider=MSDASQL;DSN=NetSuite;ServerURL=https://yourcompany.netsuite.com;Username=...

Global site tag (gtag.js) - Google Analytics