WCF分布式安全开发实践(4):传输安全模式之Windows身份验证:Transport_Windows_NetTcpBinding

简介:
  本节介绍的内容主要是:主要是传输安全模式的Windows身份验证方式,基于NetTcpBinding绑定协议的实现过程。
    为什么此安全方式不需要配置证书,他与自定义验证方式的Windows验证有什么不同?本文都会介绍。以下是本节主要内容:Windows身份验证基本概念,然后WCF传输安全模式之Windows身份验证、服务端配置、客户端配置、总结。
     此节内容因为是在 WCF分布式安全开发实践(2):传输安全模式之基本身份验证(Windows账户密码):Transport_Basic_WSHttpBinding 。我们在传输安全模式下页提供了提供了用户自定义对客户端凭据的验证代码。与消息安全不同的是,这里我们要借助SSL来保证数据交互的安全。首先我们来介绍一下什么是传输安全模式的自定义UserNamePassword。
【1】Windows域验证:
    我们这里先介绍Windows验证的基础概念。 Kerberos V5和域控制器Kerberos V5服务安装在每个域控制器上,而Kerberos V5客户机则安装在每个Windows Server 2003工作站和服务器上。
Windows Server 2003系统使用域名服务(DNS)查询定位最近的可用域控制器。该域控制器则会在用户登录期间对该用户起首选KDC的作用。如果首选KDC失效,则Windows 2003 Server系统将确定由另一个KDC提供验证。
   Kerberos V5验证过程是按以下步骤工作的:
(1) 客户机中的用户,使用口令或智能卡向KDC(Key Distribution Center)发出验证请求。
(2) KDC向客户机发出一个特别的授权票证(Ticket Granting Ticket,简称TGT)。客户机系统使用该TGT访问售票服务(Ticket Granting Service,简称TGS),它是域控制器中Kerberos V5验证机制的一部分。
(3) 然后,TGS向客户机发布一个服务票证(Service Ticket),客户机使用服务票证来请求网络服务。服务票证用来证明服务和用户的身份。
【2】传输安全模式之Windows身份验证:
       传输安全模式之Windows身份验证需要服务器不需要一个服务器提供有效的可用于安全套接字层 (SSL) 的 X.509 证书。 这里使用Tcp协议来保证数据传输安全。客户端提供有效的Windows 用户名和密码。验证有域服务器完成。
1.身份验证(服务器):不需要提供证书,Windows集成身份验证 
2.身份验证(客户端):Windows集成身份验证 
3.绑定协议:TCP
   WCF传输安全模式身之Windows身份份验证的架构如下:
【3】服务端配置:
    我们就要对WCF服务端进行配置,直接使用配置文件,这里简单。也可以使用代码来完成。
    (1)服务类定义:
     这里服务类就一个方法就是更具用户的name来打印调用时间,代码如下:
 //1.服务契约
    [ServiceContract(Namespace = "http://www.cnblogs.com/frank_xl/" )]
    
public interface
 IWCFService
    {
        
//操作契约

        [OperationContract]
        
string SayHello(string
 name);

    }
    
//2.服务类,继承接口。实现服务契约定义的操作

    public class  WCFService : IWCFService
    {
        
//实现接口定义的方法

        public string SayHello(string  name)
        {
            Console.WriteLine(
"Hello! {0},Calling at {1} "
, name,DateTime.Now.ToLongTimeString());
            
return "Hello! " +
 name;
        }
    }
    (2)传输安全模式配置:
       使用传输安全模式,采用客户端Windows身份验证策略,transport安全模式下,netTcpBinding绑定默认使用的Windows方式,而且启用签名和加密特性。配置信息如下:
       < netTcpBinding >
      
< binding name = " BindingConfigration " >
        
< security mode = " Transport " >
          
< transport clientCredentialType = " Windows "   />
        
</ security >
      
</ binding >
    
</ netTcpBinding >
   这个这里不适用配置也会生效,等价于以下设置
       < netTcpBinding >
      
< binding name = " BindingConfigration " >
        
< security mode = " Transport " >
          
