Aby połączyć się z tabelami niestandardowymi w celu uwierzytelnienia, musisz utworzyć dostawcę członkostwa. MSDN posiada dokumentację na ten temat. Możesz również obejrzeć wideo na ten temat w ASP.NET. Oto linki.
- http://msdn. microsoft.com/en-us/library/f1kyba5e(v=vs.100).aspx
- http://www.asp.net/web-forms/videos/how-do-i/how-do-i-create-a-custom-membership-provider
Główną metodą walidacji będzie metoda ValidateUser, zastąpisz tę metodę, aby zapewnić uwierzytelnianie.
public sealed class CustomMembershipProvider : MembershipProvider
{
// implement other methods
public override bool ValidateUser(string username, string password)
{
try
{
var user = // GET USER OBJECT HERE
if (user != null)
{
string name = // set username
// Set your forms authentication ticket
FormsAuthenticationTicket ticket = new FormsAuthenticationTicket(1, user.ID.ToString(), DateTime.Now, DateTime.Now.AddMinutes(30), false, name, FormsAuthentication.FormsCookiePath);
HttpCookie authCookie = new HttpCookie(FormsAuthentication.FormsCookieName, FormsAuthentication.Encrypt(ticket));
HttpContext.Current.Response.Cookies.Add(authCookie);
return true;
}
}
catch
{
}
return false;
}
// Other implementations
}
Jeśli masz role w swojej aplikacji, możesz również zaimplementować niestandardowego dostawcę ról:
http://msdn.microsoft.com/ en-us/biblioteka/8fw7xh74(v=vs.100).aspx