• 使用Impersonation仿冒用户运行WCF 服务方法


     默认情况下,当我们把wcf服务器部署在IIS上时, 我们访问wcf时使用的是IIS内建的内建角色,对于IIS8.0,它被命名为ApplicationPoolIdentity, 一般来说,系统为每个应用程序池设定一个用户, 以下图为例,IIS中有个应用程序池MailSender, 使用任务管理器可以看到用户MailSender运行了一个IIS w3wp进程,这个用户在系统中并不是实际存在的,如果你需要分配文件夹权限给这个用户,需要使用的实际用户名为IIS AppPoolMailSender.

    但出于安全策略考虑,有时我们不希望分配权限给这个内建用户,而是希望以一个特定的用户来调用WCF服务。比如我们创建一个特定用户只限于访问sql server, 我们该怎么做呢?

    本篇 所述的示例,适用于如下场景:

    若需要仿冒服务器端用户,取得服务器端某用户的权限,需要完成如下步骤:

    一、开发WCF Service ,并在WCF服务实现类的相应方法的上标注如下OperationBehavior属性。

    [OperationBehavior(Impersonation = ImpersonationOption.Required)]

    二、部署WCF 服务到IIS ,配置授权方法为Windows验证. 参考下图中的配置

    三、生成客户端代理,并且设置客户端凭证为要仿冒的凭证,参考如下代码(当然,你也可以在IIS 中直接指定固定的运行用户,方法是,在IIS中允许Asp.net Impersonation,在右键菜单中点击编辑à选择特定用户à设置…)

  • 相关阅读:
    架构漫谈阅读笔记(1)
    第一周学习进度
    2月13号寒假总结
    2月12日寒假总结
    2月11日寒假总结
    2月10日寒假总结
    寒假学习进度笔记一
    mapreduce课上实验
    个人课程总结
    用户体验评价
  • 原文地址:https://www.cnblogs.com/Hcsdn/p/3248129.html
Copyright © 2020-2023  润新知