flashAndPHP 简单交互

 

第一章: flash,php mysql 之间的连接

 

讲讲 flash ActionScript ), php mysql 之间的连接,他们三者是如何实现数据相互传送和接收的。在开始之前,请确保您做了如下的准备工作:

 

1, 配置了 apache 服务器, php mysql 等都配置成功。

2, 安装了 flash cs3 或更高的版本。

如果在配置服务器有任何问题,在网站上搜索一下相关的关键字。应该能顺利解决问题。

 

Flash 提供了很多种不同的连接方式,究竟要用那种连接方式来完成项目应根据项目的特点。

 

 

单向通行:

Flash 中的单向通信只是将数据发送给 web 服务器,并不关心服务器是否返回响应和做出什么样的响应。这种通信方式大多数时候用于打开一个 url 连接,例如:

 

var serverFile:String=”http://localhost/callLink.php”;
var urlRequest:URLRequest=new URLRequest(serverFile);
navigateToURL(urlRequest);

 

注: navigateToURL 函数接受两个参数,第一个参数是 URLRequest 的实例,第二个参数叫做窗口(或目标)。默认情况是 _self 。还可以是: ”_blank”,”_parent”,”_top”

 

flash 中还有一种和 navigateToURL 类似的单一连接方式, sendToURL ();它与 navigateToURL 的不同之处在于它不会单独的开一个 web 页面,而是悄悄的把数据发送到 web 服务器,不会妨碍用户的浏览体验。例如:

 

 

var serverFile:String=”http://localhost/callLink.php”;
var urlRequest:URLRequest=new URLRequest(serverFile);
try
{
       sendToURL(urlRequest);
}
Catch(e:Error)
{
//处理错误
}
 

发送数据到服务器

 

在很多种情况下,你可能不仅仅只是想发送一个 url ,你需要在请求一个 url 的同时向服务器发送一些数据。这是,你需要用到 URLVariables 类,这个类能创建包含键值对的对象。这些键值对和标准的 Html 中请求的键值对是相同的。

 

 

var serverFile:String=”http://localhost/callLink.php”;
var variables:URLVariables=new URLVariables();
variables.id=1004;
variables.user=”James”;
var urlRequest:URLRequest=new URLRequest(serverFile);
urlRequest.data=variables;

try
{
       sendToURL(urlRequest);
}
Catch(e:Error)
{
       //处理错误
}
 

上面发送数据的方式是不安全的,因为默认使用的是 get 方式的,这种方式会将数据显示在浏览器的地址栏中。要想安全的发送一些敏感的数据,我们要显示的说明使用 post 传送方式。如下:

 

var serverFile:String=”http://localhost/callLink.php”;
var variables:URLVariables=new URLVariables();
variables.id=1004;
variables.user=”James”;
var urlRequest:URLRequest=new URLRequest(serverFile);

urlRequest.method=URLRequestMethod.POST;
urlRequest.data=variables;

try
{
       sendToURL(urlRequest);
}
Catch(e:Error)
{
       //处理错误
}
 

 

双向通信

 

有些时候你可能想在发送数据后接收一个来自服务器的响应。例如从数据库加载指定用户的信息,你发送用户 ID 并希望接收到有关该用户的信息。

双向通信中的响应一般都由事件监听器处理。例如:

 

 

var serverFile:String=”http://localhost/callLink.php”;
var variables:URLVariables=new URLVariables();
variables.id=1004;
variables.user=”James”;
var urlRequest:URLRequest=new URLRequest(serverFile);

urlRequest.method=URLRequestMethod.POST;
urlRequest.data=variables;

var urlLoader:URLLoader=new URLLoader();
urlLoader.addEventListener(Event.COMPLETE,userResponseHandler);

try
{
       urlLoader.load(urlRequest);
}
catch(e:Error)
{
       //处理错误
}

