WebService:Axis客户端调用需要身份验证的CXF服务

CXF服务端代码:

1、web.xml配置

 

Xml代码   收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.     xsi:schemaLocation="http://java.sun.com/xml/ns/javaee   
  5.     http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">  
  6.     <!-- Spring Config Location -->  
  7.     <context-param>  
  8.         <param-name>contextConfigLocation</param-name>  
  9.         <param-value>/WEB-INF/beans.xml</param-value>  
  10.     </context-param>  
  11.     <!-- Spring ContextLoaderListener -->  
  12.     <listener>  
  13.         <listener-class>  
  14.             org.springframework.web.context.ContextLoaderListener  
  15.         </listener-class>  
  16.     </listener>  
  17.     <!-- Apache CXFServlet -->  
  18.     <servlet>  
  19.         <servlet-name>CXFServlet</servlet-name>  
  20.         <servlet-class>  
  21.             org.apache.cxf.transport.servlet.CXFServlet  
  22.         </servlet-class>  
  23.         <load-on-startup>1</load-on-startup>  
  24.     </servlet>  
  25.     <!-- CXFServlet Mapping -->  
  26.     <servlet-mapping>  
  27.         <servlet-name>CXFServlet</servlet-name>  
  28.         <url-pattern>/service/*</url-pattern>  
  29.     </servlet-mapping>  
  30. </web-app>  

 

 2、beans.xml配置, 在beans.xml中配置服务端的拦截器interceptor.AuthenticationInterceptor,拦截器需要

继承AbstractPhaseInterceptor

 

Xml代码   收藏代码
  1. <beans xmlns="http://www.springframework.org/schema/beans"  
  2.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  3.     xmlns:jaxws="http://cxf.apache.org/jaxws"  
  4.     xsi:schemaLocation="  
  5.         http://www.springframework.org/schema/beans   
  6.         http://www.springframework.org/schema/beans/spring-beans-2.0.xsd  
  7.         http://cxf.apache.org/jaxws   
  8.         http://cxf.apache.org/schemas/jaxws.xsd">  
  9.     <!-- Import Apache CXF Bean Definition -->  
  10.     <import resource="classpath:META-INF/cxf/cxf.xml" />  
  11.     <import resource="classpath:META-INF/cxf/cxf-extension-soap.xml" />  
  12.     <import resource="classpath:META-INF/cxf/cxf-servlet.xml" />  
  13.               
  14.     <!-- serviceClass指定接口 -->  
  15.     <jaxws:server id="hello"  
  16.                   serviceClass="service.SampleWebService"   
  17.                   address="/HelloWorld">  
  18.         <jaxws:serviceBean>  
  19.             <bean class="service.SampleWebService" />  
  20.         </jaxws:serviceBean>  
  21.                           
  22.         <jaxws:inInterceptors>    
  23.             <bean class="interceptor.AuthenticationInterceptor">  
  24.                 <property name="username" value="admin" />  
  25.                 <property name="password" value="admin" />  
  26.             </bean>  
  27.         </jaxws:inInterceptors>         
  28.           
  29.     </jaxws:server>  
  30.   
  31. </beans>  

3、在拦截器中对用户身份进行验证

 

Java代码   收藏代码
  1. package interceptor;  
  2.   
  3. import java.util.List;  
  4.   
  5. import javax.xml.soap.SOAPException;  
  6.   
  7. import org.apache.cxf.binding.soap.SoapMessage;  
  8. import org.apache.cxf.headers.Header;  
  9. import org.apache.cxf.interceptor.Fault;  
  10. import org.apache.cxf.phase.AbstractPhaseInterceptor;  
  11. import org.apache.cxf.phase.Phase;  
  12. import org.w3c.dom.Node;  
  13.   
  14. public class AuthenticationInterceptor extends AbstractPhaseInterceptor<SoapMessage> {  
  15.     private String username;  
  16.     private String password;  
  17.   
  18.     public AuthenticationInterceptor() {  
  19.         // 指定该拦截器在哪个阶段被激发  
  20.         super(Phase.PRE_INVOKE);  
  21.     }  
  22.   
  23.     public void handleMessage(SoapMessage msg) throws Fault {  
  24.         List<Header> headers = msg.getHeaders();  
  25.         if (null == headers || headers.size() < 1) {  
  26.             throw new Fault(new SOAPException("SOAPHeader格式错误"));  
  27.         }  
  28.         for (Header header : headers) {  
  29.             Node root = (Node) header.getObject();  
  30.             if("Authentication".equals(root.getNodeName())){  
  31.                 Node userNode = root.getFirstChild();  
  32.                 Node passwordNode = root.getLastChild();  
  33.                 if(userNode == null || passwordNode == null){  
  34.                     throw new Fault(new SOAPException("SOAPHeader需要包含Username和Password节点"));  
  35.                 }  
  36.                 if(!userNode.getNodeName().equals("Username") || !passwordNode.getNodeName().equals("Password")){  
  37.                     throw new Fault(new SOAPException("SOAPHeader需要包含Username和Password节点"));  
  38.                 }  
  39.                 if(username.equals(userNode.getTextContent()) && password.equals(passwordNode.getTextContent())){  
  40.                     System.out.println("认证通过");  
  41.                 }  
  42.                 else{  
  43.                     throw new Fault(new SOAPException("用户名或密码错误"));  
  44.                 }  
  45.             }  
  46.             else{  
  47.                 throw new Fault(new SOAPException("SOAPHeader需要包含Authentication节点"));  
  48.             }  
  49.         }  
  50.     }  
  51.   
  52.     public String getUsername() {  
  53.         return username;  
  54.     }  
  55.   
  56.     public void setUsername(String username) {  
  57.         this.username = username;  
  58.     }  
  59.   
  60.     public String getPassword() {  
  61.         return password;  
  62.     }  
  63.   
  64.     public void setPassword(String password) {  
  65.         this.password = password;  
  66.     }  
  67.   
  68. }  

4、服务接口,CXF可以直接发布JavaBean,只需要一个@WebService注解

 

Java代码   收藏代码
  1. package service;  
  2.   
  3. import javax.jws.WebService;  
  4. @WebService  
  5. public class SampleWebService{  
  6.   
  7.     public String sayHello(String name) {         
  8.         return "Hello, "+name;  
  9.     }  
  10.   
  11.     public String sayHi(String name) {    
  12.         return "Hi, "+name;  
  13.     }  
  14. }  

 5、Axis客户端:

 

Java代码   收藏代码
  1. /** 
  2.  * <soapenv:Header> 
  3.  *     <Authentication  
  4.  *              soapenv:actor="http://schemas.xmlsoap.org/soap/actor/next"  
  5.  *              soapenv:mustUnderstand="0"  
  6.  *              xmlns=""> 
  7.  *         <Username>admin</Username> 
  8.  *         <Password>admin</Password> 
  9.  *     </Authentication> 
  10.  * </soapenv:Header> 
  11.  * @param user 
  12.  * @param password 
  13.  */  
  14. public static void authentication(String user, String password){  
  15.     try {  
  16.         Call call = (Call)new Service().createCall();  
  17.         call.setTargetEndpointAddress("http://localhost:8080/ws/service/HelloWorld");  
  18.         String namespace = "";//命名空间  
  19.         SOAPHeaderElement header = new SOAPHeaderElement(namespace,"Authentication");  
  20.         header.setPrefix("");//前缀  
  21.         header.addChildElement("Username").addTextNode(user);    
  22.         header.addChildElement("Password").addTextNode(password);    
  23.         call.addHeader(header);    
  24.         Object obj = call.invoke("sayHi"new String[]{"sam"});  
  25.         System.out.println(obj);  
  26.     } catch (Exception e) {  
  27.         e.printStackTrace();  
  28.     }   
  29. }  

 在axis的jar包中还提供了一个tcp_moniter,可以用来拦截soap消息,便于debug。

可以使用java -Djava.ext.dirs=lib org.apache.axis.utils.tcpmon来启动,启动前要先将axis的jar包都放在lib目录下,然后在lib的同级目录中建一个bat脚本,脚本中写:java -Djava.ext.dirs=lib org.apache.axis.utils.tcpmon。

这样双击bat脚本就可以启动tcp_moniter了。

tcp_moniter界面:

 

cxf_server端和axis_client端的工程源码见附件。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值