|
|
|
Выборка данных с помощью хранимых процедур и Row Level Security
|
|||
|---|---|---|---|
|
#18+
Имеется MVC 4 приложение (Entity Framework 6.0, Code-First) Мой вопрос касается организации Row Level Security в базе данных MS SQL SERVER. Опишу возможные варианты процесса получения данных(представления) пользователем: Первый вариант: ADuser => Аутентификация(AccountController) => АтрибутАвторизации => Action(Controller) => UnitOfWork => GenericRepository => Метод в который передается пользователь и его группа в AD(row level security ID) => метод выполняет хранимую процедуру с подключение к БД с помощью SqlConnection и SqlDataReader => процедура возвращает вид на основании функции IS_MEMBER(Domain\Группа) Второй вариант: ADuser => Аутентификация(AccountController) => АтрибутАвторизации => Action(Controller) => UnitOfWork => GenericRepository => Метод в который передается группа пользователя в AD => метод тупо возвращает набор данных на основании группы (UnitOfWork.BlaBlaBlaRepository.Get().Where(x => x.AdGroupName==AdUserGroup)) Вопрос: Какой вариант стоит использовать? И вообще целесообразен ли такой подход к организации RLS? К тому же второй вариант совсем не RLS, а его жалкое подобие, но его удобнее использовать ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 25.11.2013, 14:48 |
|
||
|
|

start [/forum/moderation_log.php?user_name=%D0%9C%D0%B8%D1%85%D0%B0%D0%B8%D0%BB+%D0%9D%D0%B0%D1%81%D0%B5%D0%B4%D0%BA%D0%B8%D0%BD]: |
0ms |
get settings: |
10ms |
get forum list: |
12ms |
get settings: |
9ms |
get forum list: |
13ms |
get settings: |
10ms |
get forum list: |
15ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
57ms |
get topic data: |
11ms |
get forum data: |
3ms |
get page messages: |
30ms |
get tp. blocked users: |
2ms |
| others: | 4476ms |
| total: | 4654ms |

| 0 / 0 |

Извините, этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
... ля, ля, ля ...