//处理函数
function userResponseHandler(e:Event):void{
var urlLoader:URLLoader=URLLoader(e.target);
var args:URLVariables=new URLVariables(urlLoader.data);
trace(“User Data:”+args.response);
}
 

 

连接 flash php

先看下面的例子:

首先我们定义一个变量来代表你的服务器的地址:

 

 

var phpFile:String=”http://localhost/connecting/exampleCom.php”;
//在flash中创作一个按钮,并为按钮增加鼠标事件监听器:当按钮按下时调用如下函数:

function callServer(e:MouseEvent):void{

       var urlRequest:URLRequest=new URLRequest(phpFile);

       var loader:URLLoader=new URLLoader();

       loader.addEventListener(Event.COMPLETE,serverResponse);

       loader.load(urlRequest);
}
 

上面的函数创建了 URLLoader URLRequest 实例;但数据加载完成时会调用下面的函数:

 

 

function serverResponse(e:Event):void{

       var loader:URLLoader=URLLoader(e.target);

       var variables:URLVariables=new URLVariables(loader.data);

       //timeTxt为flash中创建的动态文本域,returnValue为php中定义的键值对的键名。

       timeTxt.text=variables.returnValue;

}

//callBtn为flash中按钮的实例名

callBtn.addEventListener(MouseEvent.CLICK,callServer);
 

exampleCom.php 中的代码非常的简单,如下:

 

 

<?php

       // 下面是一个简单的 php 中键值对信息
       print “returnValue=Hello from PHP,time is:”.time();

?>  

 

php 中多个键值对的信息表示如下:

 

<?php

       $userData=”username=James”;

       $userData .=”&id=1004”;

       $userData .=”&level=Reader”;

       print $userData;
?>
 

上面代码的作用就是当 flash 加载这个 php 文件时,它向 php 创送如下的数据:

    

  username=Jame&id=1004&level=Reader;
 

注意到上面的键值对信息很像标准的 POST data

 

链接到 MySql

 

使 php 链接到 php 是很简单的。当你把 php 和服务器都配置正确后,你要做的事情很少,看下面的例子:

 

 

<?php

$host=”localhost”;
$user=” ”;
$pass=” ”;
$link=mysql_connect($host,$user,$pass);
?>
 

mysql_connect 函数接受三个参数,第一个参数是主名。第二个参数是 mysql 数据库的用户名,最后一个参数是 mysql 数据库的密码。该函数返回资源标识符,这个标识符就代表当前 mysql 数据库的连接。这个资源标识符能在以后的 SQL 调用中,例如: mysql_query 和许多其他的函数。如果打印输出¥ link 变量,你会看到如下资源代码:

 

 

<?php
$link=mysql_connect(“localhost”,”root”,” ”);
print “Response:”.$link;
?>
 

上面的代码产生如下的响应:

Response Response id #32

 

持久连接

标准的 mysql_connect 函数在脚本执行完后会自动的关闭连接。但有时候你可能想保持连接状态而不管脚本是否执行完毕。 mysql_pconnect 函数正式用来完成这个任务的。这个函数在脚本执行完后仍然保持连接。下面是建立持久连接的例子:

 

<?php

$link = mysql_pconnect(“localhost”,”root”,” ”);
print “Persistent Resource ID:” .$link;
?>
 

 

关闭连接

一个好的习惯是,在 SQL 执行完毕后移除连接释放资源和内存。调用 mysql_close() 函数就能关闭连接。手动关闭连接并不是必须的,因为当脚本执行完毕后会自动的关闭连接。看下面的例子:

 

 

<?php
$link = mysql_connect(“localhost”,”root”,” “);
print “Response: “ .$link;
//关闭连接
mysql_close($link);
?>
 

mysql_close() 函数接受资源标识符作为参数,当你有多个连接时,这个参数是很有用的。这个参数不是必须的,默认情况会关闭最后一个连接。

: mysql_pconnect ()函数创建的持久连接不能用 mysql_close() 函数关闭。

 