< transport clientCredentialType = " Windows "   protectionLevel = " EncryptAndSign " />
        
</ security >
      
</ binding >
    
</ netTcpBinding >
    基于netTcpBinding来实现传输安全模式下的Windows身份验证好处就在这里,可以直接使用其提供的加密和签名功能。
  【4】客户端配置:
    这个过程和之前的传输安全模式下,添加服务的过程一样。直接引用。
    (1)引用元数据:
    因为服务的元数据交换节点启用了TCP协议,我们在客户端项目添加元数据地址net.tcp ://localhost:9003/mex查找服务信息,如图:
   这个证明我们的服务端证书设置已经起作用,而且是可信的。现在我们点击Yes。继续就会添加完毕服务引用。过程和普通的添加服务元数据引用一样,会产生客户端相关代码文件。输入NameSpace,等待完成即可。   
    (2)配置文件:
    客户端配置文件使用默认设置,主要是安全模式的设置要如下,与服务端匹配。使用Basic方式。这样我们才能提供自定义用户名和密码。
    (3)测试代码:
    等待代码生成结束,我们这里就直接生成客户端代理类的实例来调用服务进行测试。这里客户端在调用服务以前,通道客户端服务代理类的ClientCredentials.Windows.ClientCredentia属性设置Windows用户名和密码。如下:
             /// /HTTP WSHttpBinding_IWCFService1
            WCFClient.ClientProxy.WCFServiceClient wcfServiceProxy  =   new  WCFClient.ClientProxy.WCFServiceClient( " NetTcpBinding_IWCFService " );
            
// 通过代理调用SayHello服务
             string  sName  =   " Frank Xu Lei Transport Windows NetTcpBinding " ;
            
string  sResult  =   string .Empty;
            
// 设置Windows域账号密码
            wcfServiceProxy.ClientCredentials.Windows.ClientCredential.UserName  =   " FrankXuLei " ;
            wcfServiceProxy.ClientCredentials.Windows.ClientCredential.Password 
=   " 12345678 " ;
            wcfServiceProxy.ClientCredentials.Windows.ClientCredential.Domain 
=   " mydomain " ;
            sResult 
=  wcfServiceProxy.SayHello(sName);
            Console.WriteLine(
" Returned Result is {0} " , sResult);
            
// For Debug
            Console.WriteLine( " Press any key to exit " );
            Console.Read();
  也可以通过代码设置:
ChannelFactory<IMySecureService> factory = new ChannelFactory<IMySecureService>( );
// Transport 安全模式之Windows身份验证
factory.Credentials.Windows.ClientCredential = new
NetworkCredential("FrankXuLei", "12345678", "mydomain");
(4)测试结果:
    启动宿主程序,然后启动客户端程序。宿主打印的消息,当我们Windows用户名和密码的时候,客户端成功调用服务,如图:
【5】总结
     Windows Communication Foundation (WCF) 服务和客户端。服务器不需要 X.509 证书,
   (1) 此处自是在借助传输安全Windows集成身份验证,需要Windows域服务器支持。
   (2)此方式该应用程序部署在具有 Kerberos 控制器保护的域中。
   (3)Windows 集成身份验证,负责提供的是身份验证。而安全由TCP传输来实现,我可以再传输安全配置里设置,启用特定的保护级别。
   (4)transport 在NetTcpBinding绑定下,默认客户端身份验证使用Windows身份验证。 默认的保护级别是加密并且签名EncryptAndSign。
   (5)给出今天的参考代码,供大家参考:/Files/frank_xl/3.3.WCFServiceSecurityDemoFrankXuLei_Transport_Windows_NetTcpBinding.rar

参考文章:
1.WCF分布式安全开发实践(2):传输安全模式之基本身份验证(Windows账户密码):Transport_Basic_WSHttpBinding 
2.http://www.jojy.cn/bbs/thread-1474-1-1.html
3.http://gnaw0725.blogbus.com/logs/18971316.html


 本文转自 frankxulei 51CTO博客,原文链接:http://blog.51cto.com/frankxulei/320357,如需转载请自行联系原作者





