從零開始實現asp.net MVC4框架網站的用戶登錄以及許可權驗證模塊 詳細教程

来源:https://www.cnblogs.com/chengchenxu/archive/2018/03/05/8508373.html
-Advertisement-
Play Games

用戶登錄與許可權驗證是網站不可缺少的一部分功能,asp.net MVC4框架內置了用於實現該功能的類庫,只需要簡單搭建即可完成該功能. 下麵詳細介紹該功能的完成方法,尾部有實例源碼下載,希望可以給剛開始接觸MVC的朋友做個參考. 第一步:給VS安裝MVC4框架 VS2012自帶MVC4框架,其他版本可 ...


    用戶登錄與許可權驗證是網站不可缺少的一部分功能,asp.net MVC4框架內置了用於實現該功能的類庫,只需要簡單搭建即可完成該功能.

下麵詳細介紹該功能的完成方法,尾部有實例源碼下載,希望可以給剛開始接觸MVC的朋友做個參考.

    第一步:給VS安裝MVC4框架

        VS2012自帶MVC4框架,其他版本可以使用獨立安裝包進行安裝,這裡就不討論了,本例使用VS2013創建,.NET4.0+MVC4

    第二步:創建MVC4網站項目

        選擇文件-新建-項目,按下圖示例創建一個空的MVC網站

        

 

 

    第三步:配置web.config,啟用Form驗證.

        打開根目錄下的web.config,在<system.web>節點下插入一下代碼,啟用Form驗證並指定預設登錄頁面

<authentication mode="Forms">
      <forms loginUrl="/Home/Login" timeout="2880"/>
</authentication>

 

 

    第四步:創建所需要文件 

        本例需要創建以下文件:

            Model文件夾下LoginModel.cs   

            Controllers文件夾下HomeController.cs

            View下創建文件下Home,文件夾下創建文件:

                Index.cshtml

                Login.cshtml

                Show.cshtml

                Edit.cshtml

                Add.cshtml

    文件結構如下圖所示:

Screen Shot 2018-03-05 at 10.54.43 AM.png

 

    第五步:填充LoginModel代碼  

 public class LoginModel
    {
        [Display(Name="用戶名")]
        [Required(ErrorMessage="用戶名不能為空")]
        public string UserName { get; set; }
 
        [Display(Name="密碼")]
        [Required(ErrorMessage="密碼不能為空")]
        [DataType(DataType.Password)]
        [RegularExpression(@"^\w+$", ErrorMessage = "密碼格式有誤,只能是字母數字或者下劃線")]  
        public string Password { get; set; }
 
 
        [Display(Name="記住登陸?")]
        public bool RememberMe { get; set; }
 
        public string Login()
        {
            //該方法應從資料庫中對比用戶名和密碼,並取得用戶許可權列表
            //這裡為了簡單直接對比字元串並返回許可權列表,返回NULL則說明用戶名或者密碼錯誤
            //許可權列表即為用,分割的許可權名稱
            string result = null;
 
            if (this.UserName == "guest" & this.Password == "guest")
                result = "Add";
 
            if (this.UserName == "admin" & this.Password == "admin")
                result = "Add,Edit";
 
            return result;
        }
    }

 


        複製上面代碼到類中時VS的智能感知會提示你缺少以下命名空間,添加上即可

using System.ComponentModel.DataAnnotations;

 

    第五步:填充HomeControll代碼

