Реферат по предмету "Программирование"


Аутентификация пользователей с помощью ASP

Аутентификация пользователей с помощью 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. Следующий шаг - это написание asp и htm страниц.

start.htm - страница с формой для ввода имени и пароля

Имя и пароль должны содержать только английские буквы
и символы !!!




Имя





Пароль











[Здесь можнозарегистрироваться]

check.asp - страница для проверки имени и пароля
(написана на VBScript)



nm =
Request.Form("user")

ps =
Request.Form("passwd")

Set obj =
CreateObject("Auth.Security")'Создаем объект нашей DLL

obj.InitName = nm

obj.InitPassword =
ps

obj.Check

res = obj.Result

If CInt(res) = 0
Then

Session("user") = "OK" 'Установим
сессионную переменную

'Перенаправим зарегистрир. пользователя на секретную
страницу...

Response.Redirect
"secret.asp"

End If

If CInt(res) =  2

Then Response.Write
"Ошибка базы данных!"

Response.End

End If

If CInt(res) =  1

Then Response.Write "Вы не
зарегистрированы!"

Response.End

End If

If CInt(res) =  3

Then Response.Write
"Пароль неверен!"

Response.End

End If

%>

security.asp - страница, проверяющая сессионную
переменную



If Session("user") "OK"
Then

'Если сессионная переменная неверна

Response.Write "Не зарегистрированный
пользователь !"

'Завершаем сценарий

Response.End

End If

%>

register.htm - страница для новых пользователей

Имя и пароль должны содержать только английские буквы
и символы !!!

Здесь можно зарегистрироваться...





Имя(англ.)



Пароль(англ.)













[На Loginстраницу]

register.asp - страница для занесения новых
пользователей в БД



nm =
Request.Form("user")

ps =
Request.Form("passwd")

Set obj =
CreateObject("Auth.Security")

obj.InitName = nm

obj.InitPassword =
ps

obj.Register

res = obj.Result

If CInt(res) = 

   0 ThenResponse.Write

"Регистрация прошла успешно !" Response.Write "Имя:"&

nm &
"" Response.Write "Пароль:" &ps

&
""
Response.Write"[Login]"

End If

If CInt(res) = 

2
ThenResponse.Write "Ошибка базы данных!"

Response.End

End If

If CInt(res) = 

1 ThenResponse.Write "Пользователь с
таким именем уже существует!"

Response.End

End If

%>

secret.asp - секретная страница







Вы попали сюда!

Это секретная страница !

Вот и все. Исходный файл проекта прилагается: auth.zip

Список литературы

Для подготовки данной работы были использованы
материалы с сайта http://www.activex.net.ru/


Не сдавайте скачаную работу преподавателю!
Данный реферат Вы можете использовать для подготовки курсовых проектов.

Поделись с друзьями, за репост + 100 мильонов к студенческой карме :

Пишем реферат самостоятельно:
! Как писать рефераты
Практические рекомендации по написанию студенческих рефератов.
! План реферата Краткий список разделов, отражающий структура и порядок работы над будующим рефератом.
! Введение реферата Вводная часть работы, в которой отражается цель и обозначается список задач.
! Заключение реферата В заключении подводятся итоги, описывается была ли достигнута поставленная цель, каковы результаты.
! Оформление рефератов Методические рекомендации по грамотному оформлению работы по ГОСТ.

Читайте также:
Виды рефератов Какими бывают рефераты по своему назначению и структуре.