打印

flash与后台通信(ASP)的几种方法

一、使用loadVariables
一个例子简单的描述了如何通过GET方法向服务器端的ASP发送请求:
复制内容到剪贴板
代码:
_root. pushAction = function(URL,) {
    this.loadVariables(URL, "GET");
}
var ask = true;
var pushURL = ”http://localhost/test/return.asp?ask=”+ ask;
pushAction (pushURL);
_root.onEnterFrame = fuction(){
               trace(_root.output);
}
这里首先定义了一个名为pushAction的函数,在loadVariables函数中使用了GET参数。然后定义了一个名为ask的布尔型变量,用来向服务器传递变量。最后使用pushAction函数向服务器上的一个名为return的ASP页面发送GET请求。如果需要对这样的请求作出处理,在ASP中,URL行的分析结果存在于Request对象中,比如下例:
return.asp
复制内容到剪贴板
代码:
<%@ Language="JScript" %>
<%
//声明并定义接受请求的变量
var str_getask= Request.QueryString("ask");
//声明并定义返回信息变量
var str_Msg = "Sorry! Your request tread awry.";
//如果接受到的变量为true,则返回成功消息
if (str_getask == "true"){
  str_Msg = "OK! Your request succeed!";
}
Response.write("output=" + str_Msg);
%>
这样,一个名字为output,值为str_Msg的变量就发送回Flash Player中,可以在flash中以output的名字引用这个变量。当然我们必须注意服务器在处理这个过程中是需要时间的,因此最后那个onEnterFrame用来测试是否有变量返回.
4 Elements Blogs
黑色的风略过我的翅膀,我却无法落下来梳理你的羽毛

Blueidea Web Team
Team Member
二、使用LoadVars
loadVariables提供了一种简单的方法让我们可以从服务器端的ASP或者PHP页面载入变量,除了使用GET方法,它还可以使用POST方法将客户端提交的数据传递给服务器。然而在处理大量客户端与服务器端交互的信息时,使用过多的loadVariables语句会让整个程序的维护性和可读性变得复杂。在Flash MX的Action中,新增加了一个LoadVars的对象,并将它和XML,XMLSocket对象一起归纳于Client/Server对象之下。LoadVars 对象是 loadVariables 动作的替代方法,它能够提供一种更好的结构向服务器发送和返回信息。一个典型的LoadVars对象使用的例子如下:
复制内容到剪贴板
代码:
//构造一个新的LoadVars对象
myload = new LoadVars();
//设定myload的动作,以便服务器验证
myload.action = "post";
//验证和服务器连接的函数
myload.onLoad = function(success) {
//如果和服务器成功连接则…
    if (success) {
//如果验证动作成功则…
        if (this.conn == "1") {
         //将返回对象中的output变量赋值给场景中var为output的Dynamic Text框
            _root.output = this.output;
        }
    } else {
        //如果和服务器连接不成功则返回失败消息,需要检查路径是否正确
        _root.output = "Can't connect to Server";
    }
};
//Dynamic Text的初始值为一个等待消息
_root.output = "Waiting for response...";
//将myload下的变量发送到服务器端,并将服务器返回的数据结果放在myload对象中
myload.sendAndLoad("http://localhost/test/return.asp", myload, "post");
//myload.sendAndLoad("http://localhost:8001/test/return.php",myload, "post");
在场景中以一个var名为output的Dynamic Text框来接受来自服务器的消息。使用LoadVars,我们可以利用sendAndLoad方法将一个LoadVars的实体下的所有变量发送出去,并将服务器返回的数据结果存储到一个目标对象中,其中conn,output都是从服务器发送回来的,我们还利用了其onLoad事件函数来检验其是否将信息发送到了服务器页面,再利用从服务器传回来的数据(this.conn)来验证信息是否正确。服务器页面的代码如下:
ASP return.asp:
复制内容到剪贴板
代码:
<%@ Language="JScript" %>
<%
var str_Msg;
var action;
var conn;
action = Request.Form("action");
if (action == "post"){
    str_Msg = "OK! return a Msg to you!";
    conn = 1;
}
Response.write("conn=" + conn + "&output=" + str_Msg);
%>
PHP return.php:
复制内容到剪贴板
代码:
<?php
$action = $HTTP_POST_VARS["action"];
if ($action == "post") {
    $str_Msg = "OK! return a Msg to you!";
    $conn = 1;
}
echo "conn=" . $conn . "&output=" . $str_Msg;
?>
如果本例执行成功,则会在Flash Player中出现成功画面,如图所示。如果失败,则返回失败消息(一般都是路径出错)


4 Elements Blogs
黑色的风略过我的翅膀,我却无法落下来梳理你的羽毛

Blueidea Web Team
Team Member
三、使用xml
Flash中的XML对象也有方法可以将XML数据向服务器发送。即send和sendAndLoad。send方法向某个 URL 传递 XML 对象,返回的信息都被发送到另外一个浏览器窗口;sendAndLoad 方法向某个 URL 发送一个 XML 对象。返回的信息都放在一个XML对象中。
在某种程度上, XML的send方法和sendAndLoad方法类似于loadVars对象的send方法和sendAndLoad方法。
以login系统为例。首先将Flash中需要传送的信息(用户名和密码)转换成一个 XML 对象,然后将数据作为 XML 文档发送到服务器端脚本。在服务器端我们还是从数据库中提取相应的数据,在服务器端脚本中对这两种信息验证。最后将验证成功的信息也以XML格式传送回Flash。图1显示了这种结构:


首先,看看数据库的结构,很简单,用Access做一个名为login.mdb(存储到同swf,asp文件同同一目录下)的数据库文件,然后新建一个名为admin的表,第一个字段名称是”id”,数据类型是自动编号;第二个字段名称是username,数据类型是文本。字段大小改为16;第三个字段名称为password,数据类型是文本,字段大小也改为16。表结构如图2所示:


接着,我们用Flash做一个登录界面。为了使得这个界面在其他地方也能用到,可以将所有的元件都集中到一个名为login的MC里面。这个MC的基本结构如下:
bg层:用来放置登录界面的背景。第二帧加关键帧;
Title层:用来放置标题MC,MC名字为title,因为只是一个标题,就不列出这个MC的结构了。第二帧加关键帧;
Inputbg层:input文本的背景。
InputTXT层:两个input文本,第一个的var为name,第二个的var为pass,类型为Password,我们要向服务器发送的变量就从这里获得;
Pushbt层:一个确定按钮(名字为pushbt),用来发送一个XML变量,其action如下:
Action for pushbt:
复制内容到剪贴板
代码:
on (release, keyPress "<Enter>") {
//新建一个xml对象,节点明为LOGIN。在属性
    //中存放用户名和密码
    loginXML = new XML();
    loginElement = loginXML.createElement("LOGIN");
    loginElement.attributes.name = this.name;
    loginElement.attributes.pass = this.pass;
    loginXML.appendChild(loginElement);
    //新建一个xml对象,用来存放从服务器返回的信息
    loginReplyXML = new XML();
    loginXML.sendAndLoad("http://localhost/chklogin.asp", loginReplyXML);
    Msg = "正在等待服务器验证";
    gotoAndStop(2);
}
这一层有两帧,第一帧的action为stop();第二帧上的action为
Action for frame2
复制内容到剪贴板
代码:
stop();
function onLoginReply() {
    //提取从服务器返回的数据并判断信息是否正确
    var reply = this.firstChild;
    if (reply.nodeName == "LOGINREPLY" && reply.attributes.login == "1") {
        Msg = reply.attributes.msg;
    }
}
//返回服务器信息
loginReplyXML.onLoad = onLoginReply;
这个MC最后将如图3所示:

↑ login MC的第一帧

↑ login MC的第二帧

