当前位置:首页 > 全部子站 > IT > 思科认证

Java与.NET的基于WS-Security的WebServices集成实现(下)

来源:长理培训发布时间:2017-12-22 09:34:56

 百度广告

4. 打开Jbuilder9 ,新建一个Java 类,命名为TestNetService。并将axis-wsse-1.0的jar包添加到Jbuilder的jdk中(Tools->configions jdks->class tab->add)代码 

  package MyWebServiceJavaClient; 

import Java.util.Date; 

import Java.text.DateFormat; 

import org.apache.axis.MessageContext; 

import org.apache.axis.message.*; 

import org.apache.axis.client.*; 

import org.apache.axis.utils.*; 

import Javax.XML.namespace.QName; 

import Java.lang.Integer; 

import Javax.XML.rpc.ParameterMode; 

import net.vitale.filippo.axis.handlers.WsseClientHandler; 

/** 

Title: 

 

Description: 

 

Copyright: Copyright (c) 2004

 

Company: 

 

* @author not attributable 

* @version 1.0 

*/ 

public class TestNetService { 

 static String usernameS = null; 

 static String passwordS = null; 

 public TestNetService() { 

  } 

  public static void main(String args) { 

   try { 

   Integer i = new Integer(2); 

   Integer j = new Integer(2); 

   String endpoint="http://localhost/MyServices/WebServiceTest/SumService.asmx"; 

   Service service = new Service(); 

   Call call = (Call)service.createCall(); 

   call.setTargetEndpointAddress(new Java.net.URL(endpoint)); 

   call.setOperationName(new QName("http://www.contoso.com/SU","IntAdd")); 

   call.addParameter("a",org.apache.axis.encoding.XMLType.XSD_DATE,Javax.XML.rpc.ParameterMode.IN); 

   call.addParameter("b",org.apache.axis.encoding.XMLType.XSD_DATE,Javax.XML.rpc.ParameterMode.IN); 

   call.setReturnType(org.apache.axis.encoding.XMLType.XSD_INT); 

   call.setUseSOAPAction(true); 

   call.setSOAPActionURI("http://www.contoso.com/Rpc"); 

|||

   //add a user token 

   usernameS ="username"; 

   passwordS = "love"; 

   call.setUsername(usernameS); 

   call.setPassword(passwordS); 

   call.setProperty(WsseClientHandler.PASSWORD_OPTION, WsseClientHandler.PASSWORD_DIGEST_WITH_NONCE); 

   call.setClientHandlers(new WsseClientHandler(), null);  

   Integer k = (Integer)call.invoke(new Object{i,j});  

   System.out.println( "result is " + k.toString() + "."); 

  

   } 

   catch (org.apache.axis.AxisFault e) 

   {  


    System.err.println("The usernameToken and password aren't right! "); 

   else { 

      System.err.println(e.getFaultCode().toString()); 

   } 

   } 

   catch(Exception e) 

   { 

   System.err.println(e.toString()) ; 

   } 

  } 

5. 编译并运行这个Java程序,执行结果 

  The username and password aren't right! 

  可以看到,在Web Services中的PasswordProvider类中,GetPassWord()方法是用来返回相应的密码。在上面的示例中,由于username="usename",因此GetPassWord返回"password",而java传递过来的密码是"love",因此两者不符合。系统会抛出异常,我们在Java中进行捕获,并显示自己的提示信息。 

6. 修改部分Java代码并运行 

将passwordS = "love";替换成passwordS = "password";重新编译运行,结果 

result is 4. 

这样,可以看到Java客户端发送的用户名和密码在Web Services得到了认证,并执行了IntAdd方法,返回正确的计算结果。至此,一个简单的基于WS-Security的Java 客户端与.Net Web Services的互连就基本实现了。 

四:可扩展的地方 

1. Java端的用户名,密码是可以从UI界面上得到。 

2. Java端的密码传输方式用三种,可以自由选择。 

3. Web Service端的密码可以从数据库,AD,文件等处获得。 

4. Web Service端的验证错误后的异常信息可以自己制定。 

5. 可以使用X.509作为证书,添加第三方数字签名认证(目前asix-wsse1.0没有实现) 

6. 有兴趣的朋友可以看看axis-wsse-1.0的源代码,很简单,就一个文件,不过我看起来很费劲,因为调用了很多axis里面的东西,那个我也不熟悉,所以就看不明白,呵呵。 


1.X.509是包含在WS-Security中的,但是目前没有基于Java的开源实现。IBM的WebSphere有相应的实现。 

2.我个人认为这也是基于Web Services的不同平台间相互调用的一个大的问题就是异常的处理。目前我个人觉得好的方法是纪录到日志中。如果想捕获不同系统提供的异常信息的确是一个困难的事情,不知道谁还有好的方法。我发现在网上介绍Web Services的文章书籍中很少有介绍这方面的东西,也许大家都不熟悉也就不敢乱写了(出了我之外)。

责编:罗莉

发表评论(共0条评论)
请自觉遵守互联网相关政策法规,评论内容只代表网友观点,发表审核后显示!

国家电网校园招聘考试直播课程通关班

  • 讲师:刘萍萍 / 谢楠
  • 课时:160h
  • 价格 4580

特色双名师解密新课程高频考点,送国家电网教材讲义,助力一次通关

配套通关班送国网在线题库一套

课程专业名称
讲师
课时
查看课程

国家电网招聘考试录播视频课程

  • 讲师:崔莹莹 / 刘萍萍
  • 课时:180h
  • 价格 3580

特色解密新课程高频考点,免费学习,助力一次通关

配套全套国网视频课程免费学习

课程专业名称
讲师
课时
查看课程
在线题库
面授课程更多>>
图书商城更多>>
在线报名
  • 报考专业:
    *(必填)
  • 姓名:
    *(必填)
  • 手机号码:
    *(必填)
返回顶部