zoukankan      html  css  js  c++  java
  • ASP.NET 安全认证(一)—— 如何运用 Form 表单认证 .

    第一部分 如何运用 Form 表单认证

    一、        新建一个测试项目

    为了更好说明,有必要新建一个测试项目(暂且为“FormTest”吧),包含三张页面足矣(Default.aspxLogin.aspxUserInfo.aspx。啥?有人不会新建项目,不会新增页面?你问我咋办?我看这么办好了:拖出去,打回原藉,从幼儿园学起……

    二、        修改Web.config

    1、  双击项目中的Web.config(不会的、找不到的打 PP

    2、  找到下列文字 <authentication mode="Windows" /> 把它改成:

    <authentication mode="Forms">

    <forms loginUrl="Login.aspx" name=".ASPXAUTH"></forms>

    </authentication>

    3、  找到<authorization> <allow users="*" /></authorization>换成

    <authorization><deny users="?"></deny></authorization>

     

    这里没什么好说的,只要拷贝过去就行。虽说如此,但还是有人会弄错,如下:

    <authentication mode="Forms">

           <forms loginUrl="Login.aspx" name=".APSX"></forms>

    <deny users="?"></deny>

     </authentication>

    若要问是谁把 <deny users="?"></deny> 放入 <authentication> 中的,我会很荣幸地告诉你,那是 N 年前的我:<authentication> <authorization> 都是以 auth 字母开头又都是以 ation 结尾,何其相似;英文单词背不下来的我以为他们是一伙的……

    三、        编写 .cs 代码——登录与退出

    1、  登录代码:

    a、  书本上介绍的

             private void Btn_Login_Click(objectsender, System.EventArgs e)

             {

                  if(this.Txt_UserName.Text=="Admin" && this.Txt_Password.Text=="123456")

                  {

         System.Web.Security.FormsAuthentication.RedirectFromLoginPage(this.Txt_UserName.Text,false);

         }

    }

    b、  偶找了 N 久才找到的

    private void Btn_Login_Click(objectsender, System.EventArgs e)

             {

                  if(this.Txt_UserName.Text=="Admin" && this.Txt_Password.Text=="123456")

                  {

    System.Web.Security.FormsAuthentication.SetAuthCookie(this.Txt_UserName.Text,false);

         Response.Redirect("Default.aspx");

         }

    }

    以上两种都可发放验证后的 Cookie ,即通过验证,区别:

    方法 a) 指验证后返回请求页面,俗称“从哪来就打哪去”。比如:用户没登录前直接在 IE 地址栏输入 http://localhost/FormTest/UserInfo.aspx ,那么该用户将看到的是 Login.aspx?ReturnUrl=UserInfo.aspx ,输入用户名与密码登录成功后,系统将根据“ReturnUrl”的值,返回相应的页面

    方法 b) 则是分两步走:通过验证后就直接发放 Cookie ,跳转页面将由程序员自行指定,此方法多用于 Default.aspx 使用框架结构的系统。

     

    2、  退出代码:

    private void Btn_LogOut_Click(objectsender, System.EventArgs e)

         {

    System.Web.Security.FormsAuthentication.SignOut();

    }

    四、        如何判断验证与否及获取验证后的用户信息

    有的时候,在同一张页面需要判断用户是否已经登录,然后再呈现不同的布局。有人喜欢用 Session 来判断,我不反对此类做法,在此我只是想告诉大家还有一种方法,且看下面代码:

    if(User.Identity.IsAuthenticated)

             {

                  //你已通过验证,知道该怎么做了吧?

    }

    User.Identity 还有两个属性AuthenticationType(验证类型)与 Name(用户名称) ,大家要注意的是 Name 属性,此处的User.Identity.Name将得到,验证通过(RedirectFromLoginPage SetAuthCookie)时,我们带入的第一个参数 this.Txt_UserName.Text 。这个参数很重要,关系到种种……种种的情况,何出此言,且听下回分解……

    ASP.NET 安全认证(二)—— 灵活运用 Form 表单认证中的 deny allow 及保护 .htm 等文件

     

     

    本文摘自:http://blog.csdn.net/cityhunter172/article/details/524043
        本文作者:寒羽枫

  • 相关阅读:
    移动桌面文件
    软件项目经理素质能力的必备要求
    如何管理时间
    《明日歌》
    浏览网页出现iexplore.exe应用程序错误为:"0x03e620b0"指令引用的"0x00000000"内存.该内存不能为"read"?
    css网站布局学习笔记
    因为爱,人生除了理智,还有情感!
    35岁之前成功的12条黄金法则
    VS2005中没有DataGrid控件的解决方案
    先装VS2005再装IIS,出现访问IIS元数据库失败解决方案
  • 原文地址:https://www.cnblogs.com/hanshuhe/p/2202387.html
Copyright © 2011-2022 走看看