快来拿分了,很简单的问题,MVC使用ActionFilterAttribute特性时怎样重新进行身份验证(FormsAuthentication).

idoiknow 2013-04-01 03:30:20
事情是这样的,我的服务端是MVC架构,每个Controller上面都有一个 [AuthorizeFilter] ,这样Action执行之前会先进入AuthorizeFilter中的OnActionExecuting方法进行过滤处理:
 public override void OnActionExecuting(ActionExecutingContext filterContext)
{
if (filterContext.HttpContext.User.Identity.IsAuthenticated)
{
//...自定义的一些权限判断
}
}

现在问题是,由于SWFUpload上传控件在Firefox浏览器中的一个bug,服务端获取不到".ASPXAUTH"这个Cookie信息, 导致服务端判断IsAuthenticated==false , 这样我的上传动作就被判定为身份验证失败,被挡在了外面。

想必是OnActionExecuting之前,FormsAuthentication有一个更早的验证动作把IsAuthenticated置为false了。

我现在用了一个办法可以把这个缺少的".ASPXAUTH"信息给传到服务端,页面初始化上传控件时,把那个缺失Cookie放在控件的配置信息中
    post_params: {
,"ASP.NET_SessionId": sessionInfo //CUSTOM_ASPSESSID
,".ASPXAUTH": authInfo

在if(IsAuthenticated)判断的外面,通过Request.Params就可以得到,但这时候IsAuthenticated已经是false没法更改.

得到 Request.Params中的".ASPXAUTH"信息后,把它写入Response.Cookies集合里面,页面再次上传时,OnActionExecuting中Identity.IsAuthenticated就是true的。

但这是不够的,不能每次人家上传都要先出错一次才能真正开始上传吧?

我想问有什么办法能在第一次上传时,我得到了".ASPXAUTH"后,让这个FormsAuthentication重新执行一次吗?
...全文
321 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
idoiknow 2013-04-01
  • 打赏
  • 举报
回复
问题解决了.

尼玛,真是可以去撞一下墙了,在网上看到这个bug的解决方法时人家介绍的明明是在Global.cs重写
protected void Application_BeginRequest()

在Application_BeginRequest里面把Request.Params里面的".ASPXAUTH" 添加到Request.Cookie就好了
, 后面AuthorizeFilter里的HttpContext.User.Identity.IsAuthenticated就自动为true了.

我却以为MVC是没有 Application_BeginRequest()的,就跑到OnActionExecuting里面写,搞死都搞不出来.

我去~,基础不过关,浪费半天时间 !
idoiknow 2013-04-01
  • 打赏
  • 举报
回复
引用 2 楼 aleosunny 的回复:
C# code?1234567public override void OnActionExecuting(ActionExecutingContext filterContext) { if (filterContext.HttpContext.Request.Cookies[".ASPXAUTH"]!=null) ……
这个肯定不行,第一次上传时HttpContext.Request.Cookies里面只有一个ASP.NET_SessionId,而没有.ASPXAUTH 我只能在Request.Params[".ASPXAUTH"]获取到这个值,但我不可能用从这个".ASPXAUTH"就让它判断通过,因为这只是一个Request的参数,完全可以伪装的
焚寂 2013-04-01
  • 打赏
  • 举报
回复

public override void OnActionExecuting(ActionExecutingContext filterContext)
        {
             if (filterContext.HttpContext.Request.Cookies[".ASPXAUTH"]!=null)
             {
                   //...自定义的一些权限判断
             }
        }
把你ActionFilter判定权限的地方改成上面的
idoiknow 2013-04-01
  • 打赏
  • 举报
回复
高手快快来,100分等着你哪

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