關於.Net WebAPI數據認證(包括登陸認證、模型認證)

来源:http://www.cnblogs.com/zhouyukai/archive/2017/08/29/7448160.html
-Advertisement-
Play Games

1、登陸認證使用WebAPI自動認證 webApi自動認證繼承類:AuthorizeAttribute 自動認證類使用在控制器上 [Authentication] public class CardController : BasisController { } 主要重寫二個方法 1、OnAutho ...


1、登陸認證使用WebAPI自動認證

   webApi自動認證繼承類:AuthorizeAttribute

    自動認證類使用在控制器上

    [Authentication]
    public class CardController : BasisController
    {
    }
View Code

    主要重寫二個方法

      1、OnAuthorization 在認證的時候自動調用這個方法

      2、HandleUnauthorizedRequest 認證失敗的時候調用這個方法          

    /// <summary>
    /// 自動認證 作者KAI
    /// </summary>
    public class Authentication : AuthorizeAttribute
    {
        /// <summary>
        /// 自動認證
        /// </summary>
        /// <param name="actionContext"></param>
        public override void OnAuthorization(HttpActionContext actionContext)
        {
            //actionContext當前請求的HttpActionContext 可以獲取請求的內容
            //actionContext.Response
            //actionContext.Request
            //actionContext.RequestContext

            //也可以這樣獲取
            //System.Web.HttpContext.Current.Request
            //System.Web.HttpContext.Current.Response
            if (true)
            {
                //成功以後不使用session如何把數據傳到對應的Action 設置當前請求的User對象就行了 Action裡面有User直接可以用
                // HttpContext.Current.User = new UserModel() { loginUser = new_user }; //設置當前登陸人模型 UserModel是自定義模型
                base.IsAuthorized(actionContext);
                //認證成功調用 接下來會到具體的action裡面運行 
            }
            else
            {
                this.HandleUnauthorizedRequest(actionContext);
                //認證失敗調用
            }

        }
        /// <summary>
        /// 錯誤返回
        /// </summary>
        /// <param name="actionContext"></param>
        protected override void HandleUnauthorizedRequest(HttpActionContext actionContext)
        {
            JsonData jsonData = new JsonData();
            jsonData.state = "400";
            jsonData.message = "親!你還沒登陸哪";
            actionContext.Response = new HttpResponseMessage(HttpStatusCode.OK)
            {
                Content = new StringContent(JsonHelper.ObjectToJSON(jsonData), Encoding.UTF8, "application/json")
            };
        }
    }
View Code

    UserModel模型我用於傳遞數據到具體的Action

      使用 HttpContext.Current.User = new UserModel() { loginUser = new_user }; //設置當前登陸人模型

   public class UserModel : IPrincipal
    {
        public er_wx_user loginUser { get; set; }
        public bool IsInRole(string name)
        {
            return true;
        }
        public IIdentity Identity { get; set; }
    }
View Code   

2、模型認證

    webApi模型認證繼承類:ActionFilterAttribute

    模型認證類使用在Action上  

   [ModelApprove]

        public HttpResponseMessage boundUserPhone([FromBody]boundUserPhone boundUserPhoneModel)
        {
        }    
View Code

     主要重寫二個方法

       1、OnActionExecuting 模型認證的時候自動調用 webApi上如果用模型接收數據則會自動認證

       2、ErrorRequest 認證失敗的錯誤返回

/// <summary>
    /// 模型欄位認證 作者KAI
    /// </summary>
    public class ModelApprove : ActionFilterAttribute
    {
        /// <summary>
        /// 模型認證
        /// </summary>
        /// <param name="actionContext"></param>
        public override void OnActionExecuting(HttpActionContext actionContext)
        {

            //模型認證不通過
            //actionContext.ModelState.IsValid 模型認證是否通過根據模型的規則 自動認證
            if (!actionContext.ModelState.IsValid)
            {
                this.ErrorRequest(actionContext);
            }
        }

        /// <summary>
        /// 錯誤返回
        /// </summary>
        /// <param name="actionContext"></param>
        protected void ErrorRequest(HttpActionContext actionContext)
        {
            //獲取全部的錯誤模型認證錯誤的內容全在這個List內
            List<string> errorList = new List<string>();
            foreach (var value in actionContext.ModelState.Values)
            {
                foreach (var error in value.Errors)
                {
                    errorList.Add(error.ErrorMessage);
                }
            }
            //下麵是錯誤返回 和自動認證一樣寫法
            JsonData jsonData = new JsonData();
            jsonData.state = "300";
            jsonData.message = errorList.FirstOrDefault();
            jsonData.backData.Add("info", errorList);
            actionContext.Response = new HttpResponseMessage(HttpStatusCode.OK)
            {
                Content = new StringContent(JsonHelper.ObjectToJSON(jsonData), Encoding.UTF8, "application/json")
            };
        }
    }
View Code

3、自定義模型認證規則

    認證規則使用在模型屬性上

  public class addCardLog
    {
        [Required(ErrorMessage = "卡ID不能為空")]
        public int card_id { get; set; }

    }
