ASP.NET Forms身份認證

来源:http://www.cnblogs.com/lyyjun1203/archive/2017/02/04/6365780.html
-Advertisement-
Play Games

asp.net程式開發,用戶根據角色訪問對應頁面以及功能。 項目結構如下圖: 根目錄 Web.config 代碼: admin文件夾中 Web.config 代碼: teacher文件夾中 Web.config 代碼: student文件夾中 Web.config 代碼: Login.aspx中登錄 ...


asp.net程式開發,用戶根據角色訪問對應頁面以及功能。

項目結構如下圖:

根目錄 Web.config 代碼:

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <!--
 3   有關如何配置 ASP.NET 應用程式的詳細消息,請訪問
 4   http://go.microsoft.com/fwlink/?LinkId=169433
 5   -->
 6 <configuration>
 7     <system.web>
 8         <compilation debug="true" targetFramework="4.0" />
 9         <authentication mode="Forms">
10           <forms loginUrl="login.aspx"></forms>
11         </authentication>
12         <!--<authorization>
13           <allow users="*"></allow>
14         </authorization>-->
15     </system.web>
16 </configuration>

admin文件夾中 Web.config 代碼:

1 <?xml version="1.0"?>
2 <configuration>
3   <system.web>
4     <authorization>
5       <allow roles="admin" />
6       <deny users="*"/>
7     </authorization>
8   </system.web>
9 </configuration>

teacher文件夾中 Web.config 代碼:

1 <?xml version="1.0"?>
2 <configuration>
3   <system.web>
4     <authorization>
5       <allow roles="teacher" />
6       <deny users="*"/>
7     </authorization>
8   </system.web>
9 </configuration>

student文件夾中 Web.config 代碼:

1 <?xml version="1.0"?>
2 <configuration>
3   <system.web>
4     <authorization>
5       <allow roles="student" />
6       <deny users="*"/>
7     </authorization>
8   </system.web>
9 </configuration>

Login.aspx中登錄成功後設置Cookie,設置Cookie代碼:

1 protected void SetLoginCookie(string username, string roles)
2 {
3     System.Web.Security.FormsAuthentication.SetAuthCookie(username, false);
4     System.Web.Security.FormsAuthenticationTicket ticket = new FormsAuthenticationTicket(1, username, DateTime.Now, DateTime.Now.AddDays(1), false, roles, "/");
5     string hashTicket = FormsAuthentication.Encrypt(ticket);
6     HttpCookie userCookie = new HttpCookie(FormsAuthentication.FormsCookieName, hashTicket);
7     HttpContext.Current.Response.SetCookie(userCookie);
8 }

Global.asax 中進行身份驗證:

protected void Application_AuthenticateRequest(object sender, EventArgs e)
{
    HttpApplication app = (HttpApplication)sender;
    HttpContext ctx = app.Context; //獲取本次Http請求的HttpContext對象  
    if (ctx.User != null)
    {
        if (ctx.Request.IsAuthenticated == true) //驗證過的一般用戶才能進行角色驗證  
        {
            System.Web.Security.FormsIdentity fi = (System.Web.Security.FormsIdentity)ctx.User.Identity;
            System.Web.Security.FormsAuthenticationTicket ticket = fi.Ticket; //取得身份驗證票  
            string userData = ticket.UserData;//從UserData中恢復role信息
            string[] roles = userData.Split(','); //將角色數據轉成字元串數組,得到相關的角色信息  
            ctx.User = new System.Security.Principal.GenericPrincipal(fi, roles); //這樣當前用戶就擁有角色信息了
        }
    }
}

 


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

-Advertisement-
Play Games
更多相關文章
  • 前言 MoonSharp是一個支持C#調用lua腳本的類庫,支持.net, .net core, mono, unity,因此在.net core中也能夠使用,而且載入和調用lua也很方便簡單; 官網:http://www.moonsharp.org/ 源碼:https://github.com/x ...
  • 前言 在工作中經常遇到C#數組、ArrayList、List、Dictionary存取數據,但是該選擇哪種類型進行存儲數據,對於初學者的我一直不知道該怎麼取捨。於是抽空好好看了下他們的用法和比較,在這裡總結下來,後面有需要改進的再更新。 初始化 數組: ArrayList: List: Dictio ...
  • "文章原link" 場景載入器 人員 | 操作 | 日期 | 備註 | | | Conerlius | Add | 2017 2 5 | 創建 scene的進場順序,方便對每個場景的回退,同一個彈出式的視窗在游戲中只允許出現一個,彈出視窗的進場順序管理 基本類型說明: Manager解釋 對ui的堆 ...
  • 創建Visual Studio插件,項目模板,項目創建嚮導等原來也是如此簡單。本文通過開發Prism的Plugin實例講解其中的實現過程與註意事項。 ...
  • using System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Data;using System.Data.SqlClient;using System.Data.Commo ...
  • Xamarin寫Android程式時,通常要使用按中文首字母分組顯示(如通訊錄) 。 於是需要被迫包含CJK,不過包含後包肯定是會變大的,於是。。。。自己寫了一個硬枚舉的中文轉拼音的類。 原理是這樣的: 源碼: https://github.com/chsword/PinYinUtil/blob/m ...
  • 在本節中,您將創建一個新的MoviesController類,併在這個Controller類里編寫代碼來取得電影數據,並使用視圖模板將數據展示在瀏覽器里。 在開始下一步前,先Build一下應用程式(生成應用程式)(確保應用程式編譯沒有問題) 用滑鼠右鍵單擊Controller文件夾,並創建一個新的  ...
  • 前言 本節主要介紹非同步編程中Task、Async和Await的基礎知識。 什麼是非同步? 非同步處理不用阻塞當前線程來等待處理完成,而是允許後續操作,直至其它線程將處理完成,並回調通知此線程。 非同步和多線程 相同點:避免調用線程阻塞,從而提高軟體的可響應性。 不同點: 非同步操作無須額外的線程負擔,並且使 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...