Spring整合axis2

目录

服务端搭建:

第一步:创建maven工程

第二步:完成axis2相关配置

添加axis2的jar包

配置services.xml

配置applicationContext.xml

配置web.xml

第三步:写个服务类

第四步:Tomcat启动工程

客户端测试:


服务端搭建:

第一步:创建maven工程

需要对pom.xml配置spring的相关依赖。对web.xml进行进行简单的配置ok。

这篇文章主要讲axis2的配置,所以就不会详细说这些。

第二步:完成axis2相关配置

  • 添加axis2的jar包

    首先要在官网下载axis2 
    官网:http://axis.apache.org/axis2/java/core/download.cgi
    Spring整合axis2_第1张图片
  • 配置services.xml

    services.xml的目录结构如下图所示:
    Spring整合axis2_第2张图片
    在services.xml中,我们要配置发布的webservice的服务。
  • 关于服务类的配置可以分全类名和指定Spring Bean ID的方式
    • 指定spring bean ID
      
        
      	测试axis2webservices
      
          userinfo
          
          	org.apache.axis2.extensions.spring.receivers.SpringServletContextObjectSupplier
          
      	
      		
      		
      	
      	
      
      

      指定spring bean ID 需要使用org.apache.axis2.extensions.spring.receivers.SpringServletContextObjectSupplier获取对应bean id的类路径。

    • 全类名
      
        
      	测试axis2webservices
      	
      	com.axis2.UserInfo
      	
      	
      		
      		
      	
      	
      
      

       

  • 关于发布的方法配置可以不指定发布方法或者指定发布方法。
    • 不指定发布的方法:
      
        
      
      	测试axis2webservices
      
      	userinfo
      	
      		org.apache.axis2.extensions.spring.receivers.SpringServletContextObjectSupplier
      	
      
      	
      		
      		
      	
      
      
      
    • 指定发布方法:
      
        
      	测试axis2webservices
      
      
      	userinfo
      	
      		org.apache.axis2.extensions.spring.receivers.SpringServletContextObjectSupplier
      	
      	
      	
      		
      	
      	
      		
      	
      	
      		
      	
      	
      		
      	
      	
      	
      
      
  • 配置applicationContext.xml

    
    
    	
    
    
    这里注入的bean就是你要发布的服务类。当services.xml使用了SpringBeanName才需要进行的配置。
  • 配置web.xml

    
    
    	Archetype Created Web Application
    	
            
          contextConfigLocation
          
          classpath:applicationContext.xml    
            
        
    	
            
            org.springframework.web.context.ContextLoaderListener    
         
    	
    	
    		AxisServlet
    		org.apache.axis2.transport.http.AxisServlet
    		2
    	
    	
    	
    		AxisServlet
    		/services/*
    	
    	
    
    

     

第三步:写个服务类

随便写,也不需要什么注解。注意是否与services.xml中的全类名,方法名对应。applicationContext.xml中是否注入。

package com.axis2;

public class UserInfo {
	public String getUserName() {
		return "zhangxu";
	}
	
	public String addUserHobby(String like) {
		return "add hobby "+like;
	}
	
	public void setUserScore(double score) {
		System.out.println(score);
	}
	
	public void print() {
		System.out.println("啥都没有");
	}
}

第四步:Tomcat启动工程

将工程放入Tomcat,启动。在浏览器中输入:

http://localhost:8080/SpringDemo/services/UserInfoService?wsdl

如果能显示xml报文,那么我们的webservice便成功发布了!!!

这里的命名规则是:http://【ip】:【端口】/【工程名】/services/【service名】?wsdl

 


客户端测试:

package com.axis2;

import javax.xml.namespace.QName;

import org.apache.axiom.om.OMElement;
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 Test {
	public static void main(String[] args) {
        try {
            String url = "http://localhost:8080/SpringDemo/services/UserInfoService?wsdl";
            EndpointReference endpointReference = new EndpointReference(url);  
            RPCServiceClient client = new RPCServiceClient();  
            client.setTargetEPR(endpointReference );
            Options options = client.getOptions();
            options.setTo(endpointReference);  

            QName qname = new QName("http://axis2.com", "getUserName"); 
            Object[] param = new Object[]{};   //输入参数比如:"aaa",没有输入,就不写。
            Class[] types = new Class[]{String.class};  //需要返回类型就是*.class 

            Object[] obj = client.invokeBlocking(qname, param, types);  
            System.out.println(obj[0]);
        } catch (AxisFault e) {
            e.printStackTrace();
        }
	}
}

这里需要注意两个地方:

String url = "http://localhost:8080/SpringDemo/services/UserInfoService?wsdl";这个就是我们之前输入,并访问到xml的那个地址。

QName中的第一个参数是xs:schema标签的targetNamespace="http://axis2.com",第二个参数对应下面的xs:element 的name,也就是我们发布的方法。

Spring整合axis2_第3张图片

当控制台成功打印,便测试成功。

参考:

Services.xml的讲解 哈根达斯、 http://yangyangcom.iteye.com/blog/2233557

WebService - Axis2与Spring整合并发布多个service(同样使用services.xml) https://blog.csdn.net/J080624/article/details/78444986

官方文档 http://axis.apache.org/axis2/java/core/docs/spring.html

两种服务的发布方式 https://blog.csdn.net/chjttony/article/details/6211478

 

 

你可能感兴趣的:(axis2,WebService)