自定义身份验证的HttpModule如何与Windows身份验证交互?

时间:2010-12-09 17:11:06

标签: c# asp.net iis-7 windows-authentication httpmodule

我正在尝试创建一个自定义HttpModule,它控制哪些用户可以查看网站。

我正在尝试利用Windows身份验证来执行此操作。

在单个页面上,我可能会这样做:

if (HttpContext.Current.User.Identity.Name.Contains("jsmith"))
{
    Response.Write("You do not have the correct permissions to view this site.");
    Response.End();
}

但是因为我想在应用程序级别更加可配置,我想使用HttpModule。

以下是我对代码的开始:

using System;
using System.Web;

public class CustomAuthHttpModule : IHttpModule
{
    public void Dispose() { }

    public void Init(HttpApplication context)
    {
        context.BeginRequest += new EventHandler(OnBeginRequest);
        context.EndRequest += new EventHandler(OnEndRequest);
    }

    void OnBeginRequest(object sender, EventArgs e) { }

    void OnEndRequest(object sender, EventArgs e)
    {
        HttpApplication appObject = (HttpApplication)sender;
        HttpContext contextObject = appObject.Context;

        if (contextObject.User.Identity.Name.Contains("jsmith"))
        {
            contextObject.Response.Clear();
            contextObject.Response.End();
        }
    }
}

如果我可以将它放在OnBeginRequest()函数中,我可以使用我拥有的代码。但是在OnEndRequest()运行之前,不会在HttpContext对象中创建User属性。

之前运行代码会阻止应用程序执行生成此输出的额外工作,因为最终将阻止某些用户访问。

有人可以建议解决方案吗 - 这是因为我的模块在Windows Auth模块之前运行,还是什么?

...或者,也许有一种更简单的方法来执行我尝试使用IIS或文件系统权限的操作?

3 个答案:

答案 0 :(得分:10)

您想要AuthenticateRequest事件。

AuthenticateRequest event

答案 1 :(得分:0)

您是否尝试过在global.aspx中实现该方法? OnSessionStart? 此外,我会使用hasRole或其他一些group-Property而不是contains和username。

答案 2 :(得分:-1)

为什么要为此编写一个http模块。如果这是asp.net Web表单,那么为什么不简单地使用像LoginView http://msdn.microsoft.com/en-us/library/system.web.ui.webcontrols.loginview.aspx

这样的内置函数