选择数据库

在建立完到 mysql 的链接后,你能选择一个数据库。只有在连接完成并已选择了数据库时,才能查询数据库。函数 mysql_select_db ()函数就是用来选择数据库以便查询的。当然你能用这个函数在数据库之间进行切换。

注:同一时间一个处于活跃状态的连接只能有一个被链接的数据库。

mysql_select_db 函数接收两个参数,第一个参数是数据库的名字,第二个参数(可选的)是连接的资源标识符。

 

下面是选择和连接数据库的例子:

 

 

<?php
$link = mysql_connect(“localhost”,”root”,” “);
mysql_select_db(“db_name”,$link);

//关闭连接
mysql_close($link);
?>
 

mysql_query() 函数

这个函数用来执行 SQL 查询语句,这个函数会返回资源标识符。

 

 

 

 

第二章:使用数据

本章讨论的使用数据工作。在 as 中可以使用两种类型的数据:静态数据和动态数据。在大多数情况下,动态处理优于静态。因为动态数据常常包含数据库成分。

本章所讨论的是在 flash php 中使用动态数据工作。本章我们先学习加载简单的文本文件,然后我们学习加载 XML 的相关知识,最后我们学习更为高级的加载方面的知识。

 

flash 加载数据

flash 加载数据是非常常见的。几乎在每个项目中,都会有一些动态的部分。使用动态数据的目的是尽可能的减少更新的数量。例如:如果你去看某个新闻站点,你将会发现大部分外部的内容都不会改变( logos ,菜单等),这对于 flash 应用程序也是一样的,你将会发现仅仅会有某些特定的部分正真的需要更新。本部分将会涉及加载从 xml 中加载数据,以及加载图像和声音等。

先让我们来看一个使用 flash 加载文本文件的例子:

 

 

var txtFile:String  = “sample.txt”;
var urlRequest:URLRequest = new URLRequest(txtFile);
var loader:URLLoader=new URLLoader();

loader.addEventListener(Event.COMPLETE,loadHandler);
loader.load(urlRequest);

function loadHandler(e:Event):void
{

var loader:URLLoader = URLLoader(e.target);
trace(“Loaded Data:”+loader.data);

} 
 

上面的例子加载一个命名为“ sample.txt ”的文本文件并将该文件的所有内容输出到输出面板。

理解用于加载数据的类

as 中有一系列的用于加载数据的内建类。下面分别讨论这些类:

URLRequest

(内容略,比较简单,在 flash 文档中看一下就 OK 了)

URLLoader

(内容略)

下面我们主要来看一个比较重点的例子(例子总是最能说明问题的):分配多个事件

假定你想处理 Loader 实例的 IOError 事件和 Complete 事件。你可能会输入每个事件处理程序,但是,当处理多个 Loader 实例时这样做是很繁琐的。一个比较简单的做法如下:

 

var txtFile:String = “sample.txt”;
var urlRequest:URLRequest = new URLRequest(txtFile);

var loader:URLLoader = new URLLoader();
assignHandlers(loader);
loader.load(urlRequest);

function assignHandlers(target:*):void
{
target[“addEventListener”](Event.COMPLETE,completeHandler);
target[“addEventListener”](IOErrorEvent.IO_ERROR,ioErrorHandler);
}

function completeHandler(e:Event):void
{
……
}

function ioErrorHandler (e:Event):void
{
……
}
 

flash 加载 xml

在开发的时候我们会经常的和数据打交道,一种比较完美的做法是返回 xml 结构的数据。 xml 是业界的标准,在你开始使用 xml 的时候你便会发现 xml 的优越性了。 xml 是基于标签来定义数据对象的。开发者可以自定义标签。下面看一个例子:

你可能像这样定义你的 xml 文件

 

 

