15-身份验证

身份验证

ASP.NET中身份认证有如下几种方式:

(1)Windows:使用Windows操作系统和NTFS文件系统验证,适合公司内部站点使用,不适合大众商业站点 。

(2)Forms:利用网页向客户端发送凭证,客户端再把凭证提交给应用程序进行身份验证(使用最普遍)。

(3)passport:一种单点登录标准(微软提供使用付费国内应用较少)。

本教程主要讲解Forms身份验证:

(1) 在配置文件中进行配置身份验证,(用户凭证分别使用明文和MD5进行演示),只有输入了正确用户名和

密码才能访问网站页面。

(2) 在配置文件中配置目录访问规则,登录所有用户可以访问页面,某些登录用户可以访问VIP目录,某些登录

用户可以访问Admin用户。

一、网站目录结构

后面所有的测试案例都是基于以下网站目录结构为基础来进行的。

0013.PNG

二、阻挡所有匿名访问

在配置文件中进行配置身份验证,(用户凭证分别使用明文和MD5进行演示),只有输入了正确用户名和密码才

能访问网站页面。

(1)网站根目录中配置身份验证信息。

在<system.web>节点中新增如下配置,此用户凭证也可以在数据库中存储用户名和密码。

<!--设置身份验证信息-->
<authentication mode="Forms">
  <!--设置验证页面和默认跳转地址-->
  <forms loginUrl="Login.aspx" defaultUrl="Index.aspx">
    <!--用户凭证(用户名&密码)  passwordFormat="Clear":明文-->
    <!--<credentials passwordFormat="Clear">
      <user name="liubei" password="123456"/>
      <user name="guanyu" password="123456"/>
      <user name="zhangfei" password="123456"/>
      <user name="zhaoyun" password="123456"/>
      <user name="machao" password="123456"/>
      <user name="mahuateng" password="123456"/>
    </credentials>-->
    
    <!--用户凭证(用户名&密码)  passwordFormat="Clear":明文-->
    <credentials passwordFormat="MD5">
            
      <user name="liubei" password="E10ADC3949BA59ABBE56E057F20F883E"/>
      <user name="guanyu" password="E10ADC3949BA59ABBE56E057F20F883E"/>
      <user name="zhangfei" password="E10ADC3949BA59ABBE56E057F20F883E"/>
      <user name="zhaoyun" password="E10ADC3949BA59ABBE56E057F20F883E"/>
      <user name="machao" password="E10ADC3949BA59ABBE56E057F20F883E"/>
      <user name="mahuateng" password="E10ADC3949BA59ABBE56E057F20F883E"/>
    </credentials>
          
  </forms>
</authentication>

(2)访问规则授权控制,在<system.web>节点中新增如下配置

<!--设置访问规则授权-->
<authorization>
  <deny users="?"/> <!--deny:拒绝访问,?:匿名用户-->
</authorization>

(3)登录页面代码:

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <h1>登录</h1>
        <p>
            账号:<asp:TextBox ID="txtAccount" runat="server"></asp:TextBox>
        </p>
        <p>
            密码:<asp:TextBox ID="txtPwd" runat="server" TextMode="Password"></asp:TextBox>
        </p>
        <p>
            <asp:Button ID="btnLogin" runat="server" Text="登录" onclick="btnLogin_Click"/>
        </p>
    </div>
    </form>
</body>
</html>
public partial class Login : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {

    }

    #region 用户登录
    protected void btnLogin_Click(object sender, EventArgs e)
    {
        //根据配置文件进行登录用户名密码的判断(如果数据库存储用户名密码,用户名密码判断也可以从数据库读取)
        if (System.Web.Security.FormsAuthentication.Authenticate(this.txtAccount.Text, this.txtPwd.Text) == true) //登录成功
        {
            //方案一:
            //System.Web.Security.FormsAuthentication.SetAuthCookie(this.txtAccount.Text, false);
            ////如果访问其它页面,没有凭证,会自动跳转到登录页面,并返回ReturnUrl,记录访问地址
            //if (Request.QueryString["ReturnUrl"] == null)
            //{
            //    Response.Redirect("Index.aspx");
            //}
            //else
            //{
            //    Response.Redirect(Request.QueryString["ReturnUrl"]);
            //}

            //方案二:
            System.Web.Security.FormsAuthentication.RedirectFromLoginPage(this.txtAccount.Text, false);
        }
        else
        {
            Page.ClientScript.RegisterStartupScript(this.GetType(), "js", "<script>alert('用户名或密码错误!');window.location.href='Login.aspx';</script>");
        }
    }
    #endregion
}

三、配置目录访问权限

(1)如果需要配置所有匿名用户和mahuateng都不能访问网站,则<system.web>节点中新增如下配置:

<!--设置访问规则授权-->
<authorization>
    <deny users="?,mahuateng"/> <!--deny:拒绝访问,?:匿名用户(代表匿名用户和mahuateng不能访问页面)-->
</authorization>

(2)如果人员角色如下:

【1】liubei,guanyu,zhangfei公司领导。

【2】zhaoyun,machao普通员工。

【3】mahuatengIT管理员

普通员工只能访问根目录Index,公司领导访问根目录Index和VIP所有内容,IT管理员只能访问Admin所有内容

则可以在<configuration>节点中配置如下:

<!--配置VIP目录访问规则授权-->
<location path="VIP">
    <system.web>
        <authorization>
            <deny users="?,zhaoyun,machao,mahuateng"/>
        </authorization>
    </system.web>
</location>
<!--配置目录访问规则授权,此配置也可以直接写在目录的web.config中-->
<location path="Admin">
    <system.web>
        <authorization>
            <allow users="mahuateng"/>
            <deny users="*"/>
        </authorization>
    </system.web>
</location>
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容