public class HomeController : Controller
    {
        //
        // GET: /Home/
 
        public ActionResult Index()
        {
            ViewBag.Info = "該頁面不含許可權註解,所有人均可訪問.";
            return View();
        }
         
       [Authorize(Roles = "Edit")] //該註解表示只有包含Edit許可權的用戶才可以訪問
        public ActionResult Edit()
        {
            ViewBag.Info = "該頁面需要包含Edit許可權的人才可訪問.";
            return View();
        }
 
       [Authorize(Roles = "Add")] //該註解表示只有包含Add許可權的用戶才可以訪問
        public ActionResult Add()
        {
            ViewBag.Info = "該頁面需要包含Add許可權的人才可訪問.";
            return View();
        }
 
       [Authorize(Roles = "Add,Edit")] //該註解表示只有包含Add許可權的用戶才可以訪問
        public ActionResult Show()
        {
            ViewBag.Info = "該頁面需要包含Edit或者Add許可權的人才可訪問.";
            return View();
        }
 
       public ActionResult Login(LoginModel model)
       {
           return View();
       }
 
       [HttpPost] //該註解表示只接收Post數據
       [ValidateAntiForgeryToken]//該註解可以防止跨站攻擊
       [ActionName("Login")]//該註解可以更改路由中Action名稱
       public ActionResult LoginCheck(LoginModel model)
       {
           if (!ModelState.IsValid)
           {
               //用戶輸入服務端驗證,此處處理驗證不通過的提示代碼 本例略過             
               return View();
           }
 
           string result = model.Login();
 
           if (result == null)
           {
               //用戶名或者密碼不正確的提示代碼 本例略過
               return View();
           }
           else
           {
               //用戶登陸核心代碼
               FormsAuthenticationTicket authTicket = new FormsAuthenticationTicket(
                    1,
                    model.UserName,
                    DateTime.Now,
                    DateTime.Now.AddHours(240),//記住密碼的時間
                    model.RememberMe,//是否保存cookie 記住密碼
                    result //獲取的用戶許可權列表 用逗號分割的字元串
                    );
               string encryptedTickt = FormsAuthentication.Encrypt(authTicket);
               HttpCookie authCookie = new HttpCookie(FormsAuthentication.FormsCookieName, encryptedTickt);
               Response.Cookies.Add(authCookie);
 
               Response.Redirect("/Home", true);
               ActionResult empty = new EmptyResult();
               return empty;
           }
           return View();
       }

 


 

複製以上代碼,會提示添加以下命名空間:

using ChengChenXu.MVC4_Login_Demo.Models; //項目Model命名空間
using System.Web.Security;

 

    第六步:填充View代碼,下麵代碼僅展示<Body>標簽內部的內容,頁頭沒有展示(源碼中完全).

        Index.cshtml

     <h1>@ViewBag.Info</h1><br />
        <a href="/home/login">登陸</a><br />
        <p>以下鏈接 登陸後才可以訪問 未登陸時如果點擊則會跳轉到登陸頁</p>
        <a href="/home/add">添加頁面</a><br />
        <a href="/home/edit">編輯頁面</a><br />
        <a href="/home/show">查看頁面</a><br />

 


        Add.cshtml  Edit.cshtml  Show.cshtml 三個文件代碼一致

     <h1>@ViewBag.Info</h1>
        <a href="/home">返回</a><br />

 


        Login.cshtml 該文件首先要在頂部添加一行代碼,表示是一個強類型View

@model ChengChenXu.MVC4_Login_Demo.Models.LoginModel

 

        頁面代碼:

        @using (Html.BeginForm())
            {
                @Html.AntiForgeryToken()
             
                @Html.LabelFor(model=>model.UserName)
                @Html.TextBoxFor(model => model.UserName)
                <br />
 
                @Html.LabelFor(model=>model.Password)
                @Html.PasswordFor(model => model.Password)
                <br />
             
                @Html.LabelFor(Model=>Model.RememberMe)
                @Html.CheckBoxFor(model=>model.RememberMe)
                <br />
             
                <input type="submit" class="submit" tabindex="3" value="登錄" />
 
            }

 


    第七步:修改根目錄下Global.asax的代碼,添加許可權處理代碼,把下麵兩個方法複製添加到Global文件即可

     public MvcApplication()
        {
            AuthorizeRequest += new EventHandler(MvcApplication_AuthorizeRequest);
        }
 
        void MvcApplication_AuthorizeRequest(object sender, EventArgs e)
        {
            var id = Context.User.Identity as FormsIdentity;
            if (id != null && id.IsAuthenticated)
            {
                var roles = id.Ticket.UserData.Split(',');
                Context.User = new GenericPrincipal(id, roles);
            }
        }

 

    複製好後會提示缺少以下命名空間:

using System.Web.Security;
using System.Security.Principal;

 

完成好之後全部實例就完成了,運行以下試試吧.

主頁為/Home  無需許可權

登錄頁為/Home/Login  無需許可權

添加頁為/Home/Add   需要Add許可權

展示頁為/Home/Show  需要Edit或者Add許可權

編輯頁為/Home/Edit  需要Edit許可權

內置了兩個賬號 

賬號 密碼 許可權

guest guest "add"  

admin admin "add,edit"

 

運行結果:

如果直接訪問除了Home和Login頁面之外的頁面(需要許可權的頁面) 則會跳轉到Login頁面

guest賬號可以訪問Add Show頁面

admin賬號可以訪問Add Edit Show頁面

 

錦上添花:

1 自動跳轉到登錄頁的時候URL會有一個ReturnUrl參數記錄跳轉前的頁面,可以捕捉該頁面登錄後跳回

2 MVC支持客戶端驗證,需要js文件支持,這樣客戶端就不再需要寫js代碼進行輸入驗證了.本例不再展示了,請自行搜索.

 

本博文轉自我的博客:http://chengchenxu.com/Article/show/14/  

源碼下載:http://chengchenxu.com/ueditor/net/upload/file/20180305/6365584952537468509926479.rar


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1. 方法思路: 使用數據字典【Dictionary<string, string>】,聲明一個list集合,將“XML子節點名稱”、“節點值”以鍵【節點名稱】值【節點值】對的形式存入此集合,然後將此集合作為參數傳入封裝的公共方法中即可; 2. 公共方法: 3. 對公共方法的調用: 4. 整體的完整 ...
  • 在Task運行過程中,我們可以通過.Net 4中的內置方法來取消Task的運行。 創建一個可取消的Task需要用到下麵的一些對象: 1.System.Threading.CancellationTokenSource實例 2.通過CancellationTokenSource.Token屬性獲得一個 ...
  • pageSize:表示每頁有多少條數據pageNum:表示頁數,正確表達式pageNum+1。pageNum=0,是第一頁。pageNum=1,是第二頁。Skip:表示從pageNum* pageSize+1條開始算,原來就有pageNum* pageSize條數據Take:等於pageSize的值 ...
  • 實例產品基於asp.net mvc 5.0框架,源碼下載地址:http://www.jinhusns.com/Products/Download 在設計時,如果能夠預測到一些實體可能在後續的研發(或二次開發)中增加一些屬性,為了能夠快速增、減這類屬性,提供了可序列化屬性的設計機制。可序列化屬性具有以 ...
  • 本文通過ANTS Memory Profiler工具探索c#中+、string.Concat、string.Format、StringBuilder.Append四種方式進行字元串拼接時的性能。 本文涉及程式為.NET Core 2.0控制台應用程式。 一、常量字元串拼接 private stati ...
  • 從https://github.com/qingask/PetaPoco.NetCore下載源文件壓縮包 解壓出文件PetaPoco.Multiple.cs、PetaPoco.NetCore.cs 放置System.Data.SQLite.dll文件到bin文件,這個需要從SQLite官方獲取對應框... ...
  • https://github.com/exaphaser/ScrapySharp https://github.com/zzzprojects/html-agility-pack https://github.com/atifaziz/Fizzler https://archive.codeplex ...
  • 很久沒弄.net的東西,鑒於自己的網站考慮跨平臺,準備利用空閑時間把框架移植成asp.net core,本來.net的東西一般只用3版本以上的,人老了,時間不多了,只好先入坑; 第一件事就是開發環境搭建,按照文檔安裝sdk後,發現iis里的網站直接指向本地源碼不行了,調試要麼f5(從來不喜歡這種方式 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...