Flex+BlazeDS简单应用实例

前言:BlazeDS是一个基于服务器的Java远程调用和Web消息传递技术,使得后台的Java应用程序和运行在浏览器上的Flex应用程序能够相互通信,根据实际的项目环境搭建来书写这个简单的Flex_Blazds 实例。

实例的文件树结构如下:

1.Myeclipse 新建一个Web Project命名为 Flex_Blazds,创建后导入BlazeDS 包(含有:META-INF、WEB-INF文件夹)覆盖Flex_Blazds/WebRoot 下的同名文件夹。

2.配置tomcat服务器,选择tomcat版本,复制该项目服务器路径Deploy Location 。

3.选中本项目并创建新的Flex项目,配置服务器位置。Flex项目创建后执行Project / Build Project ,出现错误提示(无法创建 HTML 包装器,右键单击此处以重新创建文件夹 html-template)只需根据提示右键单击自动生成html-template。

4.由于创建的Flex项目默认位于src文件夹下,再此我们重新设置Flex项目的位置。选中本项目右键打开属性窗口,相关设置如下,完成后把Flex_Blazds.mxml移动至flex_src 文件夹下。

5.在Flex_Blazds/src文件夹下新建一个com 包,在这个包下新建一个类 命名为UserServiceImp.java 。

package com;

public class UserServiceImp {
	public String hello(String name){
		return "Hello:" + name;
	}

       public String who(String name){
        return "This is:" + name;
    }
 }

6.修改WebRoot / WEB-INF / flex 下的remoting-config.xml,添加<destination>标签的内容,此处是本项目的核心内容,为flex前端对Java后台的数据调用方式。

<?xml version="1.0" encoding="UTF-8"?>
<service id="remoting-service" 
    class="flex.messaging.services.RemotingService">

    <adapters>
        <adapter-definition id="java-object" class="flex.messaging.services.remoting.adapters.JavaAdapter" default="true"/>
    </adapters>

    <default-channels>
        <channel ref="my-amf"/>
    </default-channels>

	<destination id = "userService">
		<properties>
			<source>com.UserServiceImp</source>
			<scope>session</scope>
		</properties>
	</destination>
</service>
7.编写flex前端内容。
<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009" 
			   xmlns:s="library://ns.adobe.com/flex/spark" 
			   xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600">
	
	<fx:Declarations>
		<!--在 MXML 文件中使用 <mx:RemoteObject> 标记来表示 HTTPService 对象。此标记使您可以访问使用 Action Message Format (AMF) 编码的 Java 对象的方法。-->
		<s:RemoteObject id="userServiceObject" destination="userService" result="{res(event)}" fault="{fau(event)}"/>
	</fx:Declarations>
	
	<fx:Script>
		<![CDATA[
			import mx.controls.Alert;
			import mx.rpc.events.FaultEvent;
			import mx.rpc.events.ResultEvent;
			import com.ServiceProxy;
			
			private function submit():void{
				userServiceObject.hello(txtName.text);
			}
			
			private function res(e:ResultEvent):void{
				Alert.show(e.result.toString(),"操作提示");
			}
			
			private function fau(e:FaultEvent):void{
				Alert.show(e.message.toString(),"操作提示");
			}
		]]>
	</fx:Script>
	<s:HGroup height="100%" width="100%" horizontalAlign="center" verticalAlign="middle">
		<s:Label text="Name"/>
		<s:TextInput id="txtName"/>
		<s:Button label="Submit1" click="{submit()}"/>
	</s:HGroup>
</s:Application>
8.启动服务,并运行程序,结果如下。


9.以上是对Flex和BlazeDS的通信实例演示,接下来是利用执行代理的方式,即通过和后台数据交互的代理 SysServiceProxy.as ,读取remoting-config.xml定义的服务。

在flex_src目录下新建com包,并创建SysServiceProxy.as。

package com {
	import flash.external.ExternalInterface;
	import flash.net.URLRequest;
	import flash.net.navigateToURL;

	import mx.controls.Alert;
	import mx.events.CloseEvent;
	import mx.rpc.AbstractOperation;
	import mx.rpc.AsyncResponder;
	import mx.rpc.AsyncToken;
	import mx.rpc.events.FaultEvent;
	import mx.rpc.events.ResultEvent;
	import mx.rpc.remoting.RemoteObject;

	/**
	 * 和后台数据交互的代理
	 */
	public class ServiceProxy {

		/**
		 * 创建代理后执行此方法,并返回数据
		 * @param destination
		 * @param method
		 * @param onResult 回调函数
		 * @param params 参数(多个参数中间用逗号隔开)
		 */
		public static function execute(destination:String, method:String, onResult:Function, ... params:Array):void {

			try {
				var service:RemoteObject = new RemoteObject(destination);
				service.showBusyCursor = true;
				service.endpoint = 'messagebroker/amf';
				var asyncToken:AsyncToken;
				var operation:AbstractOperation = service.getOperation(method);

				if (params && params.length != 0) {
					asyncToken = operation.send.apply(operation, params);
				} else {
					asyncToken = operation.send();
				}

				asyncToken.addResponder(new AsyncResponder(function(event:ResultEvent, asyncToken:AsyncToken):void {
					if (onResult != null) {
						onResult(event);
					}
				}, function(event:FaultEvent, asyncToken:AsyncToken):void {

					var msg:String;
					var msgModeFlex:Boolean = true;

					if (event.fault && event.fault.rootCause) {
						if (event.fault.rootCause.hasOwnProperty("msg")) {
							msg = event.fault.rootCause.msg;
						} else if (event.fault.rootCause.hasOwnProperty("message")) {
							msg = event.fault.rootCause.message;
						} else {
							msg = event.fault.faultString;
						}
						if (event.fault.rootCause.hasOwnProperty("msgModeFlex")) {
							msgModeFlex = event.fault.rootCause.msgModeFlex as Boolean;
						}
					} else {
						msg = event.fault.faultString;
					}

					Alert.show(msg);

				}, asyncToken));

			} catch (e:Error) {
				Alert.show(e.message);
			}
		}
	}
}
10.修改Flex_Blazeds.mxml, 只需在HGroup标签内添加新的Button。

	<s:HGroup height="100%" width="100%" horizontalAlign="center" verticalAlign="middle">
		<s:Label text="Name"/>
		<s:TextInput id="txtName"/>
		<s:Button label="Submit1" click="{submit()}"/>
		<s:Button label="Submit2" click="{ServiceProxy.execute('userService','who',res,txtName.text)}"/>
	</s:HGroup>
11.启动服务,并运行程序,点击第二个按钮,结果如下。



本文版权归作者所有,欢迎转载学习,但需在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值