.net C# 调用 XFire发布的Webservice 安全访问控制

     最近接触到的项目要使用.net调用xfire发布webservice,在网上找了很多方法,遇到一些“牛人”粘贴了千篇一律的代码,看着头痛,但实际的问题并没有解决,在一次调试过程中发现服务端的安全处理Handler是有状态的,于是想了个办法让服务器端保存客户端调用的认证信息,认证一次后并不再需要对身份进行多次认证

 

这里和大家分享一下具体的代码
关于使用Xfire开发Webservice大家可以去网上搜搜,都写的很好,图文并茂,

我在这里强调的是跨平台的安全调用和状态保留,本文将阐述如何使用SOAP Header传递认证信息并且保存客户端的调用状态


这是.net 生成代理类的使用wsdl.exe工具 配置文档如下

服务器上我们添加验证方法

稍微解释下此段代码
当web服务器启动的时候,比如tomcat启动的时候,该类将被实列化,生命周期直到tomcat关闭的时候结束

 

服务器services.xml

配置如下


.net客户端调用的时候添加一个类

然后再生成的代理类里面添加

在生成的代理类的调用方法上再添加如下代码

 

在调用该方法时候,验证信息将被加入soap header

 

调用采用

 



 纠正一点,其实Java与C#通过Webservice通信的安全控制还是可以用session来控制的,只是客户端需要保存一cookie,C#提供了一个cookieContainer来为我们保存Session


 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 15
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值