诚毅小家|集美大学生活【集美大学,诚毅学院,水产学院,师范学院,美术学院,财经学院,体育学院,航海学院,集美学村,石鼓路,龙舟池】

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
热搜: 活动 交友 discuz
查看: 856|回复: 1

[分享]建一个简单的论坛-DIY版

[复制链接]
发表于 2005-3-31 15:28:00 | 显示全部楼层 |阅读模式
大家在网上看到各种各样的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建立文件是可以先建立文本文档,他的格式为&quot;文件名.txt&quot;,我们只需把它改为&quot;文件名.asp&quot; <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
&lt;% <br>6 g5 V5 _7 B: J2 ~$ Z5 B
Server.scriptTimeout=&quot;10&quot; <br>
/ L) f+ h+ [- M+ wconnstr=&quot;DBQ=&quot;+server.mappath(&quot;═bbs═.mdb&quot;)+&quot;;DefaultDir=;DRIVER={Microsoft Access Driver (*.mdb)};&quot; <br>. K7 M) C, ]5 G9 r+ M  {
set conn=Server.CreateObject(&quot;ADODB.connection&quot;) <br>9 \2 A+ z9 o' [6 }& K
conn.open connstr <br>
( N4 A4 d7 x( j' d%&gt; <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
&lt;form method=&quot;POST&quot; action=&quot;save.asp&quot;&gt; <br>
1 ?1 d: ?, q; Y3 o5 j&lt;p&gt;大名:&lt;input type=&quot;text&quot; name=&quot;name&quot; size=&quot;20&quot;&gt;&lt;/p&gt; <br>
+ U! j/ I5 r; {2 y. f&lt;p&gt;标题:&lt;input type=&quot;text&quot; name=&quot;title&quot; size=&quot;91&quot;&gt;&lt;/p&gt; <br>
3 v2 m% \& }. E* E0 w&lt;p&gt;内容:&lt;/p&gt; <br>$ f) z! S0 q1 C& D
&lt;p&gt;&lt;textarea rows=&quot;11&quot; name=&quot;body&quot; cols=&quot;97&quot;&gt;&lt;/textarea&gt;&lt;/p&gt; <br>( q2 ], I3 a( U0 O
&lt;p&gt; &lt;/p&gt; <br>* P+ X* Y* e, \  g2 F
&lt;p&gt;&lt;input type=&quot;submit&quot; value=&quot;提交&quot; name=&quot;B1&quot;&gt;&lt;input type=&quot;reset&quot; value=&quot;重置&quot; name=&quot;B2&quot;&gt;&lt;/p&gt; <br>
0 Y1 `8 J2 b, }7 K! m&lt;/form&gt; <br>
2 i8 z9 S' {% R/ D% r  D大家应该看得懂的,这个根本就是html语法,对的,根本就是,这个只是发表的界面 <br>
% n! Y7 H9 A( b' T: D1 ?不过要注意这一句&lt;form method=&quot;POST&quot; action=&quot;save.asp&quot;&gt;,他把用户所填的内容发送至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&lt;!--#include file=&quot;conn.asp&quot;--&gt; <br>+ g! n0 u6 \# c) q. R7 _; Q
&lt;%name=Replace(Request.Form(&quot;name&quot;),&quot;'&quot;,&quot;''&quot;) <br>2 l! o  U5 D3 ^' Z6 o
title=Replace(Request.Form(&quot;title&quot;),&quot;'&quot;,&quot;''&quot;) <br>
5 e9 ?% |3 e# j' i1 vbody=Replace(Request.Form(&quot;body&quot;),&quot;'&quot;,&quot;''&quot;) <br>. A* ?6 {, t' L9 _# i; o
%&gt; <br>
3 F3 R; E0 r% o4 R3 s&lt;%if name=&quot;&quot; or title=&quot;&quot; or body=&quot;&quot; then%&gt; <br>, Z. D1 o( |6 P' S0 B" Z( }& P
请&lt;a href=&quot;****:history.go(-1)&quot;&gt;后退&lt;/a&gt;填写完整资料,你才能发表帖子! <br>
. [2 n/ ^) Z% ^% g  O&lt;%else%&gt; <br>: k0 l8 j$ v0 c( i7 h0 I% Q6 A0 C
&lt;%set savebbs=conn.execute(&quot;insert into bbs(name,title,body)values('&quot;&name&&quot;','&quot;&title&&quot;','&quot;&body&&quot;')&quot;)%&gt; <br>
6 R. y. j4 `( N( y7 H. ?! t发表成功!&lt;a href=&quot;index.asp&quot;&gt;查看帖子&lt;/a&gt; <br>
0 A; B( _0 j9 ?&lt;%end if <br>
/ ~7 h6 |  x- xset savebbs=nothing <br>
$ z5 H1 g1 p% R9 q' b1 c%&gt; <br>: g' ~7 u$ l6 ~
<br>6 T! Q9 Q4 j' F. {; U) {# B
第一句:&lt;!--#include file=&quot;conn.asp&quot;--&gt;,意思是插入conn.asp文件,即与数据库进行连接! <br>7 j* A7 d* G2 X* j" k
asp语句必须用&lt;% %&gt;这个格式包含起来,而插入文件的语句就不用, <br>; q/ _( ^! o  E9 g0 W
接下来几句: <br>
) ~0 b# F6 x. O( C: qname=Replace(Request.Form(&quot;name&quot;),&quot;'&quot;,&quot;''&quot;) <br>8 n, @  z" {( U, G8 j  w
title=Replace(Request.Form(&quot;title&quot;),&quot;'&quot;,&quot;''&quot;) <br>
" J6 Y) y' C& L( Z2 tbody=Replace(Request.Form(&quot;body&quot;),&quot;'&quot;,&quot;''&quot;) <br>3 A2 Z; X; U3 i- G: t
<br>
/ v7 w; S7 H1 H: ?" G- T“Replace(Request.Form(&quot;name&quot;),&quot;'&quot;,&quot;''&quot;)”意思是接收表单中名为name的文本框发来的数据, <br>* u! c6 U4 N: p
而“name=Replace(Request.Form(&quot;name&quot;),&quot;'&quot;,&quot;''&quot;)”则是把发来的数据储存在name变量中, <br>
5 N" l2 M/ K& F$ `/ l如果你这样:“abc123=Replace(Request.Form(&quot;name&quot;),&quot;'&quot;,&quot;''&quot;)” <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=&quot;&quot; or title=&quot;&quot; or body=&quot;&quot; then <br>
" j% T$ d. K( j1 X6 W/ q# Z判断name、title和body变量中是否没有填写内容,即为&quot;&quot;,如果这样,就执行这一语句: <br>
/ P( O. O: Q, u“请&lt;a href=&quot;****:history.go(-1)&quot;&gt;后退&lt;/a&gt;填写完整资料,你才能发表帖子!” <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 ~
&quot;&lt;%else%&gt;&quot;就是说“当if……then不成立(即是说所有内容都已经填写)”,就执行语句: <br>
' L5 O. f  W7 a; b, ]“&lt;%set savebbs=conn.execute(&quot;insert into bbs(name,title,body) values('&quot;&name&&quot;','&quot;&title&&quot;','&quot;&body&&quot;')&quot;)%&gt; <br>/ d+ G3 D7 n5 Y
发表成功!&lt;a href=&quot;index.asp&quot;&gt;查看帖子&lt;/a&gt;” <br>' ]  O) b, x/ ^, J: d4 }
<br>
9 T$ i: F9 L- v; J' J5 x0 d$ g% ~&quot;set save=conn.execute&quot;属于固定的语句,不过savebbs可以自己修改,&quot;=&quot;后面的就难解释了: <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('&quot;&name&&quot;','&quot;&title&&quot;','&quot;&body&&quot;')&quot;) <br>
4 z. P9 P' K9 p& W/ ~values是“值”的意思 <br>
. S! F# a0 r0 b) k就是插入向量name,title,body,向量用格式'&quot;&name&&quot;'表示 <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(&quot;insert into bbs(name,title,body) values('&quot;&name&&quot;','&quot;&title&&quot;','&quot;&body&&quot;')&quot;) <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&lt;!--#include file=&quot;conn.asp&quot;--&gt; <br>
: Z5 Z' ~0 P# C8 C% S&lt;b&gt;&lt;a href=&quot;say.asp&quot;&gt;发表帖子&lt;/a&gt;&lt;/b&gt;&lt;br&gt;&lt;br&gt; <br>
+ F* G: W2 u7 J' |&lt;div align=&quot;center&quot;&gt; <br>6 D% h: Y3 q' H- k
&lt;center&gt; <br>
9 u. h5 l) C1 A$ B: U% j/ r&lt;table border=&quot;0&quot; cellpadding=&quot;0&quot; cellspacing=&quot;0&quot; style=&quot;border-collapse: collapse; &quot; bordercolor=&quot;#000000&quot; width=&quot;100%&quot; height=&quot;26&quot;&gt; <br>) g9 W: G* }& W7 t' f% M
&lt;tr&gt; <br>
9 P% c* @- q( r1 j- G2 {$ z; w8 {&lt;td width=&quot;17%&quot;&gt;&lt;b&gt;作者&lt;/b&gt;&lt;/td&gt; <br>
' x  J: V- s) v" {9 ~&lt;td width=&quot;83%&quot;&gt;&lt;b&gt;主题&lt;/b&gt;&lt;/td&gt; <br>
8 u2 m! j" t6 T0 ^) ]9 m&lt;/tr&gt; <br># b# M: y* v* {0 Q0 l' K
&lt;/table&gt; <br>9 B! v/ r3 C4 j% Y  S
&lt;/center&gt; <br>, {3 s! y* u3 y  w' o
&lt;/div&gt;&lt;hr size=&quot;1&quot;&gt; <br>
5 a1 Y+ Y6 ^9 B- N1 y- X&lt;%i=1 <br>
% x3 x& b) y- _! E2 b( Y! [. nset showbbs=conn.execute(&quot;select*from bbs order by id desc&quot;) <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%&gt; <br>
, i9 }# V& M% e6 Z5 g&lt;div align=&quot;center&quot;&gt; <br># M+ t% l1 e) ]- I
&lt;center&gt; <br>
$ z$ E# L2 M6 C' ~&lt;table border=&quot;0&quot; cellpadding=&quot;0&quot; cellspacing=&quot;0&quot; style=&quot;border-collapse: collapse; &quot; bordercolor=&quot;#000000&quot; width=&quot;100%&quot; height=&quot;20&quot;&gt; <br>% Z0 r+ j  l. c  o0 ~
&lt;tr&gt; <br>
: q* o# B3 W; d# a' u&lt;td width=&quot;17%&quot;&gt;&lt;%=showbbs(&quot;name&quot;)%&gt; &lt;/td&gt; <br>
7 P% f( d+ m& B* Z$ x' o" D&lt;td width=&quot;83%&quot;&gt; <br>
/ F/ a" D) I: s&lt;a href=&quot;show.asp?id=&lt;%=showbbs(&quot;id&quot;)%&gt;&quot;&gt;&lt;%=showbbs(&quot;title&quot;)%&gt;&lt;/a&gt;&lt;/td&gt; <br>
0 p. Z, Z% k3 A5 J  w9 n; b, h' s&lt;/tr&gt; <br>( y" J0 e/ l: x6 H; i  g; e) K% y
&lt;/table&gt; <br>6 f1 `6 F% U8 c- [* S- @5 E
&lt;/center&gt; <br>. ]- A9 D: Y+ Y0 I$ V' ~% h- C3 i
&lt;/div&gt;&lt;hr size=&quot;1&quot;&gt; <br>2 q: u/ [7 Z% S$ y
&lt;%i=i+1 <br>0 g: ]- @: X7 S5 \
if i&gt;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
%&gt; <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(&quot;select*from bbs order by id desc&quot;) <br>
* X: G$ ^, v( Z! E意思是:向数据库中的bbs数据表查询数据,并以id排顺序, <br>
" s, J; V# h) `& u" k还有这么一句:&lt;%=showbbs(&quot;name&quot;)%&gt; <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&gt;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&gt;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&lt;a href=&quot;show.asp?id=&lt;%=showbbs(&quot;id&quot;)%&gt;&quot;&gt;&lt;%=showbbs(&quot;title&quot;)%&gt;&lt;/a&gt; <br>- u2 R) C+ j6 ?5 h; {, C! C
里面的超连接:show.asp?id=&lt;%=showbbs(&quot;id&quot;)%&gt;,注意:这里的超连接把帖子的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
&lt;!--#include file=&quot;conn.asp&quot;--&gt; <br>3 h% k$ }* u. P- M- W( ~5 {! a
&lt;%id=request.querystring(&quot;id&quot;)%&gt; <br>
4 `9 s1 o$ R. z( S; w8 l- A&lt;%set show=conn.execute(&quot;select*from bbs where id=&quot;&id&&quot;&quot;)%&gt; <br>
' o1 s; v+ D8 b7 W- t0 k&lt;a href=&quot;index.asp&quot;&gt; <br>: o5 r4 B( j* P% ?8 v9 k5 m
&lt;b&gt;回到首页&lt;/b&gt;&lt;/a&gt;&lt;br&gt;&lt;b&gt;&lt;a href=&quot;say.asp&quot;&gt;发表帖子&lt;/a&gt;&lt;/b&gt;&lt;br&gt;&lt;hr size=&quot;1&quot;&gt; <br>, ^, z9 l, Q1 S/ l5 K6 v
&lt;table border=&quot;1&quot; cellpadding=&quot;0&quot; cellspacing=&quot;0&quot; style=&quot;border-collapse: collapse&quot; bordercolor=&quot;#111111&quot; width=&quot;100%&quot; height=&quot;180&quot;&gt; <br>; |& U, x" L  a4 j+ [8 N( o
&lt;tr&gt; <br>
: ?) V3 M, N7 {6 S- K! x/ U& O. j&lt;td width=&quot;21%&quot; height=&quot;22&quot;&gt;&lt;b&gt;作者:&lt;/b&gt;&lt;%=show(&quot;name&quot;)%&gt;&lt;/td&gt; <br>' N3 F' M2 E2 G) {) N
&lt;td width=&quot;79%&quot; height=&quot;22&quot;&gt;&lt;b&gt;主题:&lt;/b&gt;&lt;%=show(&quot;title&quot;)%&gt;&lt;/td&gt; <br>
3 c* L+ V# y7 J& ?2 J&lt;/tr&gt; <br>% z; P* Y* c! b4 Z7 G
&lt;tr&gt; <br>
/ ^* ?2 d6 V3 f/ o&lt;td width=&quot;100%&quot; colspan=&quot;2&quot; height=&quot;158&quot; valign=&quot;top&quot;&gt;&lt;b&gt;&lt;br&gt;内容:&lt;/b&gt;&lt;%=show(&quot;body&quot;)%&gt;&lt;/td&gt; <br>
0 Y. l% s+ W8 b&lt;/tr&gt; <br>2 ]! V; M  |8 I- m
&lt;/table&gt;&lt;%set show=nothing%&gt; <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(&quot;id&quot;) <br>
' K) {! a4 N- n8 [" m: f在讲解index.asp文件的后面已经说到:show.asp?id=&lt;%=showbbs(&quot;id&quot;)这一句, <br>
. P+ s# r  b# r3 q7 w% V& a1 wid=request.querystring(&quot;id&quot;)就是把地址栏中的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(&quot;id&quot;)语句把数字读取下来 <br>' ?' M& A7 A3 P, R6 L
于是接着使用:set show=conn.execute(&quot;select*from bbs where id=&quot;&id&&quot;&quot;) <br>. r0 v# P0 x  h: h
向数据表查询id为这时读取下来的数字的帖子,即where id=&quot;&id&&quot; <br>
4 \! b* R6 _8 N& y: S最后&lt;%set show=nothing%&gt; <br>0 A1 N' e$ a3 k
<br>- k9 _, I, c5 [2 K) |
好了,一个简单的DIY论坛就这样完成了
发表于 2005-3-31 16:38:00 | 显示全部楼层
高手不看也懂,我不懂
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|Archiver|手机版|小黑屋|诚毅小家 ( 小家社区工作室 闽ICP备05007965号 )

GMT+8, 2025-2-23 19:55 , Processed in 0.056701 second(s), 23 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表