用 Flash 制作留言板

原文件下载

15-1.jpg  最近我把自己制作的一个 Flash 留言板放到了爬行榜上,引起了大家不小的兴趣,很多朋友纷纷要求提供原始代码,现在,大家已经可以下载到原始代码了,但是,我想,还是要配合一个教程好一些。

  (没有概念的朋友请看这个演示……点这里

  于是,抓紧时间,马上开始写。计划是分成两部分:一部分是ASP部分的分析,另一部分是在 Flash 中的操作。

  下面,我们先来看看数据是怎样经过ASP处理的。

  这个留言板一共有三个文件——Flash SWF 影片文件、ASP程序和留言板数据文件(文本文件)。

一、数据的排列方式

15-0.gif  由于实在没有什么特殊的要求,所以,没有必要使用数据库,只要把留言板的数据格式确定好就可以了,于是,我们确定如左边图显示的这种文本结构。在实际应用中,这个文件叫做 guest.txt。

  这种结构很简单,第一条数据代表一共有多少条留言,中间部分就是内容,最后一个标记着文本文件的结束。

  我来具体解释一下:各个数据都以 & 号开头,因为这样 Flash 在读取的时候就会把它当成一个变量。现在“&total=2”被读入以后,Flash 就会把影片中的 total 设置成 2。

  中间部分也是一样,第一个留言的三个部分是 sub1 name1 text1,而第 n 个留言的三个部分就是 subn namen textn……

  最后的这个“&eof=true”好象意义不大,但是其实它主要是作为标志来用,当 Flash 在读取文件的时候,肯定要显示“正在读取中……”等内容,那么怎样才能判断是否已经完全读取了呢?当然是在“&eof=true”被读取以后(也就是在 Flash 中 eof = true),才算完成。这个时候,我们就可以告诉大家:“完成”了。否则,动画就会循环显示“正在读取中……”,直到完成。

二、ASP完成了什么

  那么,就该我们的ASP程序了,其实它完成的是最基础的工作:读取和写入,其它的功能,比如显示、浏览方式等等都还是由 Flash 完成的。

  首先,参数要全部读取进来(这些数据应该是从 Flash 传来的)。

subject = request("sub")
name = request("name")
text = request("text")
action = request("action")

  先看它的读取功能。本来我们设置了 action=read 的时候去读 guest.txt,但是发现:

  (注意:值得注意)尽管在 Netscape 中已经通过了,可是在 IE 中我们却遇到了挫折,原本不应该受 Cache 左右的 asp 程序竟然不听使唤。每次用户发了新留言以后,死活也不给刷新了。没有办法,我们只得改变战术,在 Flash 中给了 action 一个随机的参数,才解决了这个问题。

  因此,您现在看到的程序是只要有不是“add”的参数就会去执行读的操作。

if (action <> "add") then
  set fin = Server.CreateObject("Scripting.FileSystemObject")
  filepath = Server.MapPath("guest.txt")
  set f = fin.OpenTextFile(filepath)
  
  buf = f.readAll
   
  response.write(buf)

  f.close end if  
  看见了,读取其实很容易,那么下面看写入的:

if (action = "add") then
  
  set fin = Server.CreateObject("Scripting.FileSystemObject")
  filepath = Server.MapPath("guest.txt")
  set f = fin.OpenTextFile(filepath)

  
  line = f.readline
  
  total = int(mid(line,8))

  
  buf = f.readAll

  f.close

  set fout = Server.CreateObject("Scripting.FileSystemObject")

  
  Application.lock

  filepath = Server.MapPath("guest.txt")
  set f = fout.CreateTextFile(filepath,TRUE)

  
  total = total + 1
  
  f.writeline "&total="&total
  f.writeline "&sub"&total&"="&subject
  f.writeline "&name"&total&"="&name
  f.writeline "&text"&total&"="&text

   (将缓冲区的老数据写回)    f.write buf    f.close    (解开锁定)    Application.unlock    (返回成功写入的标志)    response.write("&added=1") end if

  相信有基础的闪客一定会很快就弄明白的。这里做一点说明:

  (1)buf 在这里很关键,它保存着目前留言板上的所有信息。我们要做的其实是:把老信息保留,然后添加入新的信息,再把老信息加在后面。就这样,不断的添加,生成大的留言板数据文件。这是程序的主要功能。

  (2)Application.Lock 和 Application.Unlock 是保护文件的方法,因为有可能出现大家一起读写一个文件的情况,会使数据丢失。使用它们就可以避免这种现象。

  (3)total = int(mid(line,8)) 是简单的 VB 语句,因为 line 读近来以后应该是“&total=12”或者“&total=71”什么的,我们需要的是 12 和 71,但是 Flash 需要“&total=xxx”,所以必须要这样做,使用 mid() 函数可以帮助我们得到“=”号后面的数据。int() 则把得到的字符型数据转换成整型,使之可以进行运算。

  好了,待续。下一部分将是 Flash 里面的手脚。哈哈!
三、Flash 里面的手脚

  完成了ASP部分,我们可以比较蹋实的来做FLASH里面的内容了。

  ASP部分完成了数据的读取和写入,而这些资料进入FLASH以后,则需要进行一定的排列和整理。这些工作在ASP里面做反而有些烦琐,而在FLASH里面来完成,则容易得多了……

  下面,看看我们的 timeline 吧:

16-0.gif

  上面是我们的头一部分,也就是读取和写入的关键部分。我们可以通过阅读程序来了解整个过程。

  在 reading 段,程序是这样的:

Set Variable: "eof" = "false"
Set Variable: "total" = 0
Set Variable: "added" = 0
Set Variable: "sub" = ""
Set Variable: "name" = ""
Set Variable: "text" = ""
Set Variable: "backmethod" = 0
    

(产生随机数) Set Variable: "r" = Random (65500) (通过随机参数调用程序,理由见上一部分 Load Variables ("http://www.yourhost.com/guest.asp?action="& r, "") Set Variable: "temp" = "正在读取信息中……"

  要说明的是:temp 是文本框变量名,temp 等于什么,屏幕上就显示什么。

16-0.gif

  大家看:紧接着程序向下走,经过 read(只是一个标记),继续向下到达了一个 action keyframe。

If (eof ne "true")
Go to and Play ("read")
End If

  这就是我们前面讲过的,直到读完文件,不然总是返回 read 去显示“正在读取信息中……”。如果读取完成,也就是“eof eq "true"”了的话,执行下面一个关键语句。

Set Variable: "total" = Substring ( total, 0, Length ( total ) - 2 ) 

  如果您懂得程序,就不难发现:我们通过这个语句把取得的 total 值截去了两个字节——如果不这样做的话,您会发现返回的 total 竟然有两行,我们这样做是为了取得正确的数值。尽管 Flash 的数据类型不甚讲究,但是这种错误还是会出现的。

16-0.gif

  好了,下面到了我们的 main 了,显示数据总数:

Set Variable: "temp" = "信息读取完成,共有信息条目数:"& total 
Stop 

  总数显示的页面下面会有两个按钮,一个是“查看”,另一个是“添加”,我们先来看简单的那个:“添加”。

  insert 只是停留在一个添加 frame 上,而当用户输入了信息以后,真正的提交工作是在 do_insert 完成:

If ((sub eq "") or (name eq "") or (text eq ""))
 Go to and Play ("error")
Else
 Set Variable: "temp" = "正在向服务器添加数据……"
 
 Load Variables ("http://www.yourhost.com/cgi-bin/guest.asp?action=add", "", vars=POST)

 Go to and Play ("wait2")
End If

  很简单的一个提交,把信息传送到ASP程序去,然后转到 wait2 去等待结果。至于 error,不过是一个出错 frame 罢了,不用关心。

  wait2 等待成功,后面的 action 继续循环,直到知道写入成功为止。到此,添加的工作就完成了。画面上会显示“数据成功写入!”,并且有按钮带用户回到 reading 去。

If (added <> 1)
Go to and Play ("wait2")
End If
    

Set Variable: "temp" = "数据成功写入!" Stop

16-1.gif

  下一个部分,该是“显示”功能了。

  在做这部分的时候,我有点来了脾气,想弄得更好一些,所以,做了一些“多余”的工作。在我写这篇文章的时候,站点上测试的留言已经有几百条了,而且永远不会减少。但是,我当时还是根据自己的想法,把显示功能做了强化:少于6条留言的时候有一种处理,多于6条的还有一种处理。嘿嘿,只有发头几条留言的人才会发现:原来是有一些区别的……哦。其实这个功能真的很多余,完全可以通过程序在后面来解决,现在还给大家增添了读程序的负担,实在对不起各位闪客了。

  所以,view 的程序是这样开始的:

Set Variable: "cur" = total

If (total <= 6)
Go to and Stop ("view6")
Else
Go to and Play ("view6p")
End If

   我们先通过少于等于6条留言的处理,来展示是如何实现显示留言功能的:

Set Variable: "i" = 6
Set Variable: "current" = cur

Loop While (current > 0)
 Set Variable: "t"&i = eval("sub"& current)
 Set Variable: "current" = current - 1
 Set Variable: "i" = i - 1
End Loop

Stop

  我通过简单的方法来显示这小于等于6条留言,而且不用显示有翻页功能的按钮。要说明的是:t6 t5 t4 t3 t2 t1 是按从上到下排列的6个文本框,我们可以轻易的为他们赋值。而在这6个家伙的下面,则有6个长条的按钮——就是我们要按下去看详细内容的那些按钮,它们被点击以后,会带着 b=6 5 4 3 2 1 这6个不同的数值转向 viewdetail。

16-1.gif

  viewdetail 其实也只是一个中间环节,它主要是来判断用户按下的按钮是否是无效的,如果有效,那么就转向真正的显示环节——viewdetail_now:

If (cur <= 6)
 If (b <= (6 - cur))
  Go to and Play ("nosuchitem")
 Else
  Set Variable: "load" = b - 6 + cur
  Go to and Stop ("viewdetail_now")
End If
Else
 Set Variable: "load" = b - 6 + cur
 Go to and Stop ("viewdetail_now")
End If

  关键的地方到了,看看 viewdetail_now 是怎样显示的吧:

Set Variable: "new_sub" = eval("sub"&load)
Set Variable: "new_name" = eval("name"&load)
Set Variable: "new_text" = eval("text"&load)
Set Variable: "new_sub" = Substring ( new_sub, 0, Length ( new_sub ) - 2 )
Set Variable: "new_name" = Substring ( new_name, 0, Length ( new_name ) - 2 )
Set Variable: "new_text" = Substring ( new_text, 0, Length ( new_text ) - 2 )
Set Variable: "the_sub" = new_sub
Set Variable: "the_name" = new_name
Set Variable: "the_text" = new_text
Stop

  我们先把每个数据做了类似 total 的处理,然后将他们赋给相应的文本框,显示就完成了。

  那么,多于6条留言是什么样的呢?我们给它加上了两个按钮,可以用来上下翻页的。他们的 action 其实很简单:

On (Release)
 If (cur <> total)
  Set Variable: "cur" = cur + 6
  Go to and Play ("view6p")
 End If
End On


On (Release)
 If (cur > 6)
  Set Variable: "cur" = cur - 6
  Go to and Play ("view6p")
 End If
End On

16-1.gif

  在多于6条留言的处理上,我们还加上了一些内容:

Set Variable: "i" = 6
Set Variable: "backmethod" = 1
Set Variable: "current" = cur
Loop While (i > 0)
 Set Variable: "t"&i = eval("sub"& current)
 Set Variable: "current" = current - 1
 Set Variable: "i" = i - 1End Loop

  backmethod 是专门为了返回而设置的。当信息很多的时候,用户看完一条,返回的时候却又返回到最前面,那可真的是大煞风景了!所以,我们增加了这个 backmethod,来告诉程序,到时候要返回到用户来的那个页面。(其实,如果把少于等于6条和多于6条的程序合并的话,就不需要这个了。)

  我想,大概的意思我已经都讲到了,具体程序和按钮以及 MovieClip 之间的关系,必须要看原始的 TimeLine 才能完全领会。其实,这篇小文章,还只是一个介绍性的东西吧!

  好了,祝您早日写出自己的论坛!(说了半天很麻烦,其实真正写程序的时候很快啊。)

  有不明白可以去论坛提问,也可以写信给我

  完成了ASP部分,我们可以比较蹋实的来做FLASH里面的内容了。

  ASP部分完成了数据的读取和写入,而这些资料进入FLASH以后,则需要进行一定的排列和整理。这些工作在ASP里面做反而有些烦琐,而在FLASH里面来完成,则容易得多了……

  下面,看看我们的 timeline 吧:

16-0.gif

  上面是我们的头一部分,也就是读取和写入的关键部分。我们可以通过阅读程序来了解整个过程。

  在 reading 段,程序是这样的:

Set Variable: "eof" = "false"
Set Variable: "total" = 0
Set Variable: "added" = 0
Set Variable: "sub" = ""
Set Variable: "name" = ""
Set Variable: "text" = ""
Set Variable: "backmethod" = 0

(产生随机数) Set Variable: "r" = Random (65500) (通过随机参数调用程序,理由见上一部分 Load Variables ("http://www.yourhost.com/guest.asp?action="& r, "") Set Variable: "temp" = "正在读取信息中……"

  要说明的是:temp 是文本框变量名,temp 等于什么,屏幕上就显示什么。

16-0.gif

  大家看:紧接着程序向下走,经过 read(只是一个标记),继续向下到达了一个 action keyframe。

If (eof ne "true")
Go to and Play ("read")
End If

  这就是我们前面讲过的,直到读完文件,不然总是返回 read 去显示“正在读取信息中……”。如果读取完成,也就是“eof eq "true"”了的话,执行下面一个关键语句。

Set Variable: "total" = Substring ( total, 0, Length ( total ) - 2 ) 

  如果您懂得程序,就不难发现:我们通过这个语句把取得的 total 值截去了两个字节——如果不这样做的话,您会发现返回的 total 竟然有两行,我们这样做是为了取得正确的数值。尽管 Flash 的数据类型不甚讲究,但是这种错误还是会出现的。

16-0.gif

  好了,下面到了我们的 main 了,显示数据总数:

Set Variable: "temp" = "信息读取完成,共有信息条目数:"& total 
Stop 

  总数显示的页面下面会有两个按钮,一个是“查看”,另一个是“添加”,我们先来看简单的那个:“添加”。

  insert 只是停留在一个添加 frame 上,而当用户输入了信息以后,真正的提交工作是在 do_insert 完成:

If ((sub eq "") or (name eq "") or (text eq ""))
 Go to and Play ("error")
Else
 Set Variable: "temp" = "正在向服务器添加数据……"
 
 Load Variables ("http://www.yourhost.com/cgi-bin/guest.asp?action=add", "", vars=POST)

 Go to and Play ("wait2")
End If

  很简单的一个提交,把信息传送到ASP程序去,然后转到 wait2 去等待结果。至于 error,不过是一个出错 frame 罢了,不用关心。

  wait2 等待成功,后面的 action 继续循环,直到知道写入成功为止。到此,添加的工作就完成了。画面上会显示“数据成功写入!”,并且有按钮带用户回到 reading 去。

If (added <> 1)
Go to and Play ("wait2")
End If

Set Variable: "temp" = "数据成功写入!" Stop

16-1.gif

  下一个部分,该是“显示”功能了。

  在做这部分的时候,我有点来了脾气,想弄得更好一些,所以,做了一些“多余”的工作。在我写这篇文章的时候,站点上测试的留言已经有几百条了,而且永远不会减少。但是,我当时还是根据自己的想法,把显示功能做了强化:少于6条留言的时候有一种处理,多于6条的还有一种处理。嘿嘿,只有发头几条留言的人才会发现:原来是有一些区别的……哦。其实这个功能真的很多余,完全可以通过程序在后面来解决,现在还给大家增添了读程序的负担,实在对不起各位闪客了。

  所以,view 的程序是这样开始的:

Set Variable: "cur" = total

If (total <= 6)
Go to and Stop ("view6")
Else
Go to and Play ("view6p")
End If

   我们先通过少于等于6条留言的处理,来展示是如何实现显示留言功能的:

Set Variable: "i" = 6
Set Variable: "current" = cur

Loop While (current > 0)
 Set Variable: "t"&i = eval("sub"& current)
 Set Variable: "current" = current - 1
 Set Variable: "i" = i - 1
End Loop

Stop

  我通过简单的方法来显示这小于等于6条留言,而且不用显示有翻页功能的按钮。要说明的是:t6 t5 t4 t3 t2 t1 是按从上到下排列的6个文本框,我们可以轻易的为他们赋值。而在这6个家伙的下面,则有6个长条的按钮——就是我们要按下去看详细内容的那些按钮,它们被点击以后,会带着 b=6 5 4 3 2 1 这6个不同的数值转向 viewdetail。

16-1.gif

  viewdetail 其实也只是一个中间环节,它主要是来判断用户按下的按钮是否是无效的,如果有效,那么就转向真正的显示环节——viewdetail_now:

If (cur <= 6)
 If (b <= (6 - cur))
  Go to and Play ("nosuchitem")
 Else
  Set Variable: "load" = b - 6 + cur
  Go to and Stop ("viewdetail_now")
End If
Else
 Set Variable: "load" = b - 6 + cur
 Go to and Stop ("viewdetail_now")
End If

  关键的地方到了,看看 viewdetail_now 是怎样显示的吧:

Set Variable: "new_sub" = eval("sub"&load)
Set Variable: "new_name" = eval("name"&load)
Set Variable: "new_text" = eval("text"&load)
Set Variable: "new_sub" = Substring ( new_sub, 0, Length ( new_sub ) - 2 )
Set Variable: "new_name" = Substring ( new_name, 0, Length ( new_name ) - 2 )
Set Variable: "new_text" = Substring ( new_text, 0, Length ( new_text ) - 2 )
Set Variable: "the_sub" = new_sub
Set Variable: "the_name" = new_name
Set Variable: "the_text" = new_text
Stop

  我们先把每个数据做了类似 total 的处理,然后将他们赋给相应的文本框,显示就完成了。

  那么,多于6条留言是什么样的呢?我们给它加上了两个按钮,可以用来上下翻页的。他们的 action 其实很简单:

On (Release)
 If (cur <> total)
  Set Variable: "cur" = cur + 6
  Go to and Play ("view6p")
 End If
End On


On (Release)
 If (cur > 6)
  Set Variable: "cur" = cur - 6
  Go to and Play ("view6p")
 End If
End On

16-1.gif

  在多于6条留言的处理上,我们还加上了一些内容:

Set Variable: "i" = 6
Set Variable: "backmethod" = 1
Set Variable: "current" = cur
Loop While (i > 0)
 Set Variable: "t"&i = eval("sub"& current)
 Set Variable: "current" = current - 1
 Set Variable: "i" = i - 1End Loop

  backmethod 是专门为了返回而设置的。当信息很多的时候,用户看完一条,返回的时候却又返回到最前面,那可真的是大煞风景了!所以,我们增加了这个 backmethod,来告诉程序,到时候要返回到用户来的那个页面。(其实,如果把少于等于6条和多于6条的程序合并的话,就不需要这个了。)

  我想,大概的意思我已经都讲到了,具体程序和按钮以及 MovieClip 之间的关系,必须要看原始的 TimeLine 才能完全领会。其实,这篇小文章,还只是一个介绍性的东西吧!

  好了,祝您早日写出自己的论坛!(说了半天很麻烦,其实真正写程序的时候很快啊。)

  有不明白可以去论坛提问,也可以写信给我

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
留言板安装非常简单,适合于需要个性化的用户使用。 此程序版本为v1.4 2009.9.27日更新 安装:首先,你需要有一个支持asp程序的服务器,或者在本地机器上安装pws(win98系统)或者iis(win2000、NT、XP..)然后将bbs整个目录都拷贝Inetpub\wwwroot的目录里,在地址栏输入地址进行测试。安装过程中主要注意的是数据库是data.mdb文件,用acesse打开数据库,输入地址http://localhost/gb/admin/index.asp就可以添加或者删除管理用户。 asp后台的删除还没做,可以直接在留言板里删除,密码登录就行了。 为了安全,最好是把数据库的名字修改掉,然后在相应的网页程序内把名字也修改成你新命名的名字(不懂的先看下简单的asp教程)以前的随机调用背景功能一样有用,将bg0文件夹改成bg就可以生效,里的文件修改后可以 成为背景,并且每次打开背景都不一样。 bg文件夹里共有8个flash文件,如果你想要改背景,可以将里面的文件改成不同的背景或者前景,或者你只要一个就在bg文件夹里放一个swf文件就行了。登录后可能不能及时看到删除按钮,这时点留言板上的“刷新页面”按钮一次就可以看见右边的删除按钮了。 04年5月1日,增加头像功能,暂时放了10个头像可用 头像在image文件夹里,你可以更换成你自己喜欢的头像图片,但要用和现在一样的文件名字,大小最好也和现在的图片一样。 最后,有朋友说不喜欢这个界面,那很容易,你们自己做就是了,那个bg.fla 文件就是留言板的背景界面,大家可以按照自己的喜好或者网站风格去制作自己喜欢的界面。 有空就会继续更新,希望美工好的朋友合作。 祝大家使用愉快! ================= www.52j.com =================
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值