相关文章
|
监控 关系型数据库 MySQL
PowerShell 脚本编写 :自动化Windows 开发工作流程
PowerShell 脚本编写 :自动化Windows 开发工作流程
850 0
|
Ubuntu Linux Python
如何利用wsl-Ubuntu里conda用来给Windows的PyCharm开发
如何在WSL(Windows Subsystem for Linux)的Ubuntu环境中使用conda虚拟环境来为Windows上的PyCharm开发设置Python解释器。
2889 1
|
存储 安全 程序员
Windows任务管理器开发原理与实现
Windows任务管理器开发原理与实现
|
开发者 C# Windows
WPF与游戏开发:当桌面应用遇见游戏梦想——利用Windows Presentation Foundation打造属于你的2D游戏世界,从环境搭建到代码实践全面解析新兴开发路径
【8月更文挑战第31天】随着游戏开发技术的进步,WPF作为.NET Framework的一部分,凭借其图形渲染能力和灵活的UI设计,成为桌面游戏开发的新选择。本文通过技术综述和示例代码,介绍如何利用WPF进行游戏开发。首先确保安装最新版Visual Studio并创建WPF项目。接着,通过XAML设计游戏界面,并在C#中实现游戏逻辑,如玩家控制和障碍物碰撞检测。示例展示了创建基本2D游戏的过程,包括角色移动和碰撞处理。通过本文,WPF开发者可更好地理解并应用游戏开发技术,创造吸引人的桌面游戏。
1099 0
|
开发者 iOS开发 C#
Uno Platform 入门超详细指南:从零开始教你打造兼容 Web、Windows、iOS 和 Android 的跨平台应用,轻松掌握 XAML 与 C# 开发技巧,快速上手示例代码助你迈出第一步
【8月更文挑战第31天】Uno Platform 是一个基于 Microsoft .NET 的开源框架,支持使用 C# 和 XAML 构建跨平台应用,适用于 Web(WebAssembly)、Windows、Linux、macOS、iOS 和 Android。它允许开发者共享几乎全部的业务逻辑和 UI 代码,同时保持原生性能。选择 Uno Platform 可以统一开发体验,减少代码重复,降低开发成本。安装时需先配置好 Visual Studio 或 Visual Studio for Mac,并通过 NuGet 或官网下载工具包。
2055 0
|
Linux Apache C++
FFmpeg开发笔记(三十五)Windows环境给FFmpeg集成libsrt
该文介绍了如何在Windows环境下为FFmpeg集成SRT协议支持库libsrt。首先,需要安装Perl和Nasm,然后编译OpenSSL。接着,下载libsrt源码并使用CMake配置,生成VS工程并编译生成srt.dll和srt.lib。最后,将编译出的库文件和头文件按照特定目录结构放置,并更新环境变量,重新配置启用libsrt的FFmpeg并进行编译安装。该过程有助于优化直播推流的性能,减少卡顿问题。
715 2
FFmpeg开发笔记(三十五)Windows环境给FFmpeg集成libsrt
|
Java Nacos 微服务
Spring Cloud微服务在Windows本地开发时禁用Nacos注册中心注册
Spring Cloud微服务在Windows本地开发时禁用Nacos注册中心注册
|
C# 数据安全/隐私保护
c#如何创建WCF服务到发布(SqlServer版已经验证)
c#如何创建WCF服务到发布(SqlServer版已经验证)
217 0
|
安全 数据库连接 数据库
WCF服务创建到发布(SqlServer版)
在本示例开始之前,让我们先来了解一下什么是wcf? wcf有哪些特点? wcf是一个面向服务编程的综合分层架构。该架构的项层为服务模型层。 使用户用最少的时间和精力建立自己的软件产品和外界通信的模型。它使得开发者能够建立一个跨平台的安全、可信赖、事务性的解决方案。且能与已有系统兼容写作。 简单概括就是:一组数据通信的应用程序开发接口。
395 0
|
前端开发
WCF更新服务引用报错的原因之一
WCF更新服务引用报错的原因之一

热门文章

最新文章