私は Visual Studio で遊んでいて、認証部分 (デフォルトのもの) を含む MVC4 アプリケーション プロジェクトを作成しました。一方、ユーザー(ログイン、パスワード)テーブルを含むSQLサーバーによって管理されるデータベースに好きなWebサービス(WCF)があります。「デフォルト」の認証を、Web サービスによって提供されるデータにリンクされた認証に変更したいと考えています。明確にするために、リモートデータベースにクエリを実行してログイン/パスワードの正確性を確認する方法は?
何が行われたかについてのアイデアを提供するために: AccountController :
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public ActionResult Login(LoginModel model, string returnUrl)
{
if (ModelState.IsValid && WebSecurity.Login(model.UserName, model.Password, persistCookie: model.RememberMe))
{
return RedirectToLocal(returnUrl);
}
ModelState.AddModelError("", "Login or password not correct");
return View(model);
}
ログインモデル:
public class LoginModel
{
[Required]
[Display(Name = "User name")]
public string UserName { get; set; }
[Required]
[DataType(DataType.Password)]
[Display(Name = "Password")]
public string Password { get; set; }
}
ログインフォーム :
@using (Html.BeginForm(new { ReturnUrl = ViewBag.ReturnUrl })) {
@Html.AntiForgeryToken()
@Html.ValidationSummary(true)
<fieldset>
<ol>
<li>
@Html.LabelFor(m => m.UserName)
@Html.TextBoxFor(m => m.UserName)
@Html.ValidationMessageFor(m => m.UserName)
</li>
<li>
@Html.LabelFor(m => m.Password)
@Html.PasswordFor(m => m.Password)
@Html.ValidationMessageFor(m => m.Password)
</li>
</ol>
<input type="submit" value="Login" />
私はそれを適応させることができますか、それともそのような認証を行う別の方法はありますか? ありがとう !編集 - - - - - - - - - -
私はそれをやろうとしましたが、問題があります。ログイン機能の「新しいバージョン」は次のとおりです。
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public ActionResult Login(LoginModel model, string returnUrl)
{
try
{
var context = new MyEntity(new Uri("http://localhost:12345/MyWCF.svc/"));
var usr = from user in context.PERSON
where user.LOGIN == model.UserName && user.PASSWORD == model.Password
select user;
List<PERSON> lpers = usr.ToList();
int nbRes = lpers.Count();
//if (ModelState.IsValid && WebSecurity.Login(model.UserName, model.Password, persistCookie: model.RememberMe))
if (ModelState.IsValid && nbRes ==1)
{
return RedirectToLocal(returnUrl);
}
}
catch (DataServiceQueryException ex)
{
ModelState.AddModelError("", "Erreur : "+ex.ToString());
}
ModelState.AddModelError("", "Wrong username or pwd");
return View(model);
}
しかし、私は次のエラーがあります:
System.Data.Services.Client.DataServiceQueryException: Une erreur s'est produite lors du traitement de cette requête. ---> System.Data.Services.Client.DataServiceClientException: <?xml version="1.0" encoding="utf-8" standalone="yes"?><error xmlns="http://schemas.microsoft.com/ado/2007/08/dataservices/metadata"><code></code><message xml:lang="fr-FR">Une erreur s'est produite lors du traitement de cette requête.</message></error>
à System.Data.Services.Client.QueryResult.ExecuteQuery(DataServiceContext context)
à System.Data.Services.Client.DataServiceRequest.Execute[TElement](DataServiceContext context, QueryComponents queryComponents)
--- Fin de la trace de la pile d'exception interne ---
à System.Data.Services.Client.DataServiceRequest.Execute[TElement](DataServiceContext context, QueryComponents queryComponents)
à System.Data.Services.Client.DataServiceQuery`1.Execute()
à System.Data.Services.Client.DataServiceQuery`1.GetEnumerator()
à System.Collections.Generic.List`1..ctor(IEnumerable`1 collection)
à System.Linq.Enumerable.ToList[TSource](IEnumerable`1 source)
à MyApp.Controllers.AccountController.Login(LoginModel model, String returnUrl) dans d:\....\Documents\Visual Studio 2012\Projects\MyProg\MyWS\Controllers\AccountController.cs:ligne 45
リーニュ 45 の場所
List<SteelcaseWebPortal.SteelcaseService.PERSON> lpers = usr.ToList();
リクエストに何か問題がありましたか? ありがとう !