返回列表 发帖

用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 {
附件: 您需要登录才可以下载或查看附件。没有帐号?注册

返回列表
【捌玖网络】已经运行: