1. 程式人生 > >Asp.net MVC使用FormsAuthentication,MVC和WEB API可以共享身份認證 (轉載)

Asp.net MVC使用FormsAuthentication,MVC和WEB API可以共享身份認證 (轉載)

mlp ges web api nbsp 快速 charset 生成頁面 核心 lds

在實際的項目應用中,很多時候都需要保證數據的安全和可靠,如何來保證數據的安全呢?做法有很多,最常見的就是進行身份驗證。驗證通過,根據驗證過的身份給與對應訪問權限。同在Web Api中如何實現身份認證呢?接下來的內容就介紹使用Asp.Net的FormsAuthentication來同時做Mvc 和 Web API的身份認證。

首先擴展自定義身份驗證
添加類 CustomAuthorizeAttribute.cs
該類繼承自System.Web.Http.AuthorizeAttribute(身份認證類)通過重寫其身份認證核心方法來達到 web API 身份認證的效果。
完整代碼:

public
class CustomAuthorizeAttribute : System.Web.Http.AuthorizeAttribute { public override void OnAuthorization(System.Web.Http.Controllers.HttpActionContext actionContext) { //判斷用戶是否登錄 if(!HttpContext.Current.User.Identity.IsAuthenticated) HandleUnauthorizedRequest(actionContext); }
protected override void HandleUnauthorizedRequest(System.Web.Http.Controllers.HttpActionContext actionContext) { var challengeMessage = new System.Net.Http.HttpResponseMessage(System.Net.HttpStatusCode.Unauthorized); challengeMessage.Headers.Add("WWW-Authenticate", "
Basic"); throw new System.Web.Http.HttpResponseException(challengeMessage); } }

增加身份認證(必須登錄後才能進行查詢等操作)在Controller上加上屬性,可以直接通過VS快捷鍵感應出來

技術分享

完整代碼

技術分享

PS:寫在controller類上是表示這個controller的每個action都受身份認證,如果想為某一個action制定 可以直接寫在action上,就不要寫在類上了。

接下來編寫登錄方法

public ActionResult Login()
        {
            return View();
        }

        [HttpPost]
        public ActionResult Login(FormCollection fol)
        {
            ///此處為了演示簡化登錄過程
            ///可以在此處擴展驗證用戶名或者密碼是否正確
            System.Web.Security.FormsAuthentication.SetAuthCookie(fol["username"], false);
            return Redirect("/HTMLPage5.htm");
        }

有了後臺的方法,就剩下最後的前段頁面了
通過在Login的方法中右鍵可以快速生成頁面(vs給我們帶來的提高效率的工具,就不多做介紹了)

技術分享

在生成的Login.cshtml中編寫以下登錄代碼

@using (Html.BeginForm())
{
    <fieldset>
    <label>賬號:</label><input type="text" name="username" /><br />
    <label>密碼:</label><input type="text" name="password" /><br />
    <input type="submit" value="登錄" />
    </fieldset>
}

這個時候還需要有兩個小地方做配置.
第一個就是web.config 配置form認證

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

第二個就是修改HTMLPage5.html的js(HTMLPage5.html可以直接復制HTMLPage4.html)
將這段獲取數據的代碼修改為帶驗證身份進行跳轉的
原JS

$.get(‘/api/userInfo‘, function (data) {
            // 從API中
            // 得到返回的數據,更新 Knockout 模型並且綁定到頁面UI模板中                         
            viewModel.userinfos(data);
        });

修改後的js

$.ajax({
            url: ‘/api/userinfo‘,
            type: ‘GET‘,
            contentType: ‘application/json; charset=utf-8‘,
            statusCode: {
/*Created*/: function (data) {
                    viewModel.userinfos(data)
                }, 401: function (jqXHR, textStatus, errorThrown) {
                    window.location.href = ‘/home/login‘;
                }
            }
        });

Ok 到此,代碼就已近編寫完成了,來進行測試
測試第一步直接訪問 /api/userinfo

技術分享

測試第二步 訪問HTMLPage5.html

技術分享

達到了身份認證的要求
測試第三步 輸入用戶名密碼試試功能是否能用?
答案是肯定的.
技術分享

所以在MvcController中調用FormsAuthentication.SetAuthCookie方法後,MvcController和ApiController中的HttpContext.Current.Request.IsAuthenticated屬性都會為True了,達到了Mvc的Controller和Web Api的Controller都通過Asp.Net身份認證的目的。但是本文討論的是將Asp.Net項目設置為Forms認證方式後,能夠同時做MvcController和ApiController的身份認證,其它的認證方式並不能保證對Mvc的Controller和Web Api的Controller都同時生效。

Asp.net MVC使用FormsAuthentication,MVC和WEB API可以共享身份認證 (轉載)