View Code

    有一些系統自帶的認證規則

    所在命名空間 :using System.ComponentModel.DataAnnotations;

  

   public class addInfo
    {
        [Required(ErrorMessage = "內容不能為空")]
        [StringLength(10, MinimumLength = 1, ErrorMessage = "長度範圍1-10")]
        [Range(typeof(string), "1", "2", ErrorMessage = "類型為1或者2")]
        [RegularExpression(@"^1(3|4|5|7|8)\d{9}$", ErrorMessage = "正則表達式認證錯誤內容")]
        [Compare("name_two",ErrorMessage ="二次名字不一致")]//內容是否和name_two一樣多在認證二次密碼 輸入是否一致
        public string name { get; set; }
        public string name_two { get; set; }
    }
View Code

     自定義規則認證

      webApi模型認證自定義規則繼承類:ValidationAttribute

    主要重寫一個方法

      1、IsValid

    /// <summary>
    /// 驗證碼檢查規則
    /// </summary>
    public class VerifyCodeCheck : ValidationAttribute
    {

        public string phoneString { get; set; }

        /// <summary>
        /// 檢查是否通過認證
        /// </summary>
        /// <param name="value"></param>
        /// <returns></returns>
        protected override ValidationResult IsValid(object value, ValidationContext validationContext)
        {
            try
            {
                //value 是認證的屬性的值
                //validationContext.ObjectInstance 是當前模型的object 對象可以用反射獲取值 
                //可能在認證的時候需要別值參與 objectToMap方法把 object對象變成鍵值對對象
                var phone = CommonHelper.objectToMap(validationContext.ObjectInstance)[phoneString].ToString();
                if (CacheHelper.Get(phone).ToString().Equals(value.ToString()))
                {
                    return ValidationResult.Success;
                }
                return new ValidationResult(base.ErrorMessage);
            }
            catch
            {
                return new ValidationResult("驗證碼失效或者錯誤");
            }

        }
    }
}
View Code

       反射獲取object對象的公共屬性和值

   /// <summary>
        /// 對象轉Map集合 利用反射
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <returns></returns>
        public static Dictionary<string, object> objectToMap(object obj)
        {
            try
            {

                if (obj == null) throw new Exception();
                Dictionary<string, object> map = new Dictionary<string, object>();
                foreach (var attribute in obj.GetType().GetProperties()) //反射獲取屬性列表
                {
                    map.Add(attribute.Name, attribute.GetValue(obj));

                }
                return map;
            }
            catch
            {

                return null;
            }
        }
View Code

 源碼鏈接: https://pan.baidu.com/s/1dEHWkut 密碼: 29qr


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

-Advertisement-
Play Games
更多相關文章
  • 1. 準備工作 1.1. 軟體準備 1、安裝VMWare 2、在VMWare上安裝CentOS6.5 3、安裝XShell5,用來遠程登錄系統 4、通過rpm -qa | grep ssh 檢查cent os 是否安裝了ssh server和ssh client ,然後使用ssh localhost ...
  • 本文說明的是一條linux命令在執行時大致要經過哪些過程?以及這些過程的大致順序。 1.1 shell解析命令行 shell讀取和執行命令時的大致操作過程如下圖: 以執行以下命令為例: echo -e "some files:" ~/i* "\nThe date:$(date +%F)\n$name ...
  • 監測命令的運行時間 time command $ time sleep 5 real 0m5.003s # 程式開始至結束的時間,包括其它進程占用的時間片和IO時間 user 0m0.001s # 進程真正執行占用CPU的時間 sys 0m0.002s # 進程在內核中調用所消耗的CPU時間 use ...
  • 通俗的講,環境變數就是告訴電腦 (實際是操作系統)幾個目錄。這幾個目錄下存儲幾個執行文件,如前面顯示的/usr/bin目錄,大部分的系統命令都在這個目錄下。 當我們輸入命令mkdir時,系統就會在環境變數所代表的幾個目錄從前到後去查找,哪個裡面有mkdir文件,然後去執行mkdir命令。 系統中環境 ...
  • ...
  • 我們公司目前大規模使用了Docker,目前除了資料庫應用,其他所有應用都在Docker容器內運行,下麵我就Docker在公司的應用做一些分享。、 首先我介紹一下公司的背景,公司屬於中小型創業公司,伺服器數量不多,但是為瞭解決一些問題,我們引入了現在比較火的Docker技術。 看一下我們在沒用Dock ...
  • 本篇簡單介紹內核相關的基本概念。 主要內容: 單內核和微內核 內核版本號 1. 單內核和微內核 原理 優勢 劣勢 單內核 微內核 Linux的內核雖然是基於單內核的,但是經過這麼多年的發展,也具備微內核的一些特征。(體現了Linux實用至上的原則) 主要有以下特征: 2. 內核版本號 內核的版本號主 ...
  • 游戲裡面經常有轉盤活動, 為了讓轉盤表現自然一點, 就需要自己模擬阻尼運動, 分為三個過程: 勻加速運動, 勻速運動, 勻減速運動 設定最高速度為MaxSpeed, SpeedUp1(勻加速運動的加速度), SpeedUp2(勻減速運動的加速度), Expect(期望停留的弧度點) 其實模擬只需要把 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...