MaterStudiorum.ru - домашняя страничка студента.
Минимум рекламы - максимум информации.


Авиация и космонавтика
Административное право
Арбитражный процесс
Архитектура
Астрология
Астрономия
Банковское дело
Безопасность жизнедеятельности
Биографии
Биология
Биология и химия
Биржевое дело
Ботаника и сельское хоз-во
Бухгалтерский учет и аудит
Валютные отношения
Ветеринария
Военная кафедра
География
Геодезия
Геология
Геополитика
Государство и право
Гражданское право и процесс
Делопроизводство
Деньги и кредит
Естествознание
Журналистика
Зоология
Издательское дело и полиграфия
Инвестиции
Иностранный язык
Информатика
Информатика, программирование
Исторические личности
История
История техники
Кибернетика
Коммуникации и связь
Компьютерные науки
Косметология
Краткое содержание произведений
Криминалистика
Криминология
Криптология
Кулинария
Культура и искусство
Культурология
Литература и русский язык
Литература(зарубежная)
Логика
Логистика
Маркетинг
Математика
Медицина, здоровье
Медицинские науки
Международное публичное право
Международное частное право
Международные отношения
Менеджмент
Металлургия
Москвоведение
Музыка
Муниципальное право
Налоги, налогообложение
Наука и техника
Начертательная геометрия
Новейшая история, политология
Оккультизм и уфология
Остальные рефераты
Педагогика
Полиграфия
Политология
Право
Право, юриспруденция
Предпринимательство
Промышленность, производство
Психология
Психология, педагогика
Радиоэлектроника
Разное
Реклама
Религия и мифология
Риторика
Сексология
Социология
Статистика
Страхование
Строительные науки
Строительство
Схемотехника
Таможенная система
Теория государства и права
Теория организации
Теплотехника
Технология
Товароведение
Транспорт
Трудовое право
Туризм
Уголовное право и процесс
Управление
Управленческие науки
Физика
Физкультура и спорт
Философия
Финансовые науки
Финансы
Фотография
Химия
Хозяйственное право
Цифровые устройства
Экологическое право
Экология
Экономика
Экономико-математическое моделирование
Экономическая география
Экономическая теория
Эргономика
Этика
Юриспруденция
Языковедение
Языкознание, филология
    Начало -> Информатика, программирование -> Аутентификация пользователей с помощью ASP

Название:Аутентификация пользователей с помощью ASP
Просмотров:57
Раздел:Информатика, программирование
Ссылка:Скачать(5 KB)
Описание:В этой статье будет рассказано, как зарегистрированным пользователям разрешить доступ к некой секретной asp странице, а посторонним нет.

Университетская электронная библиотека.
www.infoliolib.info

Часть полного текста документа:

