手把手教你做网站,手把手教你DIY网站论坛




<%
set rs=nothing
conn.close
set conn=nothing
%>
(3)打造qBaord.asp页面:
<%
boardid=request("boardid") ''取出由上个页面传递过来的看板ID号
Set conn = Server.CreateObject("ADODB.Connection")
conn.Open "driver={Microsoft AccessDriver (*.mdb)};dbq=" & Server.MapPath("bbssystem.mdb")
Set cmd = Server.CreateObject("ADODB.Command")
Set cmd.ActiveConnection = conn
cmd.CommandText = "主题列表"
ReDim param(0) //注:声明参数数组
param(0) = CLng(boardid)//注:CLng 不可忽略
Set rs = cmd.Execute( ,param )
%>


主题列表



�%=rs("看板�")%>板主题列� �/h1>

主题�/td>
文章数</td>

<%
do
topicid=rs("id")
topicname=rs("标题")
sum=rs("文章�")
response.write " <a href=qtopic.asp?topicid=" & topicid& "&boardname=" & boardname& ">" & topicname &" "
response.write " " &sum & "
"
rs.movenext
loop until rs.eof
%>



注:qBoard.asp列出了某个版面下的所有的主题,在点击了主题名称后就会进入相应的主题文章列表。这个列表的是由qTopic.asp这个ASP脚本来实现的。Qtopic.asp的程序代码在本质上几乎和qBoard.asp没有区别,只是在各自的细节上有所区别,这儿也不打算再多讲了�
热门推荐� DreamweaverMX实现网站批量更新   DW MX 2004的电子相册制�

手把手教你做网站,手把手教你DIY网站论坛
�4)在点击了文章列表中的文章标题后,会进入文章内容浏览页article.asp�
<%
articleid=request("articleid")
Set conn = Server.CreateObject("ADODB.Connection")
conn.Open "driver={Microsoft AccessDriver(*.mdb)};dbq=" & Server.MapPath("bbssystem.mdb")
Set cmd = Server.CreateObject("ADODB.Command")
Set cmd.ActiveConnection = conn
cmd.CommandText = "按id查询文章"
ReDim param(0) '' 声明
param(0) = CLng(articleid) '' Cint 不可忽略
Set rs = cmd.Execute( ,param )
author=rs("作者id")
title=rs("标题")
data=rs("日期")
rate=rs("推荐�")
boardid=rs("看板id")
topicid=rs("主题id")
boardname=rs("看板�")
topicname=rs("主题�")
content=rs("内容")
content=replace(content,vbCrlf,"�/p>")
content="" & content& "
"
注:这是一个要注意的地方,在内容字段中包含的是备忘类型的文本,其中可以包含换行字符。在HTML的显示中,必须要把换行字符(也就是VBCrlf常数)换成HTML的段落符号。这样在段落与段落的衔接处,就不会打乱原来输入时的格式。如果要设计的更好些,可以通过CSS来复位义标签,设定其test-indent属性,就可以实现每段开头空格了�
�5)把点击次数加一
sql="Update 内容� Set 点击次数=点击次数+1Where ID=" & articleid
conn.execute sql
注:这儿有一个SQL语句,没当页面被显示的时候,会把相应的表中点击次数字段加一,这样就能够对文章浏览的次数做出统计,并可按顺序排名。在执行条语句的时候,我发现:本来在SQL语句中,嵌入的变量名应该加上单引号以与区别,但在这儿的articleid变量上我并没有加单引号,居然也能够通过,而我以前这样写从来都是会引发错误的,不知是不是由于新版本的ADO的缘故�
set cmd=nothing
%>


Untitled Document




作者:<a href="qauthor.asp?author=<%=author%>"><%=author%> 发表日期:<%=data%>
看板:<a href="qboard.asp?boardid=<%=boardid%>"><%=boardname%>板主推荐�#rate#�/font>

标题:<%=title%>
主题�"> <%=topicname%>




文章内容�

<%response.writecontent%>





<td width="65%">关于此话题<a href="submit.asp?topicid=<%=topicid%>&boardid=�%=boardid%>">发表评论�/td>
这个连接允许网友对此评论的话题发表自己的见解,这是下一个模块要讲的内容了,这儿且按下不表�





<%
set rs=nothing
conn.close
set conn=nothing
%>
到此,文章显示部分也完成了。下面再来看看文章发表部分是如何实现的�
热门推荐� DreamweaverMX实现网站批量更新   DW MX 2004的电子相册制�

手把手教你做网站,手把手教你DIY网站论坛
3、构建文章发表部�
文章发表模块只有两个页面,一个是前面提到的用来提供输入窗体的submit.asp,还有一个是用来处理窗体输入的subresult.asp。前面的那个页面很简单,基本上就是一个HTML窗体,没有什么好讲的,下面来看看subresult.asp的内容:


发表文章



<%
author=request("author")
password=request("password")
topicid=request("topicid")
boardid=request("boardid")
content=request("content")
title=request("title")
注:这一段取出在submit.asp中提交的表但内容,放在相应的变量中�


发表文章



<%
author=request("author")
password=request("password")
topicid=request("topicid")
boardid=request("boardid")
content=request("content")
title=request("title")
�1)查询作者是否已存在
cmd.CommandText = "select * from 作者表where id=''" & author &"''"
Set rs = cmd.Execute()
�2)检查权�
cmd.CommandText = "select * from 作者表where id=''" & author &"''"
Set rs = cmd.Execute()
注:这一段是对作者权限进行检查,对于帐号不存在或者密码错误做出相应的错误处理。在这儿可以看到response.end的用法,它是用来结束当前ASP脚本。结合if语句,可以对程序中的预期错误进行处理。在一个好的WEB应用中,错误处理是必不可少的�
�3)将资料中的单引号改成两个单引号,并且在前后加上单引�
Function SqlStr( data )
SqlStr = "''" & Replace( data,"''", "''''" ) & "''"
End Function
''写入数据�
sql = "Insert Into 内容� (看板id,主题id,作者id,标题,内容)Values( "
sql = sql & SqlStr(topicid) & ","
sql = sql & SqlStr(boardid) & ","
sql = sql & SqlStr(author) & ","
sql = sql & SqlStr(title) & ","
sql = sql & SqlStr(content) & ")"
conn.Execute sql
%>

