|
  
- UID
- 1
- 帖子
- 738
- 精华
- 28
- 积分
- 14387
- 金币
- 2479
- 威望
- 1647
- 贡献
- 1427
|
用Dreamweaver制作ASP动态网页(图解五)
第六步 查找密码系统
- _: P' ?$ ~# k. u k 1,建立第一个页面 1.asp,其主要作用是让查找密码的朋友输入其用户名,很简单的页面:一个name文本输入框,和一个submit提交按钮。
1 e& S: V7 b; E; H. w& \7 D
" h5 {. z3 u( M, {$ w9 E 2,1.asp中选form标记,在相应的属性框中,“动作”填写2.asp,“方法”采用post。
+ R: M1 D8 f$ R' I J" T+ Q
) E6 @0 H+ O5 U$ I0 b, s 3,保存1.asp,在站点里面新建2.asp,并打开它。
, }; J# i1 B$ q/ P& s, j# H" g 该页的作用有两个:
+ G4 V( E. R1 j, [; ? 1,判断上一页,即1.asp所填写名字在数据库中是否存在。
4 _9 ^7 A1 G2 k3 K H4 d# E" F! y 2,不存在应提示出错,存在则应将该用户的问题(question)字段内容显示。3 R- @6 n1 c( S5 \- }# u: m
具体怎么实现呢?9 j" M3 z# Y ^$ ^4 s/ Q% J2 H
4,2.asp上数据库已经连好。老方法,先绑定记录集(“应用程序”面板--“绑定”标签下“+”“记录集(查询)”)。在弹出的“记录集”中就要好好设置了。最主要的就是“筛选”,选择"name" "=" "表单变量" "name"。, r* i, t- [* d' P9 s5 k
意思是,要显示数据库表中字段name的内容,得有个条件,那就是:从上一页(1.asp)中书写的name表单内容要和库中的字段name值相等。4 e3 p6 q. o3 _& L$ V. D7 R y- a- U
3 T4 ^+ ?6 n% C% S! v5 ?( g
5,其实切换到“高级”就可以看到自动生成的SQL代码,其中就有requeset.form("name"),意思就是把1.asp文本框中输入的值接受过来。
% g( s c3 B- F
5 E- ~& F- a$ ]: |9 v 6,在2.asp页面敲入不存在该用户的提示语言"嘿嘿,这个用户还没有注册,所以你就没必要找密码了。"4 a! ?# t1 \6 f; T1 L( c; q5 r# {
换行再敲入存在该用户的语句。但与此同时还要注意把密码问题SHOW出来,以及问题的答案做成文本框。
; @5 Y5 P$ [" t0 A# L
6 x1 p4 L9 k; f1 O/ V- K4 a9 b, c 7,选中2.asp的form标签,属性面板中动作填写3.asp,方法采用post。3.asp主要就是用来判断问题和答案是否吻合,如吻合则显示正确密码了。注意!是问题和答案在一起。而我们当前只有答案可以传过去,那我们的问题该怎么传到3.asp呢?
; v y% @# o" I# F* k0 f6 o Q! t " b% f+ n3 `) k" {! P
8,在“你的密码问题是:”后面插入光标,然后从“绑定”的“记录集”中选择“question”插入或者直接拖入到页面。注意!这还只是显示给用户密码问题,是不能将此信息传过去的。那怎么样才可以呢?3 q! e4 p* L) b4 D9 Y
9 r) N! m# D5 H# T
9,我们采用“隐藏域”来传送question的值。插入一“隐藏域”(PS:有人不会插入吗?呵呵),对“隐藏域”的属性进行修改:“隐藏区域”名称就叫"question"吧,“值”点击后面的闪电图标,弹出对话框中选择“question”。已经完成对“隐藏域”question的赋值,同样也可以进行传递。
* t8 Q* q9 x6 M9 o& s. h 7 T. M+ ]7 Y l0 [; H+ a( V& G6 y, T
10,剩下的就是把2.asp中的两部分严格分开了。0 B6 q7 o8 j& Q/ r6 V) d
选中“嘿嘿,这个用户还没有注册,所以你就没必要找密码了。”这段文本。
{/ M0 l/ r! ~8 C “应用程序”面板“服务器行为”“+”“显示区域”“记录为空则显示区域”。' U+ s! i! j% G$ E) b6 `8 \ U" ^
弹出对话框中选择刚刚建立的recordset1即可。
3 v7 ~# s5 V- f. _: c7 w3 [' W4 y 意思很明显:如果没有找到满足SQL语言查询的记录集就显示该行错误提示。
( j1 p" {1 ~6 Z
4 J3 {. o. i! M: Y7 U8 d 11,同样,选择form表单,“应用程序”面板“服务器行为”“+”“显示区域”“记录不为空则显示区域”。
_' q2 P5 Z: T. h: n 弹出对话框中选择刚刚建立的recordset1即可。
1 n* z' A Z: d4 P; k: h6 @, M, S 意思也很清楚:如果有满足SQL语言查询的记录集就显示问题和答案书写框。* V& u/ ^' y9 Z
最终效果页应该如下:" x9 I. B& I3 m8 x4 E' D: A( M
" l9 T+ L. \/ D% K! q1 Z) t* g 总算把2.asp搞定了。总结下,该页主要起承上启下的作用。先要判断有没有这个用户,如果有,还有把密码问题显示出来,并要能传送到下一页3.asp
, ~% L" Z8 E* s4 F2 \ 12,那3.asp就要判断2.asp过来的密码问题以及答案是否和数据库中的吻合了。' o) F; o4 b5 Y; @0 W8 b
又有两个作用:不吻合,说明密码答案错,返回上页再来!吻合,那就规规矩矩地给人家密码吧,呵呵。8 `. P; Q, b; @6 i
不过有了做2.asp的经验,做3.asp还不是小菜一碟!
9 b6 {! S: D! _/ L1 n 13,保存2.asp,在站点新建3.asp并且打开它。老规矩,绑定记录集(“应用程序”面板--“绑定”标签下“+”“记录集(查询)”)。
( r1 p" s" O& D2 o( W) B) r. g 在弹出的“记录集”中就要值得你要小心注意了。" {* V# h; X+ Z
“筛选”,选择"question" "=" "表单变量" "question"
* p. | M. s# O! _0 b/ S: @9 z * { l% W3 T/ i7 `5 }4 p
14,但你有没有注意到,我们要传送两个值给3.asp接受的,但现在只能一个进行选择。那该怎么办呢?切换到“高级”SQL的相关代码。我们要稍加添加。
+ i* R* m: p S1 }. [8 ]: J SQL结构查询语言会一点,模仿能力强一点,呵呵就过来了!
) G6 C1 j! O0 D+ ]$ \7 h: t “变量”添加一个“MMAnswer”,“运行值”当然就是“request.form("answer")”了% X- l2 w7 W6 {
然后把SQL语言加一下and answer = 'MMAnswer'1 A$ ~9 a7 i' U6 t
看SQL的意思就明白了:必须要求 question and answer和数据库表中两字段的值吻合。
& A2 {, C3 z. n# I3 v
, Q: `- w. z* e( C% { 15,接着,象做2.asp样快速设计3.asp
* S2 e# E- m7 M/ \9 c 页面上书写不吻合的语句“呵呵,你的问题答案不是这个吧,要不回去再试试? ”并且选中后,同样是“应用程序”面板“服务器行为”“+”“显示区域”“记录为空则显示区域”。
, q6 M! |7 ]/ ]0 L R* Q; F 接着是吻合的情况,“你的密码是:”的后面,从“绑定”“记录集”中选择“pwd”插入或者直接拖入到页面;; ]7 Q- F& H+ Z
并且还要选中该部分,“应用程序”面板“服务器行为”“+”“显示区域”“记录不为空则显示区域”。
: ~# P# W/ j" E% T7 e! V0 |1 r
0 ^$ ?% t3 ?' U& P' F 16,保存3.asp,大功告成!来调试下。
, F- d! r8 @5 o7 R9 [ ! H7 h+ s$ R: m
" j" M& ?; o! w C9 n. M5 h
第七步:修改资料篇! E# x5 ]: J) [/ e4 `/ _
修改资料!首先要清醒一点,什么人才可以修改。
7 b7 T( S, p3 l& v, s1 l 一,本人只能修改自己的;二,管理员可以修改所有人的。$ P+ n. {8 g# ^& s; i
那今天先来搞个可以修改自己资料的页面。
% T6 w5 y0 _; w9 k: ]9 w 顺序是:先确认是正确登录,然后才是自己的资料出现,再接着你才可以修改,对吧。" u9 x+ I" z! G& I$ C
还记得---菜鸟也学DW做ASP。(登录系统篇)
4 W1 ^; e* I6 s ]1 E: C 这里面的loginok.asp页面还在的吧。不在也不要紧。再做一遍,当作练习的。
0 f c' O7 O) t8 O8 b4 C 好了吧。loginok.asp主要是个人信息页面,不同的用户显示不同的信息。
8 ~+ k" ?8 K/ U, k 这个页要注意的:是一保护页面,要添加“限制对页的访问”的;当然相信你已经做了。& q0 }) c0 H. |/ c2 F/ O R9 X
那接着就是显示记录,来!动手了!
; {; ~, h! D3 W f2 P3 m3 m" L& j 1,loginok.asp中“应用程序”面板“绑定”标签“+”“记录集”。( G* v7 [6 p5 `, X5 l
修改资料篇
. L$ M0 R" R2 I8 f- u8 L" q 今天是学习怎么做修改资料的ASP页面' \/ Z4 i2 Q. C$ ]! f
修改资料!首先要清醒一点,什么人才可以修改。
8 K( D/ G8 C; [5 G# j# ~. G1 ~! v 一,本人只能修改自己的;二,管理员可以修改所有人的。; S& f2 D; x8 e
那今天先来搞个可以修改自己资料的页面。2 o0 [. ?4 s. M6 ]. c& r
顺序是:先确认是正确登录,然后才是自己的资料出现,再接着你才可以修改,对吧。. [% t# e0 b3 h( H* Q
还记得---菜鸟也学DW做ASP。(登录系统篇)
$ {* |" E, {4 ^# Q8 g 这里面的loginok.asp页面还在的吧。不在也不要紧。再做一遍,当作练习的。& g, f( K% ^; M2 t; e
好了吧。loginok.asp主要是个人信息页面,不同的用户显示不同的信息。
0 k3 \$ a5 w+ e" w1 w( _8 A4 | 这个页要注意的:是一保护页面,要添加“限制对页的访问”的;当然相信你已经做了。$ G7 @4 K4 f0 ?" n# R
那接着就是显示记录,来!动手了!9 j# u) H& c+ e8 ~7 i) h& O/ n
1,loginok.asp中“应用程序”面板“绑定”标签“+”“记录集”。
% r. C4 K8 Y' d3 ^( E) T9 { 1 D. v8 i9 ^0 [
2,弹出的对话框中,好好设置下!主要是筛选那块:"name""=""阶段变量""MM_username"。9 D1 j2 R3 q9 z- y% z
' J- U' ^/ w- f, @5 \ 3,切换到“高级...”其实就是生成了SQL:SELECT * FROM user WHERE name='MMColParam' ,并且MMColParam是一变量,运行的时候被赋上Session("MM_username")值。
% @ q/ [8 d- x$ k 很好理解,loginok.asp所绑定以及要显示的记录,有一条件:就是按WHERE后面的去找。, c& y0 c/ k( n# b' A
不愁找不到!因为只有当Session("MM_username")不存在才找不到。
5 U% j/ {, x0 F& h/ w8 [+ H) c 而如果Session("MM_username")不存在那说明这家伙根本还没有正确登录。% @/ o O9 K: U* A
呵呵,有点像鸡和鸡蛋的问题。
! x2 O0 F+ q. m# s; p6 s
& W$ Q) O% w* n7 N4 ?6 ~ 4,其实,这个时候你只要选择“应用程序”--“更新记录表单”就可以做我们的修改了。+ e7 |+ b, O8 D ^: S
但个人感受,先不去用这个,采用其它的办法同样可以,并且还能学到更多的知识。何乐而不为?
( T: ]3 k& u+ E+ Z ' e5 j% v5 k% C$ F/ T: T
5,下面,那就跟我来。再让你学一手主详细页面的制作。
`6 ?1 @* F* e- s/ } 有关主详细页,顾名思义。先来个笼统的显示(主要的),对哪个感兴趣,常会来个“详情请进”。
8 G7 F; n% [) o 当然在这个页子里面是没有多大用处的,因为主来详去就你一个用户信息。
' v# p) N/ y; {% i |) t0 U& Y. n/ l 但如果是管理员的页面呢?对这个用户具体查看一下就要用到了。) @7 ?8 ?8 {5 y4 [& k1 {5 A R. o: r% I
, R/ L; B9 ?, Z
6,在弹出的对话框中,"记录集"Recordset1无需理会,"主页字段"意思就是在主页面上要显示的字段信息。
. S* \2 q4 a6 R3 E 因为是主,其他不要显示的字段就一个个按“—”删除吧,主得只剩下大名name。/ ]# {% a0 L3 c) ?
那下面的连接到详细信息就只有选择“name”了。
7 y# m, c5 S/ r" ^ ? “传递唯一键”就选自动编号ID吧,当然其他的也可以选,但一定要确认你所选的在数据库表中一定要有内容。比如一些人注册的时候QQ号码不一定写,那这时候你就不能选oicq做为“传递唯一键”
4 A9 c3 | {7 u- X* V (所谓“传递唯一键”,就是asp中传递URL参数值。君不见xxx网址是http://www.cnbruce.com/blog/showlog.asp?cat_id=27&;log_id=219,那“?”后面的是什么玩意,cat_id就是参数,27就是值,当然后面不光只要一个参数,多个参数就用&连起来。当然这些东西,学asp的都知道了。DW做,呵呵,不要理解这么多,但你一定要学。)1 V4 {. p* R9 X6 ^ U
然后是"详细页名称",因为还没有做,当然推荐你先不做,为什么?自有玄机!3 y! o% H. w1 ~+ ?. Q, a
就先命名个“xiangxi.asp”吧。6 b9 S! \1 m! i( u- P8 V, A
“详细页字段”就不改吧。好!确定。
0 X1 ?) t3 K$ I6 W
6 N+ P5 P4 s8 t/ ^: S4 i3 G 7,确定后,一段时间的等待,突然发现,DW自动生成了xingxi.asp(刚才玄机所在)。不光页面内容生成,连“记录集”也绑定好了,动态文本也添加了。(真是服务周到)
( h' r* v+ m. K: u' ~1 w
* b! N* P! X# r( H 8,再看看loginok.asp。有不少东西,看得眼睛发呆,这些大都是和xiangxi.asp进行挂钩连接用的,不是垃圾,甭怕,呵呵。+ r a5 Q% p! A& S
$ M3 R) G, b/ L1 s9 g$ L
9,然后做什么事呢?回到xiangxi.asp吧。我们要修改资料,那得有些文本的框框让我填写啊。那这时候就有个死办法,先选中整个表瘢琧trl+x把表格给剪了。立马回到表单工具部分,插入表单,在出来的虚线框中ctrl+v粘贴过来。
3 w) [6 @4 {* D8 P ~ * ~# j( D. E- p
10,接下来,添加文本框。先把{Recordset1.xxx}一个一个删掉,只留下一个ID和name因为这两个不需要修改,也不能修改!; j" Q: ?/ B5 o
其余的,换成对应的文本框,注意“文本域”打上对应的名字。4 l" N9 O8 x9 e5 [0 I
在对表格加一行,添加两个按钮。: C- w! z A# D, ^: m
$ J# V5 ~4 F- E1 @
11,再想想,那些文本框里面是不是空的,正常修改资料的时候还会显示到原有的信息的。所以,选中表单。“应用程序”“绑定”“记录集”中相应的字段。
6 B4 a! k! w: q1 B8 W, \- ` " V9 b: M7 ~0 `# r9 R
或者,采用文本框的属性里面设置初始值,点动态闪电图标,弹出对话框中选择对应字段。
6 x2 V. K; e5 S7 O" X9 ^; ?
0 I* ~' R3 H1 T) d& q5 w) b& } 12,好了以后,选中form表单。。“应用程序”--“服务器行为”--“+”--“更新记录”% x% N; H: A/ n
% c, e8 B- V9 ^3 ?
13,弹出窗口中,一般默认。“在更新后,转到:”老规矩先写个xiugaiok.html,以后再来建。7 D% l% N1 u. i; P" m9 \
5 I6 ?% C- y2 p! U 14,当然,该页还没有结束,要添加“服务器行为”--“用户身份验证”--“限制对页的访问”,主要还是起保护作用,不能随便就能进入的。4 ]6 |) y, m" q# ^; _
最后在把xiugaiok.html做下了,大体内容:修改成功!返回loginok.asp。6 L8 b- N4 U; [% L& k! Z6 t
基本完成,可以调试了。先从loginok.asp开始。因为是第一次打开窗口,根本没有登录,所以loginok.asp回自动转向到loginbad.html
( X$ \& j. }' p6 b' E1 T. w/ o* _ ; n: Y, a4 b$ Q
返回到login.asp,一路填下去
: \, A' E. N# o" S8 ?3 J W
0 l4 Z4 G- o/ i$ S7 A. d4 P
9 G4 c7 M: \ h" {0 r 点击“cnbruce”修改密码“789”确定!
& t0 A7 X( o/ f( V# p 1 S& K" X9 j( N9 n9 @5 D; n. q: u
然后,你再返回到 login.asp看看更改密码是不是生效了!1 G" G6 l' @- O( t' E
最后:整个的修改页是越来越复杂了,我采用步骤比较多的方法,当然也附带学到了主详细页的用处。最主要是本人认为这样对初学者才有挑战性,能够灵活运用,扩展,修改,细化,都需要自己多练。有错误是正常的,需要你自己对错误的认识和摆平,只有这样,也许技术才会有所提高。
+ r' @# O5 E1 { |
附件: 您需要登录才可以下载或查看附件。没有帐号?注册
|