WebService - Axis2使用services.xml进行开发server与client(未与Spring整合)

简介: WebService - Axis2使用services.xml进行开发server与client(未与Spring整合)

服务端使用services.xml进行开发配置,发布到Tomcat,客户端有三种方式进行开发,使用main方法测试。

【1】环境准备

将axis2.war解压开,将conf,lib(去掉txt),modules,service 四个文件夹复制到已有项目的WEB-INF下。

将lib中的jar Add BuildPath。


【2】开发接口与实现类

接口类如下:

package com.web.Axis2.service;
public interface MyService {
    public String sayHello(String name);
}


实现类如下:

package com.web.Axis2.service.impl;
import com.web.Axis2.service.MyService;
public class MyServiceImpl implements MyService{
    @Override
    public String sayHello(String name) {
        System.out.println("this is service "+name);
        return "hello "+name;
    }
}


【3】配置services.xml

在services文件下新建一个文件夹(任意取名),再新建META-INF文件夹,最后再新增services.xml,接口信息就写在这里面。


具体路径:WEB-INF/services/myservice/META-INF/services.xml 。


【4】发布项目,测试服务端



【5】编写客户端

这里有三种方式:


① 使用wsdl文件(或wsdl的url)生成Stub,进行客户端研发;

② 使用RPC方式,进行service远程调用;

③ 使用document方式。

这里使用第二种方式,更便捷,不用生成Stub。

第二种方式客户端代码如下:

package com.web.client;
import javax.xml.namespace.QName;
import org.apache.axis2.AxisFault;
import org.apache.axis2.addressing.EndpointReference;
import org.apache.axis2.client.Options;
import org.apache.axis2.rpc.client.RPCServiceClient;
public class Client {
    public static void main(String[] args) {
        String url="http://localhost:8080/Axis2/services/AxisService?wsdl";  
        //调用的方法名
        String method="sayHello";  
        RPCServiceClient serviceClient;  
        try {  
            serviceClient = new RPCServiceClient();  
            Options options = serviceClient.getOptions();  
            EndpointReference targetEPR = new EndpointReference(url);  
            options.setTo(targetEPR);  
            // 在创建QName对象时,QName类的构造方法的第一个参数表示WSDL文件的命名空间名,也就是<wsdl:definitions>元素的targetNamespace属性值  
             QName opAddEntry = new QName("http://impl.service.Axis2.web.com",method);   
             Object[] opAddEntryArgs = new Object[] {"Tom"};  
             Class[] classes = new Class[] {String.class };  
            // 返回参数类型,这个和axis1有点区别  
             // invokeBlocking方法有三个参数,其中第一个参数的类型是QName对象,表示要调用的方法名;  
             // 第二个参数表示要调用的WebService方法的参数值,参数类型为Object[];  
             // 第三个参数表示WebService方法的返回值类型的Class对象,参数类型为Class[]。  
             // 当方法没有参数时,invokeBlocking方法的第二个参数值不能是null,而要使用new Object[]{}  
             // 如果被调用的WebService方法没有返回值,应使用RPCServiceClient类的invokeRobust方法,  
             // 该方法只有两个参数,它们的含义与invokeBlocking方法的前两个参数的含义相同  
             Object[] result=serviceClient.invokeBlocking(opAddEntry,opAddEntryArgs, classes);  
             System.out.println(result[0].toString());  
        } catch (AxisFault e) {  
            // TODO Auto-generated catch block  
            e.printStackTrace();  
        }  
    }  
}

【5】测试webservice

客户端输出结果如下:


服务端输出结果如下:



客户端测试结果如下:


服务端测试结果如下:


【6】第三种Client调用方式(document)

客户端代码如下:

package com.web.client;
import java.util.Iterator;
import org.apache.axiom.om.OMAbstractFactory;
import org.apache.axiom.om.OMElement;
import org.apache.axiom.om.OMFactory;
import org.apache.axiom.om.OMNamespace;
import org.apache.axis2.AxisFault;
import org.apache.axis2.addressing.EndpointReference;
import org.apache.axis2.client.Options;
import org.apache.axis2.client.ServiceClient;
public class Client2 {
    /**
     * document方式
     * @param args
     */
    public static void main(String[] args) {
        try {  
              String url="http://localhost:8080/Axis2/services/AxisService?wsdl";  
              Options options = new Options();  
              // 指定调用WebService的URL  
              EndpointReference targetEPR = new EndpointReference(url);  
              options.setTo(targetEPR);  
              options.setAction("http://impl.service.Axis2.web.com/sayHello");  
              ServiceClient sender = new ServiceClient();  
              sender.setOptions(options);  
              OMFactory fac = OMAbstractFactory.getOMFactory();  
              // targetNameSpace
              String tns = "http://impl.service.Axis2.web.com";  
              OMNamespace omNs = fac.createOMNamespace(tns, "");  
              // 接口的方法
              OMElement method = fac.createOMElement("sayHello", omNs);  
              //方法的参数
              OMElement name = fac.createOMElement("name", omNs);  
              //设置参数值
              name.setText("Jane"); 
              method.addChild(name);  
              method.build();  
              OMElement result = sender.sendReceive(method);  
              System.out.println(result);  
              System.out.println("****************************************************************************************************************");
              Iterator in = result.getChildElements();
              while(in.hasNext()){  
                OMElement om = (OMElement)in.next();  
                System.out.println(om.getText());
              }  
            } catch (AxisFault axisFault) {  
              axisFault.printStackTrace();  
            }  
    }
}

【7】第一种Client调用方式(Stub)

配置axis2环境变量(或在DOS下进入axis2bin路径)

AXIS2_HOME=D:\Java_Tomcat_MySQL_jdk_zip\axis2-1.7.6
Path: % AXIS2_HOME%\bin

执行命令如下:

wsdl2java -uri http://localhost:8080/Axis2/services/AxisService?wsdl -p com.web.client -s -o stub

20171104141405502.png


会在bin目录下生成stub文件夹:


将Stub拷入项目,进行使用;客户端代码如下:

package com.web.client;
import com.web.client.AxisServiceStub.SayHello;
import com.web.client.AxisServiceStub.SayHelloResponse;
public class Client3 {
    /**
     * Stub方式
     * @param args
     * @throws Exception 
     */
    public static void main(String[] args) throws Exception {
         try{  
                AxisServiceStub stub = new AxisServiceStub();  
                SayHello sayHello = new SayHello();
                sayHello.setName("Janus");  
                SayHelloResponse res = stub.sayHello(sayHello); 
                String result = res.get_return();
                System.out.println(result);  
            }catch(Exception ex){  
                ex.printStackTrace();  
            }  
    }
}


【8】关于wsdl2java说明

wsdl2java 用于根据WSDL生成相应的服务端和客户端代码的生成工具。

命令行格式为:

WSDL2Java [options] -uri <url or path> : A url or path to a WSDL

其中常用的options具体如下:

-o <path> : 指定生成代码的输出路径
-a : 生成异步模式的代码
-s : 生成同步模式的代码
-p <pkg> : 指定代码的package名称
-l <languange> : 使用的语言(Java/C) 默认是java
-t : 为代码生成测试用例
-ss : 生成服务端代码 默认不生成
-sd : 生成服务描述文件 services.xml,仅与-ss一同使用
-d <databinding> : 指定databingding,例如,adb,xmlbean,jibx,jaxme and jaxbri
-g : 生成服务端和客户端的代码
-pn <port_name> : 当WSDL中有多个port时,指定其中一个port
-sn <serv_name> : 选择WSDL中的一个service
-u : 展开data-binding的类
-r <path> : 为代码生成指定一个repository
-ssi : 为服务端实现代码生成接口类
-S : 为生成的源码指定存储路径
-R : 为生成的resources指定存储路径
–noBuildXML : 输出中不生成build.xml文件
–noWSDL : 在resources目录中不生成WSDL文件
–noMessageReceiver : 不生成MessageReceiver类


可以直接指定输出路径到项目下:

wsdl2java -uri http://localhost:8080/Axis2/services/AxisService?wsdl -p com.web.client2 -s -o C:\Users\12746\eclipse\workspace2\Axis2Client\

20171104142228444.png


生成的Stub如下所示:



