|
大家在网上看到各种各样的ASP论坛是不是觉的做论坛很难呢,其实我们用简单的ASP语句就完全可以完成一个属于自己的论坛。下面我教大家如何用ASP来打造一个属于自己的论坛,自己的东西毕竟用起来爽吗。<br>
7 q3 R7 j) H6 Q9 A$ `<br>
) f7 {& _5 v. n0 l; p0 Z \ O同时,再复杂的论坛的写成也离不开下面的基本步骤,大家仔细看了。 <br>1 E4 w6 z9 f' O* \# s) B8 F5 q
<br>" W; N, f' l; C$ K8 [! w
一、建立文件! <br> @, i. c) i G5 @, M6 S
最简单的论坛也要有几个必要的文件,就是: <br>
/ s' I% B# ?2 l7 P<br>
/ Q. p9 g8 L0 e5 \& ` W1、数据库,用来储存发表的帖子!-------命名为:bbs.mdb <br>- p5 T0 v5 F/ S* W e
<br>
/ z' V4 J: o3 u6 @( `4 d" p2、有数据库就必须连接数据库,该文件用来连接数据库:----命名为:conn.asp <br>
6 }7 M% F8 {0 Q' {6 e% [$ G' W<br>
5 Z6 F7 A% E2 E% h) S9 k1 X% e3、发表帖子的文件----命名为:say.asp <br>
, j/ {: O. M* T: a- f/ e+ Y<br>* g- n- k& h2 O" b" P5 a+ U5 x; P7 U
4、保存发表帖子内容的文件-----命名为:save.asp <br>
$ w! l3 V j) w* f* r2 X<br>
1 ^$ A4 z* E: N4 s* z5、显示帖子标题的文件------命名为:index.asp <br>
4 [) n/ `6 g; k" V+ Y; _<br>+ d+ H3 w0 _% M6 N: l# [
6、显示帖子内容的文件,即点击标题后所进入的页面-----命名为:show.asp <br>
" \# S0 U; D: S2 l<br>. W4 j- `* M* F& e" S2 l
建立文件是可以先建立文本文档,他的格式为"文件名.txt",我们只需把它改为"文件名.asp" <br>
5 ~4 p) t" k/ ]9 i% y<br>* M/ ~5 q- B& j) j" L6 Z2 v$ `! _8 K
二、各文件的主要内容 <br># U5 d* ~+ G6 a& u; J7 q
<br>
7 c5 S; [ V2 s6 A: A7 N/ Z1、bbs.mdb <br>: j' X4 [, k8 Z! F
<br>* ~9 D/ m; b' m. q4 e6 r- H
打开这个数据库,建立一个表,命名为bbs <br>
( x: L u5 P/ a8 {! _( `, o<br>
+ q! u3 K4 O4 v: C1 ]3 A该表中有几个字段: <br> D. _" c! ?, d4 Z% F9 m
<br>
! @* Q$ S) e( z1 S% f& aid(自动给帖子编号),他的数据类型设为“自动编号” <br>. i' @2 g' t M; m# E7 I
<br>
/ h3 w) I1 D" i0 x$ o( pname(用来储存发表的作者),数据类型为“文本” <br>4 L/ c7 H- y/ ?' I) h) I$ I. V
<br>* ]( ] @; R3 h! }" {
title(用来储存帖子的主题),数据类型为“文本” <br>
9 _) K/ h/ z7 N0 M+ J<br>* ~* {+ g6 a: }3 F
body(用来储存帖子的内容),数据类型为“备注” <br>- |3 h( [# r2 P
<br>& s: ?; v8 \0 ?3 T$ ^
2、conn.asp <br>! g1 F0 b) v/ B1 V+ h
源代码为: <br>
7 ]; c n/ N* }9 `<% <br>
* D7 J6 S* q5 N1 j8 o4 e# pServer.scriptTimeout="10" <br>, r' \1 |; e: P! h2 W
connstr="DBQ="+server.mappath("═bbs═.mdb")+";DefaultDir=;DRIVER={Microsoft Access Driver (*.mdb)};" <br>
4 r" `2 i# k- d0 aset conn=Server.CreateObject("ADODB.connection") <br>- s7 n( }1 C2 R \' Y& |+ d
conn.open connstr <br>
6 x' J* R8 U+ [7 X( ]" V%> <br>
( Z! A6 I1 b, P, s' y8 Z<br>& {8 Y6 r7 v! X9 H
这个文件就是这样,代码内容大家就自己研究,这个我也不知道怎么说才好! <br>
$ u- e v" s w<br>
8 h$ \+ o6 |' w: [) V' X1 [- S0 Z, w/ C3 \3、say.asp <br>
# d- b Y8 N$ A+ o<br>) J8 ~* K+ e% K% |6 y
源代码为: <br> {9 p3 i" d& }! j+ a/ U
<form method="POST" action="save.asp"> <br>. u% A2 D' ^8 s5 u e9 J# J5 L& V
<p>大名:<input type="text" name="name" size="20"></p> <br>+ T* A3 N+ K; I. E" y' e9 b% `
<p>标题:<input type="text" name="title" size="91"></p> <br>
7 U) c/ w3 Q) C" _<p>内容:</p> <br>
" q. [ b5 z, F, J) N7 Y<p><textarea rows="11" name="body" cols="97"></textarea></p> <br>
* y7 c2 l, z1 i! x, z<p> </p> <br>
4 P) j9 V' }. e, A0 I6 M/ o<p><input type="submit" value="提交" name="B1"><input type="reset" value="重置" name="B2"></p> <br>- e7 U0 V3 ~) `, h4 K9 q
</form> <br>/ \+ Y2 y( ], ]- U6 \$ T& b
大家应该看得懂的,这个根本就是html语法,对的,根本就是,这个只是发表的界面 <br>
+ u( l8 T7 h) A: h: Y不过要注意这一句<form method="POST" action="save.asp">,他把用户所填的内容发送至save.asp这个文件,下面就看save.asp这个文件吧! <br># I( O5 ^7 I( Z9 z T7 w
<br>' f+ D1 d- t& X( o j
4、save.asp <br>2 e( ?7 G/ W/ c3 C; v4 K% o0 W) b
<br>
/ N7 P) V8 c9 g3 ` f4 f2 v) m6 ?源代码: <br>& o8 H9 Y- a" i9 o
<!--#include file="conn.asp"--> <br>
( a5 T. z9 F% S. h<%name=Replace(Request.Form("name"),"'","''") <br>4 G0 N( q% L& F$ D+ p
title=Replace(Request.Form("title"),"'","''") <br>
* }; Z! V- v _6 H$ N8 T# Dbody=Replace(Request.Form("body"),"'","''") <br>/ \& G, r/ E# Z: A- t9 g6 Y1 ^6 `
%> <br>7 ^0 x% c. c8 X7 `
<%if name="" or title="" or body="" then%> <br>
# e, R# ~5 q* M9 Q请<a href="****:history.go(-1)">后退</a>填写完整资料,你才能发表帖子! <br>4 t0 K4 G: }( i+ Y+ \
<%else%> <br>
. Z% i6 k, C% |% y<%set savebbs=conn.execute("insert into bbs(name,title,body)values('"&name&"','"&title&"','"&body&"')")%> <br>3 A9 Q5 c1 n1 P! O$ b
发表成功!<a href="index.asp">查看帖子</a> <br>
' o9 f/ H, G; }# }6 s# }<%end if <br>7 `5 x$ `6 ? Y3 A
set savebbs=nothing <br>6 K9 R, D K- b4 y* t4 v
%> <br>- c' _& W, f" V0 @: d9 z! R) `
<br>
/ v9 c7 ~+ _, I第一句:<!--#include file="conn.asp"-->,意思是插入conn.asp文件,即与数据库进行连接! <br>
! U' ` j) ]$ l: G$ kasp语句必须用<% %>这个格式包含起来,而插入文件的语句就不用, <br>/ ?$ V- B# b, U6 e: u5 U3 ~/ F5 q
接下来几句: <br>3 t4 A' w! F' F X6 {8 ~5 j# |
name=Replace(Request.Form("name"),"'","''") <br>
4 Q8 A; m" J# p7 atitle=Replace(Request.Form("title"),"'","''") <br>
+ W+ J- y: {7 n9 Q0 ~body=Replace(Request.Form("body"),"'","''") <br>$ t/ u7 R) l1 `2 @' t) u/ I
<br>
3 g8 h, l% C K1 Z) o. t& b“Replace(Request.Form("name"),"'","''")”意思是接收表单中名为name的文本框发来的数据, <br>
6 g5 C- j+ i6 c$ u, i H Q而“name=Replace(Request.Form("name"),"'","''")”则是把发来的数据储存在name变量中, <br>
2 x% G0 Q* ~7 `# B: j$ L# [$ `如果你这样:“abc123=Replace(Request.Form("name"),"'","''")” <br>
" I1 I6 X) i# \! I5 ~就是把表单中名为name的文本框发来的数据储存在abc123变量中 <br>' M5 U- g3 r5 {6 ~5 n( P
<br>
# @, k& s3 k9 I( d7 q5 H接着:if name="" or title="" or body="" then <br>6 k; F( A2 y3 L7 {
判断name、title和body变量中是否没有填写内容,即为"",如果这样,就执行这一语句: <br>
: B! [. e# N+ c“请<a href="****:history.go(-1)">后退</a>填写完整资料,你才能发表帖子!” <br>
. C" G" V4 M/ l) _该语句属于html语法,大家都看得懂的! <br>3 Z8 I( Y2 _3 y! R2 ~; D
<br>
Z3 L* }) @$ ]* k, [/ O/ r& a" @ Y"<%else%>"就是说“当if……then不成立(即是说所有内容都已经填写)”,就执行语句: <br>, u4 w0 F3 W1 o$ |5 P
“<%set savebbs=conn.execute("insert into bbs(name,title,body) values('"&name&"','"&title&"','"&body&"')")%> <br>
+ P7 O# i( U, U8 z4 h发表成功!<a href="index.asp">查看帖子</a>” <br>; H, w1 E- x: l
<br>4 A5 I% H: M- X2 F0 G( b6 K
"set save=conn.execute"属于固定的语句,不过savebbs可以自己修改,"="后面的就难解释了: <br>
, j7 ?( ], m4 C6 E4 }5 {3 o6 ninsert into bbs(name,title,body)意思是向名为bbs的表(在建立数据库时已经建立的表) <br>7 s+ [% _- g% Q
中的name,title,body字段插入,插入什么呢?看接下的values('"&name&"','"&title&"','"&body&"')") <br>) G3 v$ u( S8 W) p
values是“值”的意思 <br>8 s5 r+ k0 r2 Y H5 n# L
就是插入向量name,title,body,向量用格式'"&name&"'表示 <br>
# A; D0 ` ?0 ^7 I- x* `: z<br>4 Q. k2 V% m1 d* s
最后:end if就是结束if……then <br>
( L- I3 C8 i ?) J% Y) _# b; Hset savebbs=nothing可以说是关闭掉: <br>
; P6 H% j9 `4 y9 Gset savebbs=conn.execute("insert into bbs(name,title,body) values('"&name&"','"&title&"','"&body&"')") <br>
0 f7 {% M) g- D<br> `( i8 M( K5 N9 B _5 c3 E
<br>
& S# a& @/ R. c. r% a7 M7 k5 z' M5、index.asp <br>9 K( Y" j5 E/ H( y5 r: ~
源代码: <br>
- @# F, `4 m9 a. N( ]) O9 ?<!--#include file="conn.asp"--> <br>% B3 d, W1 h; a5 g7 @# x7 @
<b><a href="say.asp">发表帖子</a></b><br><br> <br>/ L5 H/ e# u# d& U$ b
<div align="center"> <br>" V; d9 N7 Z' M
<center> <br>: s# g t M& o/ \
<table border="0" cellpadding="0" cellspacing="0" style="border-collapse: collapse; " bordercolor="#000000" width="100%" height="26"> <br>+ [% H4 p- Q1 j: p* g, A
<tr> <br>
- H0 M' |8 ^6 i [ I y4 X. w<td width="17%"><b>作者</b></td> <br>
/ u( H/ `( O2 l4 X* m0 S# p! S<td width="83%"><b>主题</b></td> <br>" D0 y+ }7 o: x6 z# e3 X3 T
</tr> <br>
% W1 S; S/ r6 w, o1 L8 Y. J6 @. H</table> <br>
2 x& G/ w3 h! N) D1 b9 c</center> <br>: C. t$ b. [' C; Y2 t1 v# b# w/ p
</div><hr size="1"> <br>- x w) }# Z% t% J3 r+ D4 M
<%i=1 <br>
, j( L+ ]# l6 c8 S1 w' W' lset showbbs=conn.execute("select*from bbs order by id desc") <br>. b, @& n0 }$ q# O7 ?1 I
do while not showbbs.eof <br>$ a; ?3 K7 H1 l5 u
%> <br>8 A. Y$ `9 [& K. P
<div align="center"> <br>0 H# T0 x; a, k* n1 o
<center> <br>/ m8 D7 T# k4 R, B
<table border="0" cellpadding="0" cellspacing="0" style="border-collapse: collapse; " bordercolor="#000000" width="100%" height="20"> <br>- j' @" U/ j8 ^# z( p
<tr> <br>9 z2 B; _1 T* Y/ p" m4 c0 @( t
<td width="17%"><%=showbbs("name")%> </td> <br>/ f; N7 ^4 h+ [9 ^" A; A7 q
<td width="83%"> <br>
! ?: h# A2 U* T<a href="show.asp?id=<%=showbbs("id")%>"><%=showbbs("title")%></a></td> <br>
1 V8 S: p$ o; p8 d</tr> <br>
) w5 U F) U# o; \* U</table> <br>
' _7 K e \) w( m5 x `</center> <br>
4 d0 s: Q1 h$ t3 ^' |, h</div><hr size="1"> <br>
. j Y* G& D/ D% j<%i=i+1 <br>
; a" r; U; J, K# \4 C# Mif i>50 then exit do <br>
0 \3 y. H4 a; c8 u' Cshowbbs.movenext <br>( \7 C v# i4 @5 l/ }
Loop <br>
. N, @/ r8 _7 M* x7 y/ m- r! vshowbbs.Close <br>
5 {, N& o5 U0 }; E- Eset showbbs=nothing <br>' j" z+ u3 e; B2 T7 S3 K# D
%> <br>
( _+ Y; C+ q3 T( M% t: ?<br>
& A$ H$ D# J: G# s; f. d这个文件就不一句一句的讲了 <br>
6 R; H; T6 G2 m) j3 U' m8 K2 g主要讲精华部分: <br>7 l+ o7 s5 x# Z! Z) z8 J
set showbbs=conn.execute("select*from bbs order by id desc") <br>7 c+ Z5 p2 v* _. j
意思是:向数据库中的bbs数据表查询数据,并以id排顺序, <br>/ Q+ I( @7 d( W0 B* L& O
还有这么一句:<%=showbbs("name")%> <br>; U# {3 T3 x" L! W D2 h; p
就是显示数据表中的name字段的数据,这里的showbbs就是set showbbs=……中的showbbs <br>
. q) u- D: V! `: C' f; @代码中的i=1和i=i+1 <br>
: v1 s) Q* T0 g$ i9 {- N3 V0 Iif i>50 then exit do <br>
6 `2 o" q' I3 M* E7 v2 Eshowbbs.movenext <br>
6 W. o8 U" Y, P7 Z) ULoop <br>
0 A1 L$ E) L6 k( {% }3 ]showbbs.Close <br>) c! z" k- y& z$ d$ I+ h/ [6 ^
set showbbs=nothing <br>' t6 `% _+ p7 ?( R: ^( e. c
<br>
9 K% Z, K8 C5 K, h- ~这几句属于循环语句,这里就不理他,理解了也不太好用,因为他只显示50张贴子! <br>
. l7 u# Z+ u2 \, E; X g8 eif i>50 then exit do中的50可以修改 <br>
- M0 N* _8 m1 L+ k! a( k4 b( B( {/ r但我们做论坛必须把帖子分页,又因为分页这个语句太复杂,我想就不讲了,等这一个弄懂了才来弄 <br>
+ S7 N7 S5 H. D8 v2 R( E( X- v; N. C还有一句很有用的: <br>. S; B+ |6 H! S% c% u
<a href="show.asp?id=<%=showbbs("id")%>"><%=showbbs("title")%></a> <br>
& E3 }/ j6 o+ T, F里面的超连接:show.asp?id=<%=showbbs("id")%>,注意:这里的超连接把帖子的id包含了, <br>" l2 Y8 f+ u Q( d
等一下在show.asp文件中就有用了 <br>
! [, q8 I6 e9 Q' ]" W) M6 I; r<br>
) W8 [6 v) F; ~5、show.asp <br>, L9 G$ c7 M, l; b
源代码: <br>
. W, D" }' \' e<br>
/ D1 v- D0 ^) T2 x<!--#include file="conn.asp"--> <br>
( _2 E: V, b+ @* F" h<%id=request.querystring("id")%> <br>
4 N! I/ q; P$ J3 o r7 m$ k6 f1 j$ @- j1 y<%set show=conn.execute("select*from bbs where id="&id&"")%> <br>
, V" j, s) f/ J6 Q5 w3 D<a href="index.asp"> <br>
+ z. ~7 T2 i- f' ^0 W<b>回到首页</b></a><br><b><a href="say.asp">发表帖子</a></b><br><hr size="1"> <br>
0 \. g5 H( m: }9 A! V<table border="1" cellpadding="0" cellspacing="0" style="border-collapse: collapse" bordercolor="#111111" width="100%" height="180"> <br>3 Q5 _' E) m" Q3 y+ B/ ?" P
<tr> <br>
; B k) l0 F/ g# h7 B' E# J* `& ]' I<td width="21%" height="22"><b>作者:</b><%=show("name")%></td> <br>/ q4 e% W* B' |
<td width="79%" height="22"><b>主题:</b><%=show("title")%></td> <br>
6 n2 W( y5 L! x0 p2 @</tr> <br>5 e6 ~! Y0 z3 p5 d1 C; d
<tr> <br>$ W; Y8 ?: o$ x) ^% B
<td width="100%" colspan="2" height="158" valign="top"><b><br>内容:</b><%=show("body")%></td> <br>
8 a2 y; t$ |8 P2 A0 P1 ?* n# R9 s0 ]</tr> <br>8 L3 i% q1 t4 S# f+ i5 H9 d
</table><%set show=nothing%> <br>2 T" Y$ C* e( p( i" K! w% g
<br>! ]& \! G9 }# U# ?. m9 |& ?
劲语句---精华语句: <br>& R, z' j% o( _7 h0 I0 v0 Z
id=request.querystring("id") <br>+ h3 h& l. t0 {& a. |- _
在讲解index.asp文件的后面已经说到:show.asp?id=<%=showbbs("id")这一句, <br>
7 @; \2 `0 U: G' G6 p; sid=request.querystring("id")就是把地址栏中的id的值读取下来, <br>2 N+ S5 L x% _( L& K
因为index.asp文件中的超连接点击后,地址栏就为http://…………/show.asp?id=数字, <br>
9 `, {5 Y! Z6 s2 A所以show.asp使用id=request.querystring("id")语句把数字读取下来 <br>0 Q3 n7 W6 j3 \: N S+ H4 U
于是接着使用:set show=conn.execute("select*from bbs where id="&id&"") <br>$ n! F/ g$ W, F
向数据表查询id为这时读取下来的数字的帖子,即where id="&id&" <br>! o! ]& l& H% M4 M$ K
最后<%set show=nothing%> <br>
" Y1 M4 `0 N, t8 Q5 B& g/ a<br>
1 T1 K; i! H! h. p- G2 P- N2 g好了,一个简单的DIY论坛就这样完成了 |
|