`

JavaWeb项目使用BlazeDS整合Flex进行RemoteObject数据交互

 
阅读更多


目标:

1,Java Web Project整合Flex

2,Flex中AS代码调用RemoteObject与Java数据交互

环境:

1,JDK1.6

2,MyEclipse10

3,Adobe Flash Builder 4.7 EclipsePlug-in

4,Tomcat6(绿色版,解压后路径F:\software\develop\apache-tomcat-6.0.36\)

5,blazeds-bin-4.0.1.21287.zip

步骤:

1,已安装MyEclipse10、安装FlashBuilder4.7、安装Adobe Flash Builder 4.7 Plug-in Utility.exe;

2,MyEclipse中建立WebProject:testflexblazeds2;

3,解压blazeds-bin-4.0.1.21287.zip、解压blazeds.war,

 

把blazeds\WEB-INF文件夹下的flex文件夹(包括其中文件)、lib文件夹(包括其中文件)、web.xml文件复制到JavaWeb项目testflexblazeds2的文件夹testflexblazeds2\WEB-INF下面(覆盖);

 

4,在项目testflexblazeds2上右击鼠标,

 

选择“添加/更改项目类型-->添加Flex项目类型”

 

5,在“服务器技术”栏中勾选

 

“使用远程对象访问服务”、选择BlazeDS;

 

6,在“服务器位置”栏中,填写

根文件夹:F:\software\develop\apache-tomcat-6.0.36\webapps\testflexblazeds2

根URL:http://localhost:8080/testflexblazeds2/

上下文根目录:/testflexblazeds2

点击“验证配置”按钮,没有红叉表示验证成功,点击“完成”按钮。



7,Java后台部分建立POJO类(需要序列化)和操作类(响应请求获取数据并返回数据):

 

import java.io.Serializable;

public class Entity1 implements <span style="color:#3366FF;">Serializable </span>{
	
	/**
	 * 
	 */
	private static final long serialVersionUID = 997165529976923500L;
	public String getId() {
		return id;
	}
	public void setId(String id) {
		this.id = id;
	}
	public String getIp() {
		return ip;
	}
	public void setIp(String ip) {
		this.ip = ip;
	}
	private String id;
	private String ip;

}

 

import java.sql.*;
import java.text.SimpleDateFormat;
import java.util.*;

public class Hello1 {	
	
	public String sayHello(String pname){
		SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss:SSS");
		long nw = System.currentTimeMillis();
		String ntime = df.format(new Date(nw));
		System.out.println(ntime);
		
		return "["+ntime +"] Hello: " + pname;
	}
	
	public List getList(){
		Connection con = null;
		
		List<Entity1> lsobj = new  ArrayList<Entity1>();
		
		ResultSet rs = null;
		Statement st = null;
		try {
			con = getConnection();
			st = con.createStatement();
			rs = st.executeQuery("select * from tb1 order by id limit 0,100");

			while(rs.next()){				<pre name="code" class="java">                                Entity1 o = new Entity1();
                               o.setId(rs.getString("ID"));
				o.setIp(rs.getString("ip"));
				lsobj.add(o);
			
			}
			
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}finally{
			try {
				rs.close();
				st.close();
				con.close();
				
			} catch (SQLException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}			
		}
		
		return lsobj;
	}
	
	public static Connection getConnection(){ //连接数据库
		Connection con = null;
		try {
			Class.forName("com.mysql.jdbc.Driver");
			con = DriverManager.getConnection("jdbc:mysql://localhost:3306/db1", "root", "root");			
		} catch (ClassNotFoundException e) {			
			e.printStackTrace();
		} catch (SQLException e) {			
			e.printStackTrace();
		}		
		return con;		
	}
	
	public static void main(String[] args){
		//new Hello1().sayHello("aa");		
		new Hello1().getList();
		
	}

}

 

8,在WEB-INF\flex\remoting-config.xml中增加远程服务destination,文件如下:

 

<?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>
    
<span style="color:#3366FF;">    <destination id="helloWorld">
		<properties>
			<source>com.merrick.Hello1</source>
		</properties>
     </destination></span>
    

</service>


9,在Flex程序文件MXML添加UI数据展现控件、声明RemoteObject服务,文件内容如下:

 

<?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>
		<!-- 将非可视元素(例如服务、值对象)放在此处 -->
		<span style="color:#3366FF;"><mx:RemoteObject id="say" destination="helloWorld" >   </mx:RemoteObject> 	</span>	
	</fx:Declarations>
	
	<s:layout>
		<s:VerticalLayout horizontalAlign="left" paddingTop="20" paddingLeft="10"/>
	</s:layout>
	<s:HGroup>
		<mx:Button x="335" y="80" label=" Click" click="remotingSayHello(event);"/>    		
		<mx:TextInput x="159" y="80" id="tiName"/>  
	</s:HGroup>	
	<s:HGroup>
	     <mx:Label x="109" y="82" text="name: "/>  		
	     <mx:Label text="{say.sayHello.lastResult}" 
				   x="44" y="162" 
				   width="448" height="71" id="lblView" color="#FCEE09" 
				   fontSize="20" fontWeight="bold" 
				   textDecoration="underline" fontStyle="normal"/>         
	</s:HGroup>	
     
    <fx:Script source="asfolder/AsCode.as"/>
	
	<mx:Button x="335" y="80" label="GetRemoteDBListData" click="remotingGetList(event)"/>   
	<mx:DataGrid id="dglst">
		<mx:columns>
			<mx:DataGridColumn dataField="id" headerText="EQUIPID"/>				
			<mx:DataGridColumn dataField="ip" headerText="IP address"/>		
		</mx:columns>		
	</mx:DataGrid>
	
</s:Application>

10,建立AS实体类Entity1as.as(与Java中传递的POJO序列化对象Entity1对应,用于转化数据对象为AS对象)

 

package asfolder
{	
	[Bindable]
	[RemoteClass(alias="com.merrick.Entity1")]
	public class Entity1as
	{
		public var id:String;
		 public var ip:String;		
		
	}
}



11,AS中发送远程服务请求和处理响应的部分AsCode.as,内容如下:

 

//被MXML引用,无需加 package和class
	import mx.collections.ArrayCollection;
	import asfolder.Entity1as;
import mx.rpc.events.FaultEvent;
import mx.rpc.events.ResultEvent;
import mx.controls.Alert;

	public  function remotingSayHello(event:MouseEvent):void{        //远程服务    RemoteObject,调用同一web项目中的POJO,部署运行测试成功*
		var iname:String=tiName.text;              
		say.sayHello(iname);//传递
		
	}  

	public function remotingGetList(event:MouseEvent):void{
		
		say.getList();
		
		say.addEventListener(ResultEvent.RESULT, result_op);
		say.addEventListener(FaultEvent.FAULT, fault_op);	
	}

	public function fault_op(event:FaultEvent):void {
		var faultstring:String = event.fault.faultString;
		Alert.show(faultstring);
	}

	public function result_op(event:ResultEvent):void {//处理List<Entity1>
		
		var objList:ArrayCollection = ArrayCollection(event.result);		
		
		var datalist:ArrayCollection = new ArrayCollection();
		
		for (var i:int = 0; i < objList.length; i++)
		{
			var obj:Entity1as= Entity1as(objList.getItemAt(i)); //类型强制转换 传递POJO对象
			datalist.addItem(obj);
		}
		
		dglst.dataProvider = datalist;
		
				
	}


12,部署项目启动tomcat,启动浏览器测试:

浏览器中访问地址:http://localhost:8080/testflexblazeds2/testflexblazeds2-debug/testflex2.html

点击按钮,数据收发展现成功。



 

分享到:
评论

相关推荐

    BlazeDS 整合 Flex HelloWorld 示例

    BlazeDS是一个开源项目,提供了与Adobe Flex之间的实时数据交互,使得Flex客户端可以与Java服务器进行AMF(Action Message Format)通信,实现高效的异步数据传输。 1. **开发环境**: - 系统:Windows - 浏览器...

    Flex4与JavaWeb工程基于Blazeds初步整合

    NULL 博文链接:https://zz8.iteye.com/blog/976401

    Flex 和JAVAWEB整合文档

    优化Flex与JavaWeb的通信性能,可以采用以下策略:减少不必要的网络请求,使用数据缓存;合理设计数据模型,降低AMF序列化和反序列化的开销;优化服务器端的业务逻辑和数据库查询。 **8. 整合示例** 一个典型的整合...

    34个经典javaweb项目实例

    3. **JDBC数据库操作**:JavaWeb项目通常需要与数据库交互,如MySQL、Oracle等。JDBC(Java Database Connectivity)是Java连接数据库的标准接口。实例中会展示如何编写SQL语句,进行CRUD(创建、读取、更新、删除)...

    一款仿商城的javaweb项目,可以与后台数据库交互,后台数据库为mysql.rar

    一款仿商城的javaweb项目,可以与后台数据库交互,后台数据库为mysql一款仿商城的javaweb项目,可以与后台数据库交互,后台数据库为mysql一款仿商城的javaweb项目,可以与后台数据库交互,后台数据库为mysql一款仿...

    实战突击 JavaWeb 项目整合开发4

    在“实战突击 JavaWeb 项目整合开发4”中,我们主要探讨的是如何将各种JavaWeb技术集成到实际项目中,以提升开发效率和系统性能。这个主题涵盖了多个关键知识点,包括但不限于Servlet、JSP、MVC框架(如Spring MVC)...

    Flex与Servlet之间数据的交互

    Flex与Servlet之间的数据交互是JavaWeb开发中的一个重要环节,它涉及到客户端富互联网应用程序(RIA)与服务器端数据处理的协同工作。Flex作为一个基于Adobe Flash Player的前端开发框架,主要用于创建具有丰富用户...

    不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:仓库管理系统.rar

    不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:仓库管理系统 不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:仓库管理系统 不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:仓库管理...

    5个Javaweb项目

    3. **JDBC与数据库交互**:JavaWeb项目通常需要与数据库进行交互,如MySQL。JDBC(Java Database Connectivity)是Java连接数据库的标准API,通过它,开发者可以编写SQL语句,实现数据的增删改查操作。 4. **框架...

    JavaWeb项目源码整合开发.zip

    JavaWeb项目源码整合开发.zip是一个集合了20个不同JavaWeb项目的压缩包,适合学习者进行实践操作和毕业设计。这些项目涵盖了多种JavaWeb开发技术,为学习者提供了丰富的学习资源,帮助他们掌握实际开发中的技能和...

    通过MyEclpise整合JAVA与FLEX进行通讯(通过将Flex工程加到Java web工程中)

    本话题主要关注如何通过MyEclipse这个流行的Java集成开发环境(IDE)整合JAVA与FLEX,使得它们能够有效地进行通讯。这一过程涉及到将Flex工程添加到Java Web工程中,以便在后端服务器和前端富互联网应用程序(RIA)...

    javaweb项目实训

    在实训中,你需要创建数据库连接,使用JDBC(Java Database Connectivity)API进行数据交互,包括预编译的PreparedStatement对象以防止SQL注入攻击。 其次,前端连接是用户与应用交互的界面。这部分涉及HTML、CSS和...

    javaweb项目文件.zip_javaweb_javaweb项目_javaweb项目开发_racea3s

    在JavaWeb项目中,开发者通常会用到JDBC(Java Database Connectivity)来连接数据库,执行SQL语句进行数据操作。此外,ORM(Object-Relational Mapping)框架如Hibernate或MyBatis也被广泛使用,它们简化了数据库...

    实战突击 JavaWeb 项目整合开发5

    3. 数据库连接:在JavaWeb项目中,通常使用JDBC(Java Database Connectivity)来与数据库交互。此外,ORM(对象关系映射)框架如Hibernate和MyBatis也能提高开发效率,它们提供了更高级别的抽象,使得开发者能用...

    flex + java web 整合

    - **BlazeDS**:BlazeDS是Adobe提供的一个开源项目,它为Flex和Java Web应用之间提供了数据通信的桥梁。 2. **BlazeDS集成**: - 将BlazeDS的lib目录下的必要库文件(如flex-messaging-core.jar、flex-messaging-...

    JavaWEB项目开发案例精粹

    ### JavaWEB项目开发案例精粹 #### 一、概述 《JavaWEB项目开发案例精粹》是一本专注于JavaWEB技术领域的书籍,它汇集了大量的实际项目案例,并提供了完整的源代码供读者学习与参考。本书旨在帮助读者更好地理解和...

    javaweb项目

    JavaWeb项目是一个基于Java技术构建的Web应用程序,它主要用于实现互联网上的交互式服务。这个项目包含源代码,并且有详细的文档注释,非常适合JavaWeb开发的初学者和初级程序员进行学习和实践。物流信息网是一种...

    构建全栈式Flex、BlazeDS和Spring集成解决方案

    7. **测试和优化**:运行项目进行测试,检查数据交互是否正常,优化性能,确保应用稳定可靠。 这样的集成解决方案能够充分利用Flex的前端优势,BlazeDS的数据传输效率以及Spring的后端服务管理能力,打造出高性能、...

    实战突击javaweb项目整合开发项目源代码7-10

    在“实战突击javaweb项目整合开发项目源代码7-10”中,我们主要探讨的是Java Web应用程序的开发过程,特别是如何将多个技术组件整合到一个完整的项目中。这个阶段通常涉及到的主要知识点包括Servlet、JSP、MVC设计...

Global site tag (gtag.js) - Google Analytics