文章已经被发送到数据库,当板主审阅后就可以看到了<h2>


到这儿,文章已经被保存在数据库中了。但是,它并不能够立刻被显示出来,还需要版主的认可才行。下面,就来看看论坛的管理部分的内容�
热门推荐� DreamweaverMX实现网站批量更新   DW MX 2004的电子相册制�

手把手教你做网站,手把手教你DIY网站论坛
4、论坛的管理部分
这儿是我们这个论坛的核心之所在,但它实现起来也没有什么特别的地方。还是那些老东西:窗体处理,数据库查询,在用ASP把他们有机的结合起来。当进入了文章审阅模式(前面提到的板务处理)之后,最为首要的内容,应该是对版主的身份进行验证了。下面来看看版主登陆页面�
<%
boardid=request("boardid")
(注:boardid是由进入这个页面的连接所传递过来的,是要进行板务处理的看板的ID。通过它才能知道处理的是那个板的板务。)
Set conn = erver.CreateObject("ADODB.Connection")
conn.Open "driver={Microsoft AccessDriver (*.mdb)};dbq=" & Server.MapPath("bbssystem.mdb")
Set cmd = Server.CreateObject("ADODB.Command")
Set cmd.ActiveConnection = conn
cmd.CommandText = "板主密码查询"
ReDim param(0)
param(0) = CLng(boardid) //注:CLng 不可忽略
Set rs = cmd.Execute( ,param )
boardmanager=rs("板主")
set cmd=nothing
%>


Untitled Document



只有板主<%=boardmanager%>才能够进入这个地方</p>
请输入验证密�, 并且为了保持身份验证,请打开浏览器的Cookies。</p>


>


注:这个页面仅仅是用来登陆用的,它得到斑竹输入的密码后,并不能进行验证,而是将验证的工作放到下一个页面中进行。实际上,密码输入和验证的工作是可以放在一个页面中完成的,只不过程序代码的结构安排上有点麻烦�


<%
set rs=nothing
conn.close
set conn=nothing
%>
现在得到了版主ID和输入的密码,下面就是进行验证的工作managerloginrest.asp了,它接受上面那个文件中窗体的内容,并进行相关处理:
<%
response.buffer=true
注:把缓冲区设置为允许使用。这一条一般来说,是应该加在每个ASP页面的首部的,这样能够提高ASP页面的性能。在打开了缓冲区后,ASP中还有一些相应的特殊用法,在后面会提及�
boardid=request("boardid")
password=request("password")
Set conn = Server.CreateObject("ADODB.Connection")
conn.Open "driver={Microsoft AccessDriver (*.mdb)};dbq=" & Server.MapPath("bbssystem.mdb")
Set cmd = Server.CreateObject("ADODB.Command")
Set cmd.ActiveConnection = conn
cmd.CommandText = "板主密码查询"
ReDim param(0) '' 声明
param(0) = CLng(boardid)//注:CLng不可忽略
Set rs = cmd.Execute( ,param )
boardmanager=rs("板主")
if password<> rs("密码")then %>


身份验证



密码错误


<%
else
session("beenthere")=boarded
注:使用Session来保持对版主的身份验证,这必须要求客户端浏览器的cookie被打开了。因为Session是通过cookie来实现的。在这儿,把看板ID赋给Session变量beenthere,表明版主主已经通过了身份验证。在后面的每个版务处理的页面中,都要检查beenthere是否和相应的看版ID相符�
url="boardmanager.asp?boardid="& boardid
response.redirect url
补充:初学ASP的时候总是为response.redirect这个方法感到困惑,屡用不爽,现在我来告诉你一些技巧。使用它之前,必须通过response.buffer=true来让ASP页面使用缓冲区。这时,在ASP被解释成HTML程序代码之前,它是放在缓冲区中的,而不直接被发送的客户端浏览器。还有一个必须要知道的是:在使用response.redirect之前,是不能有任何实际的HTML程序代码被发送到客户端浏览器的,否则就会出错。当然也有变通的方法,如果在response.redirect之前已经有HTML程序代码被解释出来,可以用response.clear方法来清除缓冲区,然后就可以使用它来进行复位向了�
end if
%>
注:下面就是在上面身份验证通过后复位向的目标:boardmanager.asp。它将列出了所有别有被处理的文章�
<%
boardid=request("boardid")
if session("beenthere")<>boardidthen response.redirect "forums.asp"
注:这就是检验版主身份的地方,因为前面已经通过cookie在斑竹的浏览器中作了标记,现在我们就能够通过seesion来辨认版主的身份了。如果标示不符,就会通过response.redirect返回到最开始的登陆页面。如果版主浏览器的cookie没有打开,那么seesion�"beenthere")的值会为空,同样也无法进入这个页面�
热门推荐� DreamweaverMX实现网站批量更新   DW MX 2004的电子相册制�

手把手教你做网站,手把手教你DIY网站论坛

&nbsp;&nbsp;
添加图片&nbsp;&nbsp;
删除该页
&nbsp;&nbsp;使用所见及所得编辑器
&nbsp;&nbsp; 添加HTML标签











该页标题: