axis2,Axis2的具体使用
各位朋友,你是否对axis2和Axis2的具体使用的相关问题感到好奇?别担心,我将为你揭示这些问题的答案,帮助你更好地理解和应用这些知识。让我们一起探索吧!
axis2调用webservice问题
importjavax.xml.namespace.QName;
importorg.apache.axiom.om.OMAbstractFactory;
importorg.apache.axiom.om.OMElement;
importorg.apache.axiom.om.OMFactory;
importorg.apache.axiom.om.OMNamespace;
importorg.apache.axis2.AxisFault;
importorg.apache.axis2.addressing.EndpointReference;
importorg.apache.axis2.client.Options;
importorg.apache.axis2.client.ServiceClient;
importorg.apache.axis2.rpc.client.RPCServiceClient;
publicclasstest{
publicstaticvoidmain(String[]args)throwsException{
//使用RPC方式调用WebService
RPCServiceClientser=newRPCServiceClient();
Optionsoptions=ser.getOptions();
//指定调用WebService的URL
EndpointReferencetargetEPR=newEndpointReference(
"http://webservice.webxml.com.cn/WebServices/MobileCodeWS.asmx?WSDL");
options.setTo(targetEPR);
options.setAction("http://WebXml.com.cn/getMobileCodeInfo");
//指定getMobileCodeInfo方法的参数值
Object[]opAddEntryArgs=newObject[]{"15818843224","15848888"};
//指定getMobileCodeInfo方法返回值的数据类型的Class对象
Class[]classes=newClass[]{String.class,String.class};
//指定要调用的getMobileCodeInfo方法及WSDL文件的命名空间
QNameopAddEntry=newQName("http://WebXml.com.cn/","getMobileCodeInfo");
//调用getMobileCodeInfo方法并输出该方法的返回值
Object[]str=ser.invokeBlocking(opAddEntry,opAddEntryArgs,classes);
// System.out.println(ser.invokeBlocking(opAddEntry,opAddEntryArgs));
try{
ServiceClientsc=newServiceClient();
Optionsopts=newOptions();
//确定目标服务地址
opts.setTo(newEndpointReference(
"http://webservice.webxml.com.cn/WebServices/MobileCodeWS.asmx?WSDL"));
//确定调用方法
opts.setAction("http://WebXml.com.cn/getMobileCodeInfo");
sc.setOptions(opts);
//发送请求并并得到返回结果,注意参数生成方法的分析
OMElementres=sc.sendReceive(createPayLoad());
//值得注意的是,返回结果就是一段由OMElement对象封装的xml字符串。
//我们可以对之灵活应用,下面我取第一个元素值,并打印之。因为调用的方法返回一个结果
res.getFirstElement().getText();
System.out.println(res.getFirstElement().getText());
}catch(AxisFaulte){
e.printStackTrace();
}
}
publicstaticOMElementcreatePayLoad(){
OMFactoryfac=OMAbstractFactory.getOMFactory();
//指定命名空间
OMNamespaceomNs=fac.createOMNamespace("http://WebXml.com.cn/","nsl");
//指定方法
OMElementmethod=fac.createOMElement("getMobileCodeInfo",omNs);
//指定方法的参数
OMElementvalue=fac.createOMElement("mobileCode",omNs);
value.setText("15818843224");
method.addChild(value);
OMElementvalue1=fac.createOMElement("userID",omNs);
value1.setText("");
method.addChild(value1);
//返回方法(实际上就是OMElement封装的xml字符串)
returnmethod;
}
}
我不知道怎么使用rpc这种方法能够拼凑出如下的内容:
<?xmlversion="1.0"encoding="utf-8"?>
<soap:Envelopexmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:xsd="http://www.w3.org/2001/XMLSchema"xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
<soap:Body>
<getMobileCodeInfoxmlns="http://WebXml.com.cn/">
<mobileCode>string</mobileCode>
<userID>string</userID>
</getMobileCodeInfo>
</soap:Body>
</soap:Envelope>
你的代码只能够产生如下的内容:
不知道是不是.net的webservice是不是一定要
<mobileCode>string</mobileCode>
<userID>string</userID>
形式的,但是使用rpc方式,我是不知道怎么办到的,所以我只能采用document方式调用,生成如下的内容:
现在总算是可以了:
15818843224:广东广州广东移动全球通卡
Axis2的具体使用
为了搞个Web Services,让我真是煞费苦心.还好最后用到了axis,在axis上发布Web Services是一件很轻松的事情.甚至不做配置的情况下都可以采用即时发布.就象JSP的发布
安装axis需要Servlet容器,我用的是Tomcat-5.0.28,下载Tomcat和axis我就不说了,下载后将axis解压后,将axis文件夹考到Tomcat的webapps下.
设置环境变量是非常重要的,设置环境变量:AXISCLASSPATH为:
%AXIS_LIB%axis.jar;%AXIS_LIB%commons-discovery-0.2.jar;%AXIS_LIB%commons-logging-1.0.4.jar;%AXIS_LIB%jaxrpc.jar;%AXIS_LIB%saaj.jar;%AXIS_LIB%log4j-1.2.8.jar;%AXIS_LIB%wsdl4j-1.5.1.jar;%AXIS_LIB%xml-apis.jar;%AXIS_LIB%xercesImpl.jar
设置AXIS_LIB为随便一个文件夹,将上面的一堆jar包搞进去.再将activation.jar, mail.jar, wsdl4j-1.5.1.jar搞到%CATALINA_HOME%commonlib下.
若启动Tomcat后在浏览器输入:http://localhost:8080/axis/happyaxis.jsp,若Needed Components都加载了就说明正常启动了axis.
axis支持两种发布方式:(先启动Tomcat)
1.即时发布:直接使用java语言编辑.jws文件,将它放到axis目录下.
实例:用文本编辑器编写HelloWorld.jws
public class HelloWorld
{
public String helloWorld(){
System.out.println("Hello World!");
return"Hello World!";
}
}
拷贝到axis下,在浏览器中输入:http://localhost:8080/axis/HelloWorld.jws?wsdl,若显示出相应的描述,说明发布成功,一般不会失败的,除非axis本身有问题.
2.定制发布:将编译完的.class文件放到axisWEB-INF,要包含包的文件夹.然后编写.wsdd文件,用org.apache.axis.client.AdminClient来发布
实例:编写并编译文件Capacity.java.
package samples.capacity;
public class Capacity
{
public double convertGallon2Litre(double gallon,String user){
if("Andy".equals(user))
return gallon* 4.546;
else
return 0.0d;
}
}
将Capacity.class文件拷贝到axisWEB-INFclasses下(带着文件夹拷),编写deploy.wsdd文件
<deployment xmlns="http://xml.apache.org/axis/wsdd/" xmlns:java="http://xml.apache.org/axis/wsdd/providers/java">
<service name="Capacity" provider="java:RPC">
<parameter name="className" value="samples.capacity.Capacity"/>
<parameter name="allowedMethods" value="*"/>
</service>
</deployment>
拷到Capacity.class所在的目录,在控制台切换到该目录执行:
java-cp%AXISCLASSPATH% org.apache.axis.client.AdminClient deploy.wsdd
显示如下信息说明发布完毕:
Processing file deploy.wsdd
<Admin>Doneprocessing</Admin>
在浏览器输入http://localhost:8080/axis/services/Capacity?wsdl,若显示描述,则说明发布成功.(好象要等一段时间才)
调用Web Services:编写AXISTest.java文件:
package axisexercise;
import org.apache.axis.client.Call;
import org.apache.axis.client.Service;
import org.apache.axis.encoding.XMLType;
import javax.xml.rpc.ParameterMode;
public class AXISTest
{
public static void main(String[] args) throws Exception{
Service service= new Service();
Call call=( Call) service.createCall();
//////////访问即时发布的Distance服务
//设置访问点
call.setTargetEndpointAddress("http://localhost:8080/axis/Distance.jws");
//设置操作名
call.setOperationName("convertMile2Kilometre");
//设置入口参数
call.addParameter("op1",XMLType.XSD_DOUBLE,ParameterMode.IN);
call.setReturnType( XMLType.XSD_DOUBLE);
Double d1= new Double( 190);
//调用服务
System.out.println(d1+"英里相当于"+ call.invoke(new Object[]{d1})+"公里!");
//////////访问定制发布的Capacity服务
call=( Call) service.createCall();
//设置访问点
call.setTargetEndpointAddress("http://localhost:8080/axis/services/Capacity");
//设置操作名
call.setOperationName("convertGallon2Litre");
//设置入口参数
call.addParameter("op1",XMLType.XSD_DOUBLE,ParameterMode.IN);
call.addParameter("op2",XMLType.XSD_STRING,ParameterMode.IN);
call.setReturnType( XMLType.XSD_DOUBLE);
d1= new Double( 10.00);
String str1="ss";
//调用服务
System.out.println(d1+"加仑相当于"+ call.invoke( new Object[]{d1,str1})+"升!");
}
}
编译:javac-classpath.;%AXISCLASSPATH% AXISTest.java
执行:java-classpath.;%CATALINA_HOME%commonlibwsdl4j-1.5.1.jar;%AXISCLASSPATH% axisexercise.AXISTest
显示如下结果:
log4j:WARN No appenders could be found for logger(org.apache.axis.i18n.ProjectResourceBundle).
log4j:WARN Please initialize the log4j system properly.
190.0英里相当于 305.71公里!
10.0加仑相当于 0.0升!
若将AXISTest.java中的str1改为Andy,则接过就是45.46升
Axis2的主要特点
采用名为 AXIOM(AXIs Object Model)的新核心XML(标准通用标记语言的子集)处理模型,利用新的XML解析器提供的灵活性按需构造对象模型。支持不同的消息交换模式。目前Axis2支持三种模式:In-Only、Robust-In和In-Out。In-Only消息交换模式只有SOAP请求,而不需要应答;Robust-In消息交换模式发送SOAP请求,只有在出错的情况下才返回应答;In-Out消息交换模式总是存在SOAP请求和应答。提供阻塞和非阻塞客户端 API。支持内置的 Web服务寻址(WS-Addressing)。灵活的数据绑定,可以选择直接使用 AXIOM,使用与原来的 Axis相似的简单数据绑定方法,或使用XMLBeans、JiBX或 JAXB 2.0等专用数据绑定框架。新的部署模型,支持热部署。支持HTTP,SMTP,JMS,TCP传输协议。支持REST(Representational State Transfer)。
Axis2的介绍
Axis2是下一代 Apache Axis。Axis2虽然由 Axis 1.x处理程序模型提供支持,但它具有更强的灵活性并可扩展到新的体系结构。Axis2基于新的体系结构进行了全新编写,而且没有采用 Axis 1.x的常用代码。支持开发 Axis2的动力是探寻模块化更强、灵活性更高和更有效的体系结构,这种体系结构可以很容易地插入到其他相关 Web服务标准和协议(如 WS-Security、WS-ReliableMessaging等)的实现中。Apache Axis2是Axis的后续版本,是新一代的SOAP引擎。
好了,文章到此结束,希望可以帮助到大家。