Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Работа с библиотекой Apache Shiro 
:(
    Опции темы
ReFLeXive
Дата 9.3.2013, 21:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Здравствуйте!
Пишу приложение и необходимо реализовать авторизацию/аутентификацию пользователей. Решил использовать библиотеку Apache Shiro, т.к. предоставляемые возможности меня полностью устраивают.
Но возникла небольшая трудность и пока точно не знаю как ее разрешить. 
Приложение у меня клиент-серверное. Клиент на swing, устанавливается у пользователей. Сервер работает с jetty-embedded. Общение клиента и сервера происходит через http. На сервере есть один сервлет, который обрабатывает запрос пользователя, делает какое то действие (выборка из БД списка, обновление какой-либо сущности и т.п. ) и выдает ответ в виде json (к примеру список объектов для таблицы). Пользователи хранятся в embedded БД HSqlDB.
Итак, мне необходимо в клиенте сперва залогиниться, а затем делать проверку имеет ли данный пользователь право (имеет ли определенную роль), чтобы увидеть какой то элемент управления или сделать то или иное действие. 
В терминах Shiro все выглядит достаточно просто:

Код

Subject subject = SecurityUtils.getSubject();
subject.login();
...

button.setEnabled( subject.hasRole( "admin" ) );
// и далее в том же духе


Проблема в том, что вся информация о пользователях и их ролях будет хранится на сервере, к которому клиент обращается по http. Соответственно, я не могу понять, можно ли использовать какой-нибудь стандартный механизм Shiro, чтобы авторизовать пользователей на удаленном http-сервере? или необходимо реализовывать собственную логику в виде своего Realm'a?
Т.е. при вызове getSubject() мой клиентский код должен обратиться по http на сервер, проверить есть ли такой пользователь, проверить его пароль и вернуть ответ. 
Затем при каждом вызове hasRole("roleName") также необходимо подключаться к серверу, спрашивать такую ли роль имеет пользователь и возвращать ответ. (либо при логине сразу возвращать роль пользователя).

PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
javastic
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux, javastic.

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


 




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


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

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