WCF服务保护正确实现步骤浅析

开发 开发工具
WCF服务保护的实现,可以帮助我们打造一个安全性极强的解决方案。在这里我们将会分为两步来详细介绍其中的操作步骤。

作为一个合格的开发人员,在编写程序的同时,首要考虑的就是程序的安全问题。那么今天我们将会为大家详细讲解一下WCF服务保护的实现方法,希望能够帮助大家从中对这方面的安全知识有一个详细了解。#t#

通过说到安全,我们会想到认证和授权,要求登录的系统都提供了认证和授权的安全性。

WCF程序有更多的安全问题,因为消息需要跨越机器边界传递,对消息进行加密是一方面,带签名是另一种方式。通常WCF包括传输通道和消息级别的安全性。如https就是具有更高安全性的传输专用通道,消息级别包括加密和解密等。下面分别来介绍一下

一、消息级别的WCF服务保护

示例:NetTcpBinding绑定的消息加密。宿主程序和客户端的配置文件中分别增加

  1. < system.serviceModel> 
  2. ...  
  3. < bindings> 
  4. < netTcpBinding> 
  5. < binding name="tcpBindingConfig"> 
  6. < security mode="Message"> 
  7. < message algorithmSuite="Basic128" /> 
  8. < /security> 
  9. < /binding> 
  10. < /netTcpBinding> 
  11. < /bindings> 
  12. ...  
  13. < /system.serviceModel> 

然后修改binding=netTcpBinding的endpoint指定bindingConfiguration属性=tcpBindingConfig,这样这种绑定的消息会自动进行加密和解密。下载的示例demo中启用了trace输出,这样可以通过service trace viewer工具查看D:\winform\WCF step by step\Chapter 5\Shore.cnblogs.com.WCFHost\app_tracelog.svclog(这个地址在你本机可能需要修改)这个文件来观察消息是否真正的被加密了。

基本BasicHttpBinding绑定的消息加密需要证书,比较麻烦,但WSHttpBinding绑定的消息加密默认就会有消息加密功能,所以只要提供一个WSHttpBinding的endpoint就OK。

二、在传输通道级别保护一个HTTP服务

我提到过,传输通道的保护可以配置为https来增强保护,由于启用https需要证书文件,比较麻烦。暂时不演示了,后面有时间再补充吧。

三、认证与授权

认证和授权是基本form验证的一种有效方式,也是在web程序中用的最多的一种验证方式。WCF对认证和授权有了很好的支持,这个主题也很广泛,这里只是简单演示服务器端怎么样拿到客户端的windows用户名。

netTcpBinding绑定

string usrName = Thread.CurrentPrincipal.Identity.Name;

这样WCF服务保护的操作就完成了。

责任编辑:曹凯 来源: 博客园
相关推荐

2010-02-25 16:52:12

引用WCF服务

2010-02-25 10:10:29

WCF使用Header

2010-02-24 10:07:48

WCF跨越边界

2010-02-26 08:59:10

WCF服务宿主程序

2010-02-24 13:48:44

MSMQ使用WCF

2010-02-26 11:22:16

LitwareHR使用

2009-12-21 10:09:26

WCF创建客户端服务对

2010-02-25 13:48:23

WCF动态创建代码

2010-02-25 09:13:34

WCF异步调用

2010-02-26 10:30:03

ASP.NET Aja

2010-03-02 09:39:11

保护WCF服务

2010-07-28 10:28:47

DB2数据移动

2010-02-26 09:33:18

WCF创建WebSer

2010-02-22 10:52:34

PDA访问WCF

2010-02-25 13:35:27

WCF tcpTrac

2010-03-04 15:12:33

Python算法

2009-12-29 18:09:00

Silverlight

2010-03-04 11:12:02

Python AOP

2009-12-03 11:11:57

PHP网站优化

2010-02-22 14:28:35

WCF实现loadin
点赞
收藏

51CTO技术栈公众号