目录
相关文章
|
5天前
|
监控 Java 应用服务中间件
SpringBoot是如何简化Spring开发的,以及SpringBoot的特性以及源码分析
Spring Boot 通过简化配置、自动配置和嵌入式服务器等特性,大大简化了 Spring 应用的开发过程。它通过提供一系列 `starter` 依赖和开箱即用的默认配置,使开发者能够更专注于业务逻辑而非繁琐的配置。Spring Boot 的自动配置机制和强大的 Actuator 功能进一步提升了开发效率和应用的可维护性。通过对其源码的分析,可以更深入地理解其内部工作机制,从而更好地利用其特性进行开发。
19 6
|
15天前
|
人工智能 Java API
阿里云工程师跟通义灵码结伴编程, 用Spring AI Alibaba来开发 AI 答疑助手
本次分享的主题是阿里云工程师跟通义灵码结伴编程, 用Spring AI Alibaba来开发 AI 答疑助手,由阿里云两位工程师分享。
阿里云工程师跟通义灵码结伴编程, 用Spring AI Alibaba来开发 AI 答疑助手
|
2月前
|
人工智能 前端开发 Java
Spring AI Alibaba + 通义千问,开发AI应用如此简单!!!
本文介绍了如何使用Spring AI Alibaba开发一个简单的AI对话应用。通过引入`spring-ai-alibaba-starter`依赖和配置API密钥,结合Spring Boot项目,只需几行代码即可实现与AI模型的交互。具体步骤包括创建Spring Boot项目、编写Controller处理对话请求以及前端页面展示对话内容。此外,文章还介绍了如何通过添加对话记忆功能,使AI能够理解上下文并进行连贯对话。最后,总结了Spring AI为Java开发者带来的便利,简化了AI应用的开发流程。
421 0
|
24天前
|
监控 JavaScript 数据可视化
建筑施工一体化信息管理平台源码,支持微服务架构,采用Java、Spring Cloud、Vue等技术开发。
智慧工地云平台是专为建筑施工领域打造的一体化信息管理平台,利用大数据、云计算、物联网等技术,实现施工区域各系统数据汇总与可视化管理。平台涵盖人员、设备、物料、环境等关键因素的实时监控与数据分析,提供远程指挥、决策支持等功能,提升工作效率,促进产业信息化发展。系统由PC端、APP移动端及项目、监管、数据屏三大平台组成,支持微服务架构,采用Java、Spring Cloud、Vue等技术开发。
|
2月前
|
XML JSON Java
Spring Boot 开发中常见的错误
本文总结了 Java 开发中常见的几个问题及其改进方法,包括:1. 过度使用 `@Component` 注解;2. `@ResponseBody` 注解的错误用法;3. `@Autowired` 的不当使用;4. `application.properties` 管理不善;5. 异常处理不当。每部分详细解释了错误情况和建议的改进方案,并提供了相应的代码示例。
65 11
|
2月前
|
IDE Java 测试技术
互联网应用主流框架整合之Spring Boot开发
通过本文的介绍,我们详细探讨了Spring Boot开发的核心概念和实践方法,包括项目结构、数据访问层、服务层、控制层、配置管理、单元测试以及部署与运行。Spring Boot通过简化配置和强大的生态系统,使得互联网应用的开发更加高效和可靠。希望本文能够帮助开发者快速掌握Spring Boot,并在实际项目中灵活应用。
59 5
|
2月前
|
前端开发 Java 开发者
这款免费 IDEA 插件让你开发 Spring 程序更简单
Feign-Helper 是一款支持 Spring 框架的 IDEA 免费插件,提供 URL 快速搜索、Spring Web Controller 路径一键复制及 Feign 与 Controller 接口互相导航等功能,极大提升了开发效率。
|
3月前
|
前端开发 JavaScript Java
如何使用 Spring Boot 和 Angular 开发全栈应用程序:全面指南
如何使用 Spring Boot 和 Angular 开发全栈应用程序:全面指南
65 1
|
2月前
|
XML Java 数据格式
Spring Boot 开发中的常见失误
本文深入分析了Spring Boot开发中常见的失误,包括不当使用@Component、@ResponseBody、@Autowired注解,以及不良的异常处理和日志记录实践,提供了有效的规避策略,帮助开发者提升代码质量和系统性能。
|
3月前
|
存储 运维 安全
Spring运维之boot项目多环境(yaml 多文件 proerties)及分组管理与开发控制
通过以上措施,可以保证Spring Boot项目的配置管理在专业水准上,并且易于维护和管理,符合搜索引擎收录标准。
69 2