|
大家在网上看到各种各样的ASP论坛是不是觉的做论坛很难呢,其实我们用简单的ASP语句就完全可以完成一个属于自己的论坛。下面我教大家如何用ASP来打造一个属于自己的论坛,自己的东西毕竟用起来爽吗。<br>
8 q3 e$ w/ P9 P% L" Q<br>
6 i( Y0 x3 K! R7 c/ y1 p同时,再复杂的论坛的写成也离不开下面的基本步骤,大家仔细看了。 <br>6 P4 Y7 z* y# @5 T: E( J, u/ d( {
<br>. f8 L+ j2 c& P' e
一、建立文件! <br>
- U& V+ A- b; D最简单的论坛也要有几个必要的文件,就是: <br>
; V6 e2 m7 {5 \; b9 v1 Z9 L- k<br>
* j. o/ N2 H) f6 A2 L1、数据库,用来储存发表的帖子!-------命名为:bbs.mdb <br>! Z% J% G3 u) g- o
<br>. w- j+ c" p7 n- n. r
2、有数据库就必须连接数据库,该文件用来连接数据库:----命名为:conn.asp <br>* i5 E4 \/ x, I& [3 X6 u
<br>7 s! y+ i v! o9 g9 `
3、发表帖子的文件----命名为:say.asp <br>
7 X; p9 m3 k8 f) Z& {<br>
9 \! y5 P: ]8 f: U4、保存发表帖子内容的文件-----命名为:save.asp <br>! }8 z/ ]: y2 ^, g' B& j2 c- ?
<br>* N) T7 s; Z, l/ K9 I. V" R
5、显示帖子标题的文件------命名为:index.asp <br>3 L3 C4 M2 g3 z% c. s& ~. ^4 f
<br>
, K% h( q2 v9 a2 N6、显示帖子内容的文件,即点击标题后所进入的页面-----命名为:show.asp <br>- _6 s& f- @: q, x& l& O& a& ^& l) j
<br>
* j$ E. _- b# W建立文件是可以先建立文本文档,他的格式为"文件名.txt",我们只需把它改为"文件名.asp" <br>
' G3 }; ]- T8 k# N) f<br> k3 p0 c7 }- _. E3 r0 N. H' |# J) T
二、各文件的主要内容 <br>: Q" R( J2 x( }3 B8 \1 _5 h
<br>. M8 |8 [1 ~# y
1、bbs.mdb <br>
- H! l: `1 N% R; D" ?$ Y+ d' r! i% `* X i<br>. `4 X; \7 X8 U0 @$ H6 U
打开这个数据库,建立一个表,命名为bbs <br>
/ t+ @& d U! H<br>
! w9 \' j) K* T" A$ @: [该表中有几个字段: <br>4 S3 i5 c0 C; a# l6 c! Y
<br> ~3 C9 |; {$ B* q
id(自动给帖子编号),他的数据类型设为“自动编号” <br>
, }" ]# a. o+ u0 x- Y$ w$ W<br>
& U8 d3 S6 d! Q4 u6 ~7 B# `name(用来储存发表的作者),数据类型为“文本” <br>7 I# K" S5 c/ Q
<br>
~( v- k( J4 d2 Htitle(用来储存帖子的主题),数据类型为“文本” <br>3 @" f/ f% S! o; Y3 S; K
<br>+ ~, f6 h) a+ P) I
body(用来储存帖子的内容),数据类型为“备注” <br>
1 {" o M* t# v; h<br>
, [. T8 B$ B9 J! i$ J# x2、conn.asp <br>
( s/ J8 h: t# l8 R6 d, `- I! e源代码为: <br>6 H Q, f7 K# f+ H" M F8 x
<% <br>6 g5 V5 _7 B: J2 ~$ Z5 B
Server.scriptTimeout="10" <br>
/ L) f+ h+ [- M+ wconnstr="DBQ="+server.mappath("═bbs═.mdb")+";DefaultDir=;DRIVER={Microsoft Access Driver (*.mdb)};" <br>. K7 M) C, ]5 G9 r+ M {
set conn=Server.CreateObject("ADODB.connection") <br>9 \2 A+ z9 o' [6 }& K
conn.open connstr <br>
( N4 A4 d7 x( j' d%> <br>- I0 N* Y! B% p' ^1 W, q
<br>
8 r' X/ k2 X4 A+ ^% S这个文件就是这样,代码内容大家就自己研究,这个我也不知道怎么说才好! <br> z5 s- s) b0 B+ X) f
<br>
- ^. v9 A* @( R( O" s1 Y, T% ?2 \3、say.asp <br>
, Q2 {8 g; `( b8 F. `<br>' v( F* g: ~! r
源代码为: <br>9 u& d8 J" s! ~9 Z( z: ?! _' j+ M
<form method="POST" action="save.asp"> <br>
1 ?1 d: ?, q; Y3 o5 j<p>大名:<input type="text" name="name" size="20"></p> <br>
+ U! j/ I5 r; {2 y. f<p>标题:<input type="text" name="title" size="91"></p> <br>
3 v2 m% \& }. E* E0 w<p>内容:</p> <br>$ f) z! S0 q1 C& D
<p><textarea rows="11" name="body" cols="97"></textarea></p> <br>( q2 ], I3 a( U0 O
<p> </p> <br>* P+ X* Y* e, \ g2 F
<p><input type="submit" value="提交" name="B1"><input type="reset" value="重置" name="B2"></p> <br>
0 Y1 `8 J2 b, }7 K! m</form> <br>
2 i8 z9 S' {% R/ D% r D大家应该看得懂的,这个根本就是html语法,对的,根本就是,这个只是发表的界面 <br>
% n! Y7 H9 A( b' T: D1 ?不过要注意这一句<form method="POST" action="save.asp">,他把用户所填的内容发送至save.asp这个文件,下面就看save.asp这个文件吧! <br>
# ?1 O; W0 p+ \* W G<br>: ^) |$ ?) w: {$ f' O
4、save.asp <br>
4 J' |: p- o" l* U+ I5 r; C5 g+ o<br>5 L: v9 B5 X7 R( S/ c& W7 D
源代码: <br>
) S$ ^: u5 b1 G0 E; H' x<!--#include file="conn.asp"--> <br>+ g! n0 u6 \# c) q. R7 _; Q
<%name=Replace(Request.Form("name"),"'","''") <br>2 l! o U5 D3 ^' Z6 o
title=Replace(Request.Form("title"),"'","''") <br>
5 e9 ?% |3 e# j' i1 vbody=Replace(Request.Form("body"),"'","''") <br>. A* ?6 {, t' L9 _# i; o
%> <br>
3 F3 R; E0 r% o4 R3 s<%if name="" or title="" or body="" then%> <br>, Z. D1 o( |6 P' S0 B" Z( }& P
请<a href="****:history.go(-1)">后退</a>填写完整资料,你才能发表帖子! <br>
. [2 n/ ^) Z% ^% g O<%else%> <br>: k0 l8 j$ v0 c( i7 h0 I% Q6 A0 C
<%set savebbs=conn.execute("insert into bbs(name,title,body)values('"&name&"','"&title&"','"&body&"')")%> <br>
6 R. y. j4 `( N( y7 H. ?! t发表成功!<a href="index.asp">查看帖子</a> <br>
0 A; B( _0 j9 ?<%end if <br>
/ ~7 h6 | x- xset savebbs=nothing <br>
$ z5 H1 g1 p% R9 q' b1 c%> <br>: g' ~7 u$ l6 ~
<br>6 T! Q9 Q4 j' F. {; U) {# B
第一句:<!--#include file="conn.asp"-->,意思是插入conn.asp文件,即与数据库进行连接! <br>7 j* A7 d* G2 X* j" k
asp语句必须用<% %>这个格式包含起来,而插入文件的语句就不用, <br>; q/ _( ^! o E9 g0 W
接下来几句: <br>
) ~0 b# F6 x. O( C: qname=Replace(Request.Form("name"),"'","''") <br>8 n, @ z" {( U, G8 j w
title=Replace(Request.Form("title"),"'","''") <br>
" J6 Y) y' C& L( Z2 tbody=Replace(Request.Form("body"),"'","''") <br>3 A2 Z; X; U3 i- G: t
<br>
/ v7 w; S7 H1 H: ?" G- T“Replace(Request.Form("name"),"'","''")”意思是接收表单中名为name的文本框发来的数据, <br>* u! c6 U4 N: p
而“name=Replace(Request.Form("name"),"'","''")”则是把发来的数据储存在name变量中, <br>
5 N" l2 M/ K& F$ `/ l如果你这样:“abc123=Replace(Request.Form("name"),"'","''")” <br>
! I6 u$ G% ?, V5 m2 P就是把表单中名为name的文本框发来的数据储存在abc123变量中 <br>7 f% I% ?* I8 P! L* l- ?( V2 U
<br>
3 b9 n) j8 F( E接着:if name="" or title="" or body="" then <br>
" j% T$ d. K( j1 X6 W/ q# Z判断name、title和body变量中是否没有填写内容,即为"",如果这样,就执行这一语句: <br>
/ P( O. O: Q, u“请<a href="****:history.go(-1)">后退</a>填写完整资料,你才能发表帖子!” <br>8 j* u, E* u5 K2 d3 N; O1 v
该语句属于html语法,大家都看得懂的! <br>1 k( U+ A6 J7 o. C, q6 v# U# g" t
<br> r: c5 l' H6 ]2 z: s3 ~
"<%else%>"就是说“当if……then不成立(即是说所有内容都已经填写)”,就执行语句: <br>
' L5 O. f W7 a; b, ]“<%set savebbs=conn.execute("insert into bbs(name,title,body) values('"&name&"','"&title&"','"&body&"')")%> <br>/ d+ G3 D7 n5 Y
发表成功!<a href="index.asp">查看帖子</a>” <br>' ] O) b, x/ ^, J: d4 }
<br>
9 T$ i: F9 L- v; J' J5 x0 d$ g% ~"set save=conn.execute"属于固定的语句,不过savebbs可以自己修改,"="后面的就难解释了: <br>4 u$ B6 V2 n; z0 O" L# k
insert into bbs(name,title,body)意思是向名为bbs的表(在建立数据库时已经建立的表) <br>1 n( |7 N6 s5 B" J- ~9 ^& e
中的name,title,body字段插入,插入什么呢?看接下的values('"&name&"','"&title&"','"&body&"')") <br>
4 z. P9 P' K9 p& W/ ~values是“值”的意思 <br>
. S! F# a0 r0 b) k就是插入向量name,title,body,向量用格式'"&name&"'表示 <br>
0 E8 j8 Q* G" ]: ~% K8 d$ w9 I<br>
/ X, D8 Q1 q) Q& d- G* a9 i最后:end if就是结束if……then <br>' ?. f t- E+ m4 Q* p8 k
set savebbs=nothing可以说是关闭掉: <br>
- I `9 F o9 r2 {2 ?set savebbs=conn.execute("insert into bbs(name,title,body) values('"&name&"','"&title&"','"&body&"')") <br>. g c) E! l8 v) n& r
<br>3 [( Y% c( a( V, w- x
<br>
& k% v" O4 f' v& t- d$ U5、index.asp <br>
% S$ u) A2 T K$ t3 ?; @* f" @源代码: <br>
P; Y: H# g8 p+ k<!--#include file="conn.asp"--> <br>
: Z5 Z' ~0 P# C8 C% S<b><a href="say.asp">发表帖子</a></b><br><br> <br>
+ F* G: W2 u7 J' |<div align="center"> <br>6 D% h: Y3 q' H- k
<center> <br>
9 u. h5 l) C1 A$ B: U% j/ r<table border="0" cellpadding="0" cellspacing="0" style="border-collapse: collapse; " bordercolor="#000000" width="100%" height="26"> <br>) g9 W: G* }& W7 t' f% M
<tr> <br>
9 P% c* @- q( r1 j- G2 {$ z; w8 {<td width="17%"><b>作者</b></td> <br>
' x J: V- s) v" {9 ~<td width="83%"><b>主题</b></td> <br>
8 u2 m! j" t6 T0 ^) ]9 m</tr> <br># b# M: y* v* {0 Q0 l' K
</table> <br>9 B! v/ r3 C4 j% Y S
</center> <br>, {3 s! y* u3 y w' o
</div><hr size="1"> <br>
5 a1 Y+ Y6 ^9 B- N1 y- X<%i=1 <br>
% x3 x& b) y- _! E2 b( Y! [. nset showbbs=conn.execute("select*from bbs order by id desc") <br>
# A8 V2 B1 K t% Y o, u$ K3 f( `do while not showbbs.eof <br>
! g, w' o/ K! w& T [0 {2 Z8 `2 z%> <br>
, i9 }# V& M% e6 Z5 g<div align="center"> <br># M+ t% l1 e) ]- I
<center> <br>
$ z$ E# L2 M6 C' ~<table border="0" cellpadding="0" cellspacing="0" style="border-collapse: collapse; " bordercolor="#000000" width="100%" height="20"> <br>% Z0 r+ j l. c o0 ~
<tr> <br>
: q* o# B3 W; d# a' u<td width="17%"><%=showbbs("name")%> </td> <br>
7 P% f( d+ m& B* Z$ x' o" D<td width="83%"> <br>
/ F/ a" D) I: s<a href="show.asp?id=<%=showbbs("id")%>"><%=showbbs("title")%></a></td> <br>
0 p. Z, Z% k3 A5 J w9 n; b, h' s</tr> <br>( y" J0 e/ l: x6 H; i g; e) K% y
</table> <br>6 f1 `6 F% U8 c- [* S- @5 E
</center> <br>. ]- A9 D: Y+ Y0 I$ V' ~% h- C3 i
</div><hr size="1"> <br>2 q: u/ [7 Z% S$ y
<%i=i+1 <br>0 g: ]- @: X7 S5 \
if i>50 then exit do <br>
& ]6 P/ G# `3 T6 h& mshowbbs.movenext <br>- ^- y! E% w: b5 X
Loop <br>/ c' F1 c1 a, A1 h0 |
showbbs.Close <br>. e8 a# P. L6 H/ L
set showbbs=nothing <br>3 g) y$ J" ?# u( P9 Y- @3 B
%> <br>
- Q8 R7 l7 J( X<br>1 u/ @+ d {' o+ V
这个文件就不一句一句的讲了 <br>
1 P. \5 G2 K7 V2 S8 `: q% u# y) Q" {主要讲精华部分: <br>+ o8 c: w& \* p
set showbbs=conn.execute("select*from bbs order by id desc") <br>
* X: G$ ^, v( Z! E意思是:向数据库中的bbs数据表查询数据,并以id排顺序, <br>
" s, J; V# h) `& u" k还有这么一句:<%=showbbs("name")%> <br>1 h4 ^3 {7 K* q6 c8 e0 D
就是显示数据表中的name字段的数据,这里的showbbs就是set showbbs=……中的showbbs <br>" z$ L- V1 F* ]9 R/ v9 E0 m
代码中的i=1和i=i+1 <br>
% V* z/ i* u! ~3 _7 o2 ~/ r% x; uif i>50 then exit do <br>
5 I+ K$ _# J$ g/ S8 v. i+ r8 u- B& Ushowbbs.movenext <br>
0 L" i* `: @+ S! ^/ k) \- wLoop <br>& f+ p) V. U; W/ g' F
showbbs.Close <br>
+ o" G. |3 G5 t- h' rset showbbs=nothing <br>; g2 O" q( l' p& r/ _* Z8 g" a4 A
<br> r, O* [5 I, j; D3 m9 Q/ C
这几句属于循环语句,这里就不理他,理解了也不太好用,因为他只显示50张贴子! <br>, B6 G5 Z! u r/ G9 M7 G
if i>50 then exit do中的50可以修改 <br>0 t: O% Y. {! P
但我们做论坛必须把帖子分页,又因为分页这个语句太复杂,我想就不讲了,等这一个弄懂了才来弄 <br>
6 I' [9 W/ p) j5 [, u还有一句很有用的: <br>
k0 a r8 y7 y' G% p; u- n0 S<a href="show.asp?id=<%=showbbs("id")%>"><%=showbbs("title")%></a> <br>- u2 R) C+ j6 ?5 h; {, C! C
里面的超连接:show.asp?id=<%=showbbs("id")%>,注意:这里的超连接把帖子的id包含了, <br>
3 [9 [6 h! K3 V& s/ `等一下在show.asp文件中就有用了 <br>! W8 p$ w, y' k
<br>+ b- R) }. i. v' _$ z& u
5、show.asp <br>* ^" H& j* E/ [" g& @7 C
源代码: <br>
7 W6 p v! h' f( H% j" U+ Z<br>, j1 w) S! Z d1 Q
<!--#include file="conn.asp"--> <br>3 h% k$ }* u. P- M- W( ~5 {! a
<%id=request.querystring("id")%> <br>
4 `9 s1 o$ R. z( S; w8 l- A<%set show=conn.execute("select*from bbs where id="&id&"")%> <br>
' o1 s; v+ D8 b7 W- t0 k<a href="index.asp"> <br>: o5 r4 B( j* P% ?8 v9 k5 m
<b>回到首页</b></a><br><b><a href="say.asp">发表帖子</a></b><br><hr size="1"> <br>, ^, z9 l, Q1 S/ l5 K6 v
<table border="1" cellpadding="0" cellspacing="0" style="border-collapse: collapse" bordercolor="#111111" width="100%" height="180"> <br>; |& U, x" L a4 j+ [8 N( o
<tr> <br>
: ?) V3 M, N7 {6 S- K! x/ U& O. j<td width="21%" height="22"><b>作者:</b><%=show("name")%></td> <br>' N3 F' M2 E2 G) {) N
<td width="79%" height="22"><b>主题:</b><%=show("title")%></td> <br>
3 c* L+ V# y7 J& ?2 J</tr> <br>% z; P* Y* c! b4 Z7 G
<tr> <br>
/ ^* ?2 d6 V3 f/ o<td width="100%" colspan="2" height="158" valign="top"><b><br>内容:</b><%=show("body")%></td> <br>
0 Y. l% s+ W8 b</tr> <br>2 ]! V; M |8 I- m
</table><%set show=nothing%> <br>
5 V6 c/ F7 | V<br>
7 K, E7 w- B4 S" S劲语句---精华语句: <br>
7 U$ _- G& z3 K- E6 f" Sid=request.querystring("id") <br>
' K) {! a4 N- n8 [" m: f在讲解index.asp文件的后面已经说到:show.asp?id=<%=showbbs("id")这一句, <br>
. P+ s# r b# r3 q7 w% V& a1 wid=request.querystring("id")就是把地址栏中的id的值读取下来, <br>
) v- a! J6 \& g8 d因为index.asp文件中的超连接点击后,地址栏就为http://…………/show.asp?id=数字, <br>0 @3 R3 @& F6 z* c( u9 w
所以show.asp使用id=request.querystring("id")语句把数字读取下来 <br>' ?' M& A7 A3 P, R6 L
于是接着使用:set show=conn.execute("select*from bbs where id="&id&"") <br>. r0 v# P0 x h: h
向数据表查询id为这时读取下来的数字的帖子,即where id="&id&" <br>
4 \! b* R6 _8 N& y: S最后<%set show=nothing%> <br>0 A1 N' e$ a3 k
<br>- k9 _, I, c5 [2 K) |
好了,一个简单的DIY论坛就这样完成了 |
|