这样,如果你输入的name为admin,pass为admin的话,按下确定按钮,服务器的chklogin.asp页面就会接受到以下XML:
<LOGIN pass ="admin" name ="admin" />
在服务器响应并验证了信息之后,需要发送回来以下形式的XML:
<LOGINREPLY login=”1” Msg=someMessage />

最后看看asp怎么写。
chklogin.asp:
复制内容到剪贴板
代码:
<%@ Language="JScript"%>
<%
//创建一个新的DomDocument对象,存入客户端传送过来的XML请求
var xmlReceive = new ActiveXObject("Msxml2.DomDocument");
xmlReceive.loadXML(Request.Form());
var reElement = xmlReceive.documentElement;
//提取用户名和密码信息
password = reElement.attributes[0].nodeValue;
username = reElement.attributes[1].nodeValue;
//创建并打开一个新连接。
var conn = new ActiveXObject("ADODB.CONNECTION");
strconn = "DBQ="+Server.MapPath("login.mdb")+";DefaultDir=;Driver={Microsoft Access Driver (*.mdb)};";
conn.Open(strconn);
//新建并打开一个查询
var rs = new ActiveXObject("ADODB.RECORDSET");
sql = "select * from admin where id=1";
rs.open(sql,conn,1,1);
//开始验证
if (!(rs.BOF && rs.EOF)){
    if (password == rs("password") && username == rs("username")){
        Msg = "恭喜你," + username + "你已经成功登陆!";
        }else if(username != rs("username")){
        Msg = "对不起,您填写的用户名不正确,请返回重新填写";
        }else if(password != rs("password")){
        Msg = "对不起,您填写的密码不正确,请返回重新填写";      
    }
}else{
Msg = "登陆没有成功,看上去服务器出了点问题。"
}
//创建一个新的DomDocument对象,向客户端发送
var xmlRepley = new ActiveXObject("Msxml2.DomDocument");
xmlRepley.loadXML("<LOGINREPLY login='1' msg='"+Msg+"' />");
Response.Write(xmlRepley.xml);
%>
我们知道,Flash中xml.sendAndLoad方法是以HTTP的POST方法发送到服务器页面的,因此这个XML数据存在于Request对象中。在DOM中可以直接象在第5行中使用的方法那样以loadXML的方法加载。
虽然可以使用DOM的其他方法来创建xmlRepley 这个XML文档(例如createNode),但是那样对初学者来说是很难控制的。因此简单的以字串的形式加载到xmlRepley中更为直观。如果你有了一定的经验后,需要利用ADO从数据库中提取数据并封装为XML文档,那么就会发现使用createNode方法会有效率一些。
4 Elements Blogs
黑色的风略过我的翅膀,我却无法落下来梳理你的羽毛

Blueidea Web Team
Team Member

TOP

认证您的手机,获得手机认证图标, 更多手机认证的好处
在同等服务器条件下, 这三种的效率对比怎么样? 呵呵,我没有空间测试
blog: Flashlight (q.pnq.cc)
从理论上说,第三种应该是最慢的。但是从团队协作方面看,使用xml还是有莫大的好处的。这样,flash程序员就可以不用关注后台是如何计算,数据是以什么样的变量名传递进来的。只需要知道xml的结构就可以进行开发了。
4 Elements Blogs
黑色的风略过我的翅膀,我却无法落下来梳理你的羽毛

Blueidea Web Team
Team Member

TOP

难得看到这么完整的flash与后台交互的文章
其实像第二部分那样稍加改动就是一篇flash与ASP,PHP,CF交互的超完整的教程了
把无知当武器?
SWFever.com
不要迷恋哥,哥只是个传说~

TOP

精辟!


rm -rf /

TOP

TOP

使用fscommand调用html中的form也算是一种方法,而且有时为了安全性考虑需要限制asp请求的referer的时候,必须要用这种方式才能达到,前三种都不行
英领科技 引领潮流

