Чат на ASP: от простого к сложному. |
Ну что ж, чат у нас, можно сказать, уже работает. Существует окно ввода и окно с фразами, можно писать в первом, что душа пожелает, и наблюдать начертанное во втором. Ну просто верх творения ума человеческого. Но что-то как-то не совсем...
Для начала создадим "неполную" авторизацию пользователя. Для этого создаем стартовую страницу чата (если таковой еще нет) примерно следующим образом:
<html> <body> <form method=post action=chat.asp name="mForm" target="_top"> имя (Login): <input type=text name="userName" size=12> <input type=submit value=" Ok "> </form> </body> </html>
Далее мастерим сам chat.asp:
<frameset rows="*,68"> <frame src="chatbody.asp" name=bod scrolling="yes"> <frame src="chatinput.asp" name=menu scrolling="no"> </frameset>
Здесь мы, соответственно, создали два фрейма : chatbody.asp - фрейм с фразами, chatinput.asp - фрейм с полем ввода.
Теперь добавим немного кода в chat.asp и создадим ту самую "неполную" авторизацию:
<% Session("Login")=request("userName") if Session("Login") = "" then Session("Login") = "некто" end if if Session("dooropen")=0 then Session("dooropen")=1 dim NewMess() Redim NewMess(20) messArray=Application("MessageArray") for i=0 to 19 NewMess(i+1) = messArray(i) next NewMess(0)=Session("Login") & "снова с нами..." Application.Lock Application("MessageArray")=NewMess Application.UnLock end if %>
И что же мы сделали? Всего навсего зверски выпытали у входящего пользователя его имя и решили его запомнить хорошенько, заодно предупредив находящихся уже в чате о его прибытии:
Для чего здесь служит Session-переменная dooropen? А вы попробуйте ее не использовать? И тогда при каждом обновлении родительского окна, тоесть chat.asp будете получать событие входа нового пользователя. Пока вся система еще только лишь во всеуслышанье извещает о сим факте - ничего ужастного в этом, в принципе, и нет, а что будет дальше? А вот при таком простом подходе один раз занесем значение единицы в Session-переменную и, пока не будет уничтожена сессия, dooropen будет его хранить, не давая тем самым ложных входов.
Стоит заметить, что в файле global.asa следует все же создать процедуру Session_OnStart и указать в ней Session("dooropen") = 0, я бы еще посоветовал тут же конкретизировать таймауты сессии ( Session.Timeout = 10 ), но сие не к спеху.
Ну, пожайлуй, для начала хватит. Разве что свериться кодами с chatinput.asp (chatbody.asp, отвечающего за вывод фраз на экран пользователя) мы не планировали изменять. У вас в chatinput.asp должно быть примерно следующее:
<form method=post action=chatinput.asp target=_self name=mForm> <Select Name=Type> <Option Value=Phrase>сказать</option> <Option Value=Action>сделать</option> </Select> <input type=text size=39 maxlength=255 name=mess> <input type=submit value=" Ok "> </form> <% If (Request("mess") <>"" then Messa = Session("Login") & ": " & Request("mess") if Request("Type")="Action" then Messa="<i>" & Messa & "</i>" end if dim NewMess() Redim NewMess(20) messArray=Application("MessageArray") for i=0 to 19 NewMess(i+1) = messArray(i) next NewMess(0)= Messa Application.Lock Application("MessageArray")=NewMess Application.UnLock end if %>
Надеюсь, что данный код не столь уж и непонятен :-).
Ну что ж, в нашем чате уже можно даже разобраться, кто что пишет (если вы не забыли, в последний раз мы создавали "неполную" авторизацию пользователя). А теперь представим такую картину. Заходим в чат. Основное окно пестрит фразами. Все просто замечательно... За некоторым исключением. А кто на данный момент находится в чате? Можете ответить на такой каверзный вопрос? Те, кто пишет? А кто не пишет? Может половина курить пошла?..
К чему это я? Да к тому, что пора создавать список пользователей, находящихся на нашем чат-сервере, и отображать их список в отдельном окне.
В первую очередь нам нужно создать еще один общедоступный массив под этот самый список пользователей (по типу Application("MessageArray")). Для этого изменим файл global.asa:
Sub Application_OnStart dim MyMessArray() Redim MyMessArray(20) Application("MessageArray")=MyMessArray dim UserArray() Redim UserArray(50) Application("UsersArray")=UserArray End Sub
Мы с вами только что добавили еще один массив UsersArray размерностью 50. Почему именно 50? Хм, можете сделать и 100. Но вряд ли у вас одновременно будут находиться 100 пользователей, а вот резвость своему серверу вы подобными "щедрыми" объявлениями поубавите.
Дальше нам нужно изменить наш "родительский" chat.asp:
<frameset rows="*,68"> <frameset cols="*,190" border=0> <frame src="chatbody.asp" name=bod scrolling="yes"> <frame src="chatuser.asp" name=usr scrolling="yes"> </frameset> <frame src="chatinput.asp" name=menu scrolling="no"> </frameset> <% Session("Login")=request("userName") if Session("Login") = "" then Session("Login") = "некто" end if if Session("dooropen")=0 then Session("dooropen")=1 dim NewMess() Redim NewMess(20) messArray=Application("MessageArray") NewUser=Application("UsersArray") for i=0 to 19 NewMess(i+1) = messArray(i) next for i=0 to 49 if NewUser(i)="" then NewUser(i)=Session("login") i=99 end if next NewMess(0)=Session("Login") & "снова с нами..." Application.Lock Application("MessageArray")=NewMess Application("UsersArray")=NewUser Application.UnLock end if %>
Итак, что мы сделали?
Теперь давайте займемся самим списком в том виде, в каком его увидят пользователи, т.е. создадим chatuser.asp:
<html> <meta http-equiv="Refresh" content="45"> <meta http-equiv="Content-Type" content="text/html; charset=windows-1251"> <body> <% User=Application("UsersArray") for i=0 to 49 if User(i)<>"" then Response.write User(i) & "<br>" end if next %> </body> </html>
Ну вот почти и все. За исключением, разве того, что через некоторое время (как я вас не убеждал в обратном) вам не хватит 50 пользователей, отведенных в списке UsersArray... :-)). Для устранения сего недоразумения следует еще раз обратиться к файлу global.asa и добавить туда (наконец-то) процедуру Stssion_OnEnd:
Sub Session_OnEnd users=Application("UsersArray") mess=Application("MessageArray") for i=0 to 49 if users(i)=Sessoin("Login") then users(i) ="" dim NewMess() Redim NewMess(20) for i=0 to 19 NewMess(i+1) = messArray(i) next NewMess(0)=Session("Login") & "покинул нас..." Application.Lock Application("MessageArray")=NewMess Application("UsersArray")=users Application.UnLock i=99 end if next End sub
Тем самым мы после прекращения сессии удалили ушедшего пользователя из списка и записали в общедоступный массив с фразами сообщение о его выходе.
Источник: www.relib.com
<Назад>
<Sub
Main> <Download Centre> <Guest Book & Forum> <Contact
Info> <Add Links>
![]() |
|