Web Services Enhancements 3.0 Quick Start(一)

Web Services Enhancements 3.0 Quick Start(一)

Web Services Enhancement的目的
      1、基于基本的Web Services
      2、满足企业级应用的需求Secure、reliable and transacted Web services
      3、保留Web Services得以成功的优点 Interoperability Ability to be implemented Add no more complexity than needed
这篇主要介绍WSE通过安全证书(Policy File)构建安全Web Service
     一、先定义安全证书(Policy File) 
     二、使用专有的Web service安全证书特性
具体步骤
     1、在vs2005中开一个Web Service项目
     2、运行WSE Settings 3.0 Tool
     3、通过WSE Settings 3.0 Tool打开Web Service项目的web.config
     4、选中Enable this project for web Service Enhancements

        5、选择Policy并Add,填写你证书的名字,我现在是使用ServicePolicy名称然后下一步
        6、然后的的向导界面就要重点讲述下在第一个选择项是标注你选择的服务还是客户,在第二个选择项中有四个选项


选项说明
Anonymous匿名访问
Username需要包含用户名和密码的Usernametoken的安全令牌
Certificate需要发送含有X509SecurityToken的安全令牌的X.509证书
Windows需要发送含有KerberosToken的windows身份认证
    7、选择SOAP头的类型


选项说明
NoneSOAP消息应当在传输层(SSL协议)提供保护,WSE在传输层(SSL协议)不提供保护。
Sign-OnlySOAP消息必须签名
Sign and Encrypt SOAP消息必须签名和SOAP消息体加密
Sign, Encrypt, Encrypt Signature SOAP消息必须签名、消息体签名加密
8、完成
就能根据您的配置生成以下配置文件
< policies >
  
< extensions >
    
< extension name = " kerberosSecurity "
               type
= " Microsoft.Web.Services3.Design.KerberosAssertion, Microsoft.Web.Services3, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35 "   />
    
< extension name = " kerberos "
               type
= " Microsoft.Web.Services3.Design.KerberosTokenProvider, Microsoft.Web.Services3, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35 "   />
    
< extension name = " requireActionHeader "
               type
= " Microsoft.Web.Services3.Design.RequireActionHeaderAssertion, Microsoft.Web.Services3, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35 "   />
  
</ extensions >
  
< policy name = " ServicePolicy " >
    
< kerberosSecurity establishSecurityContext = " false "  signatureConfirmation = " false "  protectionOrder = " SignBeforeEncrypting "  deriveKeys = " false " >
      
< protection >
        
< request signatureOptions = " IncludeAddressing, IncludeTimestamp, IncludeSoapBody "  
                 encryptBody
= " true "   />
        
< response signatureOptions = " IncludeAddressing, IncludeTimestamp, IncludeSoapBody "  
                 encryptBody
= " true "   />
        
< fault signatureOptions = " IncludeAddressing, IncludeTimestamp, IncludeSoapBody "  
                 encryptBody
= " false "   />
      
</ protection >
    
</ kerberosSecurity >
    
< requireActionHeader  />
  
</ policy >
</ policies >
9、应用在Web Service
using  System;
using  System.Web;
using  System.Web.Services;
using  System.Web.Services.Protocols;
using  Microsoft.Web.Services3;
using  Microsoft.Web.Services3.Design;

[WebService(Namespace 
=   " http://www.contoso.com/ " )]
[WebServiceBinding(ConformsTo 
=  WsiProfiles.BasicProfile1_1)]
[Policy(
" ServicePolicy " )] 
public   class  Service : System.Web.Services.WebService
{
    
public Service () {

    }


    [WebMethod]
    
public string SayHello() {
        
return "Hello World";
    }

    
}
小结
现在主要是建立服务器端的Policy File,以及使用,下次就介绍关于客户端建立Policy File以及使用  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值