TOP

我使用第三种方法测试时如果返回的是中文,则显示的是乱码,英文正常.

TOP

手工老大,ASP俺也习惯用JavaScript写的。
My Hello Snoopy
China Blogs
.NET and Flash develop

TOP

写这个没有考虑国际化,因此在第三例子中as中首行加一句
System.useCodePage = true;
4 Elements Blogs
黑色的风略过我的翅膀,我却无法落下来梳理你的羽毛

Blueidea Web Team
Team Member

TOP

babybug在上个帖子中说
引用:
我使用第三种方法测试时如果返回的是中文,则显示的是乱码,英文正常.
要显示中文,需使用utf-8编码

TOP

我个人用的较多,还是Flash和Xml的结合...
但不知那一种好一点.

TOP

有个原文件看看就好了

TOP

flash我没学过..不知道是不是还可以用xmlhttp呢?
找稳定的工作和老婆...

TOP

乌龟爬到这里干什么?
xmlhttp怎么用? 快讲讲,搬个凳子听...
blog: Flashlight (q.pnq.cc)

TOP

那个好点呢

TOP

LeXRus在上个帖子中说
引用:
flash我没学过..不知道是不是还可以用xmlhttp呢?
没有试过……如果要用到DOM的Serverxmlhttp对象恐怕要多加一层asp页面了。因为flash的XML对象中的send,load和DOM的Serverxmlhttp机制,功能不一样。
其实还可以用socket的,只是服务器端编写socket我始终没有怎么研究。
4 Elements Blogs
黑色的风略过我的翅膀,我却无法落下来梳理你的羽毛

Blueidea Web Team
Team Member

TOP

请教一个问题:loadVariables("test.asp", "", "POST")也可以与ASP通信,那么它的变量是怎么传递的呢?
比如说吧,当前祯的按钮事件:
on (release) {
   loadVariables("test.asp", "", "POST");
}
是否向ASP文件传递的变量就是当前祯中的所有变量的值,而不需要管具体发送哪几个?

TOP

这个通信真是问题多多啊:在FALSH中定义了一个文本框用来接受用户输入,ASP中接受变量值是request.form还是request.QueryString呢?
在FLASH查看文本框的动作出现Unknow Error ID #1086,不知道是什么原因?

TOP

第一个问题:是的。传递当前帧下所有的变量
第二个问题:如果是post方法,应该是在request.form之中。最好trim一下。
4 Elements Blogs
黑色的风略过我的翅膀,我却无法落下来梳理你的羽毛

Blueidea Web Team
Team Member

TOP

很好的教程,但是我发现在中文的返回信息乱码,这是什么回事呀?是asp返回给flash的那些提示信息乱码,不知大家有没有遇到这种情况?

TOP

仔细看一下回帖,已经给出答案了……
4 Elements Blogs
黑色的风略过我的翅膀,我却无法落下来梳理你的羽毛

Blueidea Web Team
Team Member

TOP

我用了另外一种方法,将flash的输出改成是flash 5就可以了!这样还可以向下兼容呢!
不过你的方法在另一些方面可能好一些!

TOP

不错,就是不能提交到远程asp
(我只试了第二种办法)

TOP

我用PHP返回给flash中文信息,可显示的是乱码,
如何让PHP返回unicode(或utf-8)编码的文本?
若是一个记事本文件,我们可以通过“另存为”来改变其编码,可是PHP怎么做到?

TOP

如何作出flash+asp的循环列表~~?
Macromedia Professional WEb Designer

TOP

不好意思,请问一下老大,前两种做出来了,第三种的第二帧的那个等待验证的。txt,是怎么出来的啊?我怎么做不出来啊!?
Msg = "正在等待服务器验证";
就是这句,他是用那个txt提取出来的啊?上面不就说明一个name一个pass吗?
谢谢!
该思考的时候就不要珍惜脑细胞

TOP

好东西!好教程!我珍藏!!

TOP