ASP.Net WCF服务的Thread.CurrentPrincipal被联邦(WIF)环境中的
我有一个每次调用的WCF服务,它在IIS(.svc)中托管.在服务的构造函数中,我按照
this article设置了Thread.CurrentPrincipal = HttpContext.Current.User.在这种情况下,HttpContext.Current.User的类型为Microsoft.IdentityModel.Claims.ClaimsPrincipal,并具有从我的自定义被动方式发回的声明STS.
但是,只要我进入我的服务操作并检查Thread.CurrentPrincipal,当此对象仍然是Microsoft.IdentityModel.Claims.ClaimsIdentity类型时,该对象本身不再与HttpContext.Current.User相同(IsAuthenticated = false),AuthenticationType =“”,并且Thread.CurrentPrincipal.Identity上的Name为null,而这些值仍然在HttpContext.Current.User上正确填充.这告诉我有些东西拦截了对操作的调用,并错误地将当前主体更改为一些通用的,空的,未经身份验证的声明主体. 我在构造函数和操作中检查了线程ID,并且它在两个地方都是相同的,并且在从HttpContext.Current.User分配后在立即窗口中评估Thread.CurrentPrincipal显示正在正确设置线程标识.构造函数,所以在构造函数和方法之间肯定会执行某些操作,并且有些东西正在改变我的Thread.CurrentPrincipal. 有没有人知道这是做什么的,以及如何防止/解决这种行为? 解决方法
我刚遇到类似的问题.我在我的WCF服务的构造函数中设置我的自定义主体.当我离开构造函数并进入我调用的方法时,thread.currentprincipal被一个空的覆盖.我通过添加以下行为解决了这个问题:
<serviceAuthorization principalPermissionMode="None"></serviceAuthorization> 这对我来说很好. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- ASP.Net Web API架构选择
- asp.net-mvc-4 – 禁止从地址栏调用操作方法
- asp.net-mvc – ASP.NET MVC区域可以显示自己的错误页面集吗
- asp.net – 使用XML Schema和OpenXML SDK进行WordML模板化
- asp.net-mvc – 如何在C#中为MVC创建值为“00”和“”的自己
- asp.net – 如何将div的ClientID插入OnClientClick事件
- asp.net-mvc – ASP.NET身份与简单的会员优点和缺点?
- asp.net – 实体框架CTP5,代码优先.可选的导航属性
- asp.net – 我今天应该使用什么DOCTYPE?
- asp.net – 改进MonoRail
- asp.net-web-api – 使用swashbuckle api文档的h
- asp.net-mvc – Upshot.js的当前状态
- 用AJAX实现的无刷新的分页实现代码(asp.net)
- asp.net – 是否可以解密和查看ViewState值?
- asp.net-mvc – 是否有PRG模式的名称,在验证失败
- asp.net-mvc – Durandal和ASP.NET MVC约定
- asp.net-mvc-3 – 在ASP.NET MVC 3中使用不显眼的
- ASP.NET缓存管理的几种方法
- asp.net-mvc – 如何创建特定于区域,控制器和操作
- asp.net – 为不同项目中的所有Web应用程序网页添