前言
flash编程俺不熟,跟java的语法较相近,应要求需要flash与数据库通讯,或者间接通讯。于是在网上找相关的文章,装了个Flash CS3 ,也看到网上说不能直接和数据库直接通讯,后来也真让我找到了flash直接连接数据库的文章,是个牛人自己写了一个连接数据库的驱动,叫flashTDS,文章地址:http://space.flash8.net/bbs/viewthread.php?tid=341811。连接SQL2000没有问题,但是连接带实例名的SQL2005死活都连接不上,他的连接字符串:flashtds:MSSqlConnection:localhost:1433/MyFlashDB;user=gates;password=gates88 我把连接字符串改成flashtds:MSSqlConnection:over\sql2005:1433/MyFlashDB;user=gates;password=gates88 不行,sql2005是实例名,把斜杠换成双斜杠、去掉端口都试了就是不行,后来没有再试,放弃了这种办法。然后也找到了用LoadVars方法,都不太理想,后来找到了FluorineFx,觉得比较符合自己的要求,一方面Flash程序员调用起来方面,一方面C#程序员开发起来也比较方便,文中的例子采用《Flash/Flex ActionScript 3.0 交互式开发详解》这本书二十二章第二节第三点(22.2.3)的例子,代码几乎相同,但是需有注意的地方。
需要下载
1. FluorineFx :http://www.fluorinefx.com/ 下载安装,这是VS的一个插件,网上也有相关文章.
正文
1.下载安装FluorineFx,新建一个FluorineFx示例项目:
2.新建项目之后会生成很多文件,可以先浏览一下,尤其是Web.config文件,然后在App_Code下编写测试连接类:
Test.cs
using
System;
using
System.Data;
using
System.Configuration;
using
System.Web;
using
System.Web.Security;
using
System.Web.UI;
using
System.Web.UI.WebControls;
using
System.Web.UI.WebControls.WebParts;
using
System.Web.UI.HtmlControls;
///
<summary>
///
Test 的摘要说明
///
</summary>
public
class
Test
{
public
Test()
{
//
//
TODO: 在此处添加构造函数逻辑
//
}
///
<summary>
///
///
</summary>
///
<param name="sName"></param>
///
<returns></returns>
public
string
hello(
string
sName)
{
return
"
hello,
"
+
sName;
}
}
3.修改配置文件Web.config,这里注意了,大家就不要走弯路了,用默认的配置是连不上的,我是后来找它自带的例子的时候才找到可用的配置文件的,如下,直接覆盖就行。
<?
xml version="1.0"
?>
<!--
Note: As an alternative to hand editing this file you can use the
web admin tool to configure settings for your application. Use
the Website->Asp.Net Configuration option in Visual Studio.
A full list of settings and comments can be found in
machine.config.comments usually located in
\Windows\Microsoft.Net\Framework\v2.x\Config
-->
<
configuration
xmlns
="http://schemas.microsoft.com/.NetConfiguration/v2.0"
>
<
configSections
>
<
sectionGroup
name
="fluorinefx"
>
<
section
name
="settings"
type
="FluorineFx.Configuration.XmlConfigurator, FluorineFx"
requirePermission
="false"
/>
</
sectionGroup
>
</
configSections
>
<
fluorinefx
>
<
settings
>
<!--
value="browse|access"
-->
<
remotingServiceAttribute
>
browse
</
remotingServiceAttribute
>
</
settings
>
</
fluorinefx
>
<
connectionStrings
/>
<
system.web
>
<
httpModules
>
<
add
name
="FluorineGateway"
type
="FluorineFx.FluorineGateway, FluorineFx"
/>
</
httpModules
>
<
compilation
debug
="true"
>
<
assemblies
>
<
add
assembly
="System.Messaging, Version=2.0.0.0, Culture=neutral, PublicKeyToken=B03F5F7F11D50A3A"
/></
assemblies
></
compilation
>
<
authentication
mode
="None"
/>
</
system.web
>
</
configuration
>
4.编写flash的CS文件,这里是用的NetConnection进行连接的,cs代码如下:
RemotingConnection.as
package
{
import
flash.net.NetConnection;
import
flash.net.ObjectEncoding;
import
flash.net.URLLoader;
import
flash.net.URLRequest;
import
flash.events.Event;
import
flash.system.Security;
public
class
RemotingConnection
extends
NetConnection
{
public
function RemotingConnection(gatewayUrl:String)
{
//
设置通信权限
Security.allowDomain(gatewayUrl);
//
设置数据格式
this
.objectEncoding
=
ObjectEncoding.AMF0;
//
连接网关
this
.connect(gatewayUrl);
}
}
}
ConnectionASPNET.as
package
{
import
flash.display.Sprite;
import
RemotingConnection;
import
flash.net.Responder;
public
class
ConnectionASPNET
extends
Sprite
{
public
var gateway:RemotingConnection;
public
var responder:Responder;
public
function ConnectionASPNET()
{
//
连接网关
//
http://localhost
:1968/Gateway.aspx
//
http://localhost
:1968/FluorineFx/GateWay.aspx
gateway
=
new
RemotingConnection(
"
http://localhost:1968/Gateway.aspx
"
);
//
调用类
gateway.call(
"
Test.hello
"
,
new
Responder(onResult,onFault),
"
lalo
"
);
}
/**
*************************
* 返回成功
*
*/
public
function onResult(resultt:Array):
void
{
trace(resultt);
}
/**
*************************
* 返回失败
*
*/
public
function onFault(fault:String):
void
{
trace(fault);
}
}
}
说明:
a)as调用的时候用的是类的全限定名加方法名称,很明显ASP.NET这边是要用反射来找这个类了。
b) new Responder 第二个参数可以设置为null,表示不接受错误返回,默认也是null
c) call 方法最后的参数是不定的,也就是你传的参数,可以不传,也可以传1个、2个、3个......
5.走到这一步基本上没有什么问题了,能够通讯了,但是调用起来有点麻烦,因为不是阻塞式的,不能直接调用就能拿到返回值,用了接受返回值的回调函数onResult,咋办?我的办法就是用一个变量保存验证前后的状态,像这样:
//null 未完成通讯
public
var CheckFlag:String
=
null
;
在接受的地方把代码改成
CheckFlag
=
resultt;
接受结果时用Timer来阻塞当前线程来等待服务器返回数据,如下
var oneMinuteTimer:Timer
=
new
Timer(
500
,
3
);
oneMinuteTimer.start();
oneMinuteTimer.addEventListener(TimerEvent.TIMER,timerevent);
function timerevent(e:TimerEvent) {
if
(asp.CheckFlag
==
null
)
{
//
说明还没有通讯完毕,继续等待
}
else
{
//
显示到swf的文本框
tbShowInfo.text
=
asp.CheckFlag.toString();
//
终止Timer
oneMinuteTimer.removeEventListener(TimerEvent.TIMER,timerevent);
}
}
结束
折腾一天,不容易,呵呵,标记,欢迎有朋友能推荐更好的办法。这里已经和ASP.NET通讯上了,再间接连接数据库就不用再说了。