重定向至“自定义禁用页面在asp.net中不起作用”诊断树

本文关键字:net asp 不起作用 诊断 自定义 重定向 | 更新日期: 2023-09-27 17:59:48

我有一个公共(无身份验证)网站,除了一个需要身份验证的页面。这很好。

受保护的页面位于包含以下web.config的文件夹中:

<?xml version="1.0"?>
<configuration>
    <system.web>
        <authorization>
            <allow roles="Warehouse" />
            <deny users="*" />
        </authorization>
        <customErrors mode="RemoteOnly" defaultRedirect="../WebForbidden.aspx">
            <!--<error statusCode="403" redirect="WebForbidden.aspx" />
            <error statusCode="404" redirect="FileNotFound.htm" />-->
        </customErrors>
    </system.web>
</configuration>

该页面的主文件包含以下内容:

protected void Page_Init(object sender, EventArgs e)
    {
        CheckLogged();
    }
    public bool CheckLogged()
    {
        bool status = false;
        if (Session["Username"] == null)
        {
            FormsAuthentication.SignOut();
            Response.Redirect("../WebForbidden.aspx");
            //FormsAuthentication.RedirectToLoginPage();
        }
        else
        {
            status = true;
        }
        return status;
    }

我在网站的根目录中有WebForbidden.aspx页面。

现在,每次我尝试直接进入受保护的页面(除非经过身份验证,否则是被禁止的)而不是显示被禁止的页面时,都会显示一个错误:The resource cannot be found,当然网站正在尝试重定向到不存在的登录页面。

任何帮助都将不胜感激。

重定向至“自定义禁用页面在asp.net中不起作用”诊断树

尝试告诉表单身份验证重定向到WebForbidden.aspx,而不是让它使用默认值,如果不指定,它将查找Login.aspx

<system.web>
    <authentication mode="Forms">
        <forms loginUrl="WebForbidden.aspx" />
    </authentication>
</system.web>