Аутентификация пользователей с помощью ASP Христофоров Юрий
    В этой статье будет рассказано, как зарегистрированным пользователям разрешить доступ к некой секретной asp странице, а посторонним нет.
    Постановка задачи: Есть база данных Access 97, в которой хранятся имена зарегистрированных пользователей и их пароли, и есть некая секретная страница, доступ к которой должны иметь только пользователи, занесенные в БД. Пароли в БД требуется хранить в зашифрованном виде. Преимущество такого подхода в том, что поля базы данных, содержащие пароли, не содержат реальных значений и их нельзя использовать при входе в систему.
    Для работы нам понадобится ActiveX компонент Ecrypt, который Вы можете взять на этом сайте в разделе ActiveX.
    Движемся по шагам:
    1. Создайте БД в Access. Имя таблицы - TUSERS. Описание полей:
    n_id - Счетчик (Primary Key)
    s_name - Текстовый
    s_password - Текстовый
    Затем создайте DSN для этой БД. При работе с WindowsNT (2000) необходимо создать System DSN, а при работе с Windows95-98 можно создать и User DSN. Дайте DSN имя reg.
    2. Напишем ActiveX DLL Auth на Visual Basic 6, которая будет выполнять основную работу. Запустите Visual Basic 6 и в окне New Project выберем ActiveX DLL. Переименуем имя проекта на Auth, а имя класса на Security. Теперь надо подключить необходимые библиотеки: выбираем Project ->References...
    Подключаем библиотеки Microsoft ActiveX Data Objects 2.1 Library и ECrypt 1.0 Type Library (см. выше).
    3. Далее набираем следующий код:
    Option Explicit
    Private cn As ADODB.Connection
    Private rs As ADODB.Recordset
    Private sName As String 'Имя пользователя
    Private sPasswd As String 'Пароль
    Private sError As String
    Private sResult As Integer 'Результат
    Public Property Get Result() As Integer
    Result = sResult
    End Property
    Public Property Let InitName(ByVal Name As String)
    sName = Name
    End Property
    Public Property Let InitPassword(ByVal Passwd As String)
    sPasswd = Passwd
    End Property
    Private Sub Class_Initialize()
    sError = ""
    Set cn = New ADODB.Connection
    cn.Open "DSN=reg" 'Установим соединение
    Set rs = New ADODB.Recordset
    End Sub
    Private Sub Class_Terminate()
    Set rs = Nothing
    Set cn = Nothing
    End Sub
    'Регистрирует пользователей
    Public Sub Register()
    On Error GoTo Er
    rs.Open "SELECT N_ID FROM TUSERS WHERE S_NAME='" & sName & "'", cn, 1
    'Если пользователь с таким именем уже есть, то
    If rs.RecordCount 0 Then
    sResult = 1 'Возвращаем результат
    rs.Close
    cn.Close
    Exit Sub 'Выход
    End If
    Dim crypt_obj As ECRYPTLib.Cryptor
    Dim crypt_pass As String
    Set crypt_obj = New ECRYPTLib.Cryptor
    crypt_obj.Key = "Visual+Basic+6 !" 'Ключ шифрования
    crypt_obj.Text = sPasswd 'Пароль
    crypt_pass = crypt_obj.coder() 'Шифруем
    'Добавляем новую запись
    cn.Execute "INSERT INTO TUSERS (S_NAME,S_PASSWORD) VALUES ('" & Replace(sName, "'", "''") & _
    "','" & Replace(crypt_pass, "'", "''") & "')"
    sResult = 0 'Все прошло успешно
    rs.Close
    cn.Close
    Exit Sub
    Er:
    sResult = 2 'Непредвиденная ошибка
    End Sub
    'Проверка пользователей
    Public Sub Check()
    On Error GoTo Er
    rs.Open "SELECT S_NAME,S_PASSWORD FROM TUSERS WHERE S_NAME='" & sName & "'", cn, 1
    'Если нет пользователя с таким именем
    If rs.RecordCount = 0 Then
    sResult = 1
    rs.Close
    cn.Close
    Exit Sub
    End If
    Dim tmp As String
    tmp = rs.Fields("S_PASSWORD")
    Dim uncrypt_obj As ECRYPTLib.Cryptor
    Dim uncrypt_pass As String
    Set uncrypt_obj = New ECRYPTLib.Cryptor
    uncrypt_obj.Key = "Visual+Basic+6 !"
    uncrypt_obj.Text = tmp
    'Расшифровываем пароль из БД
    uncrypt_pass = uncrypt_obj.decoder()
    'Если они не совпадают
    If uncrypt_pass sPasswd Then
    sResult = 3
    rs.Close
    cn.Close
    Exit Sub
    End If
    sResult = 0 'Все нормально
    rs.Close
    cn.Close
    Exit Sub
    Er:
    sResult = 2 'Непредвиденная ошибка
    End Sub
    Компилируем проект и получаем Auth.dll.
    4. ............




Нет комментариев.



Оставить комментарий:

Ваше Имя:
Email:
Антибот:  
Ваш комментарий:  



Похожие работы:

Название:Private banking в России
Просмотров:352
Описание: PRIVATE BANKING В РОССИИ Перевод понятия "private banking" достаточно прост: "индивидуальное обслуживание банком состоятельных частных лиц". Однако в обиходе российские банки, предоставляющие данный вид услуг с

Название:Private sector and human-resource development in Georgia
Просмотров:316
Описание: TBILISI, GEORGIA             Private Sector and Human-resource Development in Georgia Author: Lasha Martashvili E-mail: lmg@bk.ru    (18.02.2004)             TABLE OF CONTENTS 1.      Government Policies. 5 1.1        Governmen

Название:Private label
Просмотров:360
Описание:Private label- что это такое? Потребитель и Private Label. Мировая практика. Производители. Условия успеха.

Название:Private label: золотое дно?
Просмотров:350
Описание:Private label - Что это такое ? Потребитель и Private Label. Мировая практика. В России. Производители.

 
     

Вечно с вами © MaterStudiorum.ru