Модераторы: Partizan, gambit
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Аутентификация и авторизация пользователей в веб-с 
:(
    Опции темы
Anyone
Дата 20.12.2011, 14:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 218
Регистрация: 1.6.2008

Репутация: нет
Всего: нет



Подскажите, пожалуйста, как лучше всего реализовать аутентификацию и авторизацию пользователей в asmx веб-сервисе на основе ролей?
Пользователи и роли удут храниться в БД.
Также интересует возможность регистрироваться и управлять своим профилем.
Решил использовать Membership со своим MembershipProvider.
Вот метод Login():
Код

[WebMethod]
public bool Login(string userName, string password)
{
    LogHelper.Log.Debug("Call WebBasedMnemonicWS.WebBasedMnemonicWebService.Login()");
    var toReturn = Membership.ValidateUs er(userName, password);
    LogHelper.Log.Debug("Membership.Name=" + Membership.GetUser().UserName));
    return toReturn;
}


У меня Membership.GetUser().UserName возвращает пустую строчку.
Тестовый MembershipProvider:
Код

class WbmMembershipProvider: MembershipProvider 
{
    public override MembershipUser GetUser(string username, bool userIsOnline)
    {
        return new MembershipUser("CustomMembershipProvider", username, 1, "", "", "", false, false, DateTime.Now, DateTime.Now, DateTime.Now, DateTime.Now, DateTime.Now);
    }
    public override bool ValidateUser(string username, string password)
    {
        return username == password;
    }
}

Почему я не вижу текущего пользователя?
Как определить метод Logout?
Спасибо.  
PM MAIL   Вверх
jonie
Дата 22.12.2011, 21:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 5613
Регистрация: 21.8.2005
Где: Владимир

Репутация: 22
Всего: 118



вам надо будет делать два сервиса: один безопасный (закрытый паролем и логином) второй для действий регистрационного характера.
В WCF это уже сделано за вас (Windows Communication Foundation Authentication see http://msdn.microsoft.com/en-us/library/bb386582.aspx), а вот в старых наврядли.

Поясняю: старые сервисы это сервисы на основе инфраструктуры asp.net. Авторизация там соотвественно тоже ихняя и может использовать (зависит от настроек) либо cookie либо что-то типа того (обычно куки, используя Forms Authentification).
Соотвественно нужен будет сервис (незащищенный, разруливается в web.config) который будет уметь вызывать методы MembershipProvider-а (типа ValidateUser), и если всё окей эти самые хитрые куки ставить\снимать используя методы что ниже (подробнее http://support.microsoft.com/kb/301240)

Код

                //perform asp.net auth if needed
                    FormsAuthenticationTicket authTicket = new FormsAuthenticationTicket(1, // version
                                                                                         dbUser.UserName, // user name
                                                                                         DateTime.Now, // creation
                                                                                         DateTime.Now.AddHours(12),// Expiration
                                                                                         credential.IsPersistent,// Persistent (remember me)
                                                                                         string.Empty); // User data

                    string encryptedTicket = FormsAuthentication.Encrypt(authTicket);
                    HttpCookie authCookie = new HttpCookie(FormsAuthentication.FormsCookieName, encryptedTicket);
                    HttpContext.Current.Response.Cookies.Add(authCookie);


///logout (самый "крутой логаут") ------------------------------------------------------------------

            FormsAuthentication.SignOut();
            HttpContext.Current.Session.Abandon();
            
            // clear authentication cookie
            HttpCookie cookie1 = new HttpCookie(FormsAuthentication.FormsCookieName, "");
            cookie1.Expires = DateTime.Now.AddYears(-1);
            HttpContext.Current.Response.Cookies.Add(cookie1);

            // clear session cookie
            HttpCookie cookie2 = new HttpCookie("ASP.NET_SessionId", "");
            cookie2.Expires = DateTime.Now.AddYears(-1);
            HttpContext.Current.Response.Cookies.Add(cookie2);


юзерную информацию на авторизированном сервисе вы сможете получить используя User.Identity


--------------------
Что-то не поняли? -> Напейтесь до зеленых человечков... эта сверхцивилизация Вам поможет...
PM MAIL Jabber   Вверх
Anyone
Дата 23.12.2011, 11:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 218
Регистрация: 1.6.2008

Репутация: нет
Всего: нет



Цитата(jonie @  22.12.2011,  21:37 Найти цитируемый пост)
вам надо будет делать два сервиса: один безопасный (закрытый паролем и логином) второй для действий регистрационного характера.

Сомневаюсь что такое решение удовлетворит заказчика, нужен один сервис
Цитата(jonie @  22.12.2011,  21:37 Найти цитируемый пост)
В WCF это уже сделано за вас 

Может тогда лучше использовать не asmx Веб-сервис, а WCF?
Но мне нужно будет обращаться к сервису из javascript, не знаю как передавать данные в формате json.

Спасибо за ответ.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Прежде чем создать тему, посмотрите сюда:
mr.DUDA
THandle

Используйте теги [code=csharp][/code] для подсветки кода. Используйтe чекбокс "транслит" если у Вас нет русских шрифтов.
Что делать если Вам помогли, но отблагодарить помощника плюсом в репутацию Вы не можете(не хватает сообщений)? Пишите сюда, или отправляйте репорт. Поставим :)
Так же не забывайте отмечать свой вопрос решенным, если он таковым является :)


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, mr.DUDA, THandle.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Общие вопросы по .NET и C# | Следующая тема »


 




[ Время генерации скрипта: 0.0789 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.