asp.net web api添加自訂認證

來源:互聯網
上載者:User

標籤:

1、定義認證失敗結果產生器

   /// <summary>    /// 認證失敗結果產生器    /// </summary>    public class AuthenticationFailureResult : IHttpActionResult    {        public AuthenticationFailureResult(string reasonPhrase, HttpRequestMessage request)        {            ReasonPhrase = reasonPhrase;            Request = request;        }        public string ReasonPhrase { get; private set; }        public HttpRequestMessage Request { get; private set; }        public Task<HttpResponseMessage> ExecuteAsync(CancellationToken cancellationToken)        {            return Task.FromResult(Execute());        }        private HttpResponseMessage Execute()        {            return Request.CreateErrorResponse(HttpStatusCode.Unauthorized, this.ReasonPhrase);        }    }

2、定義自訂認證過濾器(基於Cookie)

/// <summary>    /// 自訂認證    /// </summary>    public class CustomAuthenticationFilter : Attribute, IAuthenticationFilter    {        public virtual bool AllowMultiple        {            get { return false; }        }        public async Task AuthenticateAsync(HttpAuthenticationContext context, CancellationToken cancellationToken)        {            var principal = await this.AuthenticateAsync(context.Request);            if (principal == null)            {                context.Request.Headers.GetCookies().Clear();                context.ErrorResult = new AuthenticationFailureResult("未授權請求", context.Request);            }            else            {                context.Principal = principal;            }        }        public Task ChallengeAsync(HttpAuthenticationChallengeContext context, CancellationToken cancellationToken)        {            return Task.FromResult(0);        }        private Task<IPrincipal> AuthenticateAsync(HttpRequestMessage request)        {            return Task.Run<IPrincipal>(() =>                {                    CookieHeaderValue cookieMobile = request.Headers.GetCookies("clientMobile").FirstOrDefault(),                        cookieToken = request.Headers.GetCookies("clientToken").FirstOrDefault();                    if (cookieMobile == null || cookieToken == null                        || string.IsNullOrWhiteSpace(cookieMobile["clientMobile"].Value)                        || string.IsNullOrWhiteSpace(cookieToken["clientToken"].Value))                    {                        return null;                    }                    string mobile = cookieMobile["clientMobile"].Value,                        token = cookieToken["clientToken"].Value;                    ClientDTO client = null;
            //此處從Redis伺服器中取出指定使用者,各位可以根據需要自行更換 using (ICache cache = ObjectContainer.Current.Resolve<ICacheFactory>().CreateCache()) { client = cache.Get<ClientDTO>(RedisTables.CLIENT, mobile); }
            //驗證使用者合法性,如果合法,構建聲明式安全主題許可權模式並返回,若使用者驗證不通過返回空 if (client != null && string.Equals(token, Md5Helper.MD5(string.Format("{0}{1}", mobile, client.MsgCode), 32), StringComparison.Ordinal)) { IEnumerable<Claim> claims = new List<Claim>() { new Claim(ClaimTypes.Name, mobile) }; var identity = new ClaimsIdentity("LoanCookie"); identity.AddClaims(claims); return new ClaimsPrincipal(identity); } return null; }); } }

3、將認證特性標記應用於全域、控制器或控制器操作,以控制器操作為例:

 

asp.net web api添加自訂認證

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.