<store>

       <item>
              <name>Book</name>
              <price>Learning</price>
              <inStock>yes</inStock>
      </item>

       <item>
              <name>Football</name>
              <price>4.99</price>
              <inStock>no</inStock>
       </item>

       <item>
              <name>Bike</name>
              <price>89.95</price>
              <inStock>no</inStock>
       </item>

       <item>
              <name>Basketball</name>
              <price>8.95</price>
              <inStock>yes</inStock>
       </item>

</store>
 

 

你可能想加载上面的 xml 文件并显示其中的 items 。这是非常容易做到的。假设我们把上面的 xml 文件保存在 storeItems.xml 中。我们来看一下加载的代码:

 

 

var xmlFile:String = “storeItems.xml”;
loadXML();

function loadXML():void
{
       var urlRequest:URLRequest = new URLRequest(xmlFile);
       var urlLoader:URLLoader = new URLLoader();

       urlLoader.addEventListener(Event,COMPLETE,xmlHandler);
       urlLoader.load(urlRequest);
}

function xmlHandler(e:Event):void
{
       var urlLoader:URLLoader = URLLoader(e.target);
       var xml:XML = new XML(urlLoader.data);

       for each(var item in xml..item)
       {
              trace(item.name);
              trace(item.price);
       }
}
 

 

php 中使用 xml

在本部分学习如何使用 php 加载和管理 xml 文件,在 php 中使用 xml 会开发更具动态的应用。

下面来看一下怎么 php 加载 xml 文件:

 

 

<?php
$xml = simplexml_load_file(‘sample.xml’);
print $xml->sampleNode;
?>
 

接下来看一下发送 xml

php 发送 xml flash 也是非常简单的,首先我们来动态建立 xml 文件:

 

 

<?php
header(“content-type:text/xml”);

$xmlData = “”;
$xmlData .=”<store>\n”;
$xmlData .=   ”<item>\n”;
$xmlData .=”         <name>Book</name>\n”;
$xmlData .=”         <price>19.95</price>\n”;
$xmlData .=”         <inStock>yes</inStock>\n”;
$xmlData .=   “</item>\n”;
$xmlData .=   ”<item>\n”;
$xmlData .=”         <name>Book</name>\n”;
$xmlData .=”         <price>19.95</price>\n”;
$xmlData .=”         <inStock>yes</inStock>\n”;
$xmlData .=   “</item>\n”;
$xmlData .=   ”<item>\n”;
$xmlData .=”         <name>Bike</name>\n”;
$xmlData .=”         <price>19.95</price>\n”;
$xmlData .=”         <inStock>yes</inStock>\n”;
$xmlData .=   “</item>\n”;
$xmlData .=   ”<item>\n”;
$xmlData .=”         <name>Football</name>\n”;
$xmlData .=”         <price>19.95</price>\n”;
$xmlData .=”         <inStock>yes</inStock>\n”;
$xmlData .=   “</item>\n”;
$xmlData .=”</store>\n”;

print “response=” .=$xmlData;
?>
 

上面代码的最后一句有神奇的作用,它将 xml 数据输出到输出缓冲区并最终传到 flash

 

从数据库动态产生 xml

 

 

 

<?php

header(“content-type:text/xml”);

$quer      =     “SELECT * FROM store WHERE inStock=yes”;
$link = mysql_connect(“localhost”,”user”,”pass”);
$result = mysql_query($query.$link);

$xmlData = “”;
$xmlData .=”<store>\n”;

while($row=mysql_fetch_array($result))
{
       $xmlData .=”  <item>\n”;
       $xmlData .=”         <name>” .$row[‘name’]       .”</name>\n”
       $xmlData .=”         <price>”  .$row[‘price’] .”</price>\n”
       $xmlData .=”         <inStock>”     .$row[‘inStock’]    .”</inStock>\n”
       $xmlData .=”  </item>\n”;
}

$xmlData .=”</store>\n”;

print “response=” .$xmlData;

?> 

 

 

 

 

 

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值