目标:
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 点击按钮,数据收发展现成功。
相关推荐
NULL 博文链接:https://zz8.iteye.com/blog/976401
一款仿商城的javaweb项目,可以与后台数据库交互,后台数据库为mysql一款仿商城的javaweb项目,可以与后台数据库交互,后台数据库为mysql一款仿商城的javaweb项目,可以与后台数据库交互,后台数据库为mysql一款仿...
实战突击 JavaWeb 项目整合开发4
不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:仓库管理系统 不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:仓库管理系统 不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:仓库管理...
20个JavaWeb项目源码整合开发,学习练习或者毕业设计都不错
JavaWeb项目报告模板.docxJavaWeb项目报告模板.docxJavaWeb项目报告模板.docxJavaWeb项目报告模板.docxJavaWeb项目报告模板.docxJavaWeb项目报告模板.docxJavaWeb项目报告模板.docxJavaWeb项目报告模板.docxJavaWeb...
教务管理系统javaweb项目教务管理系统javaweb项目教务管理系统javaweb项目教务管理系统javaweb项目教务管理系统javaweb项目教务管理系统javaweb项目教务管理系统javaweb项目教务管理系统javaweb项目教务管理系统...
34个经典javaweb项目实例
实战突击 JavaWeb 项目整合开发5
Flex整合JAVAWEB方面的文档。可以让你清楚的知道如何使用Flex与javaWEB项目进行整合。
80个JavaWeb项目(包含项目源码) ExtS2.2开源网络硬盘系统dogdisk.rar WAP图铃下载系统unimg.rar 北雨下裁系统v1.0.1 bydown101.rar 仿163网盘无刷新文件上传for Jsp_fileupload _jsp.rar 宏软JSP上传系统v1.0 ...
实战突击javaweb项目整合开发项目源代码7-10
JavaWEB项目开发案例精粹,包含大量实际项目开发案例,附带源码,适合拿来巩固Javaweb及框架知识
不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:网络购物中心 不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:网络购物中心 不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:网络购物...
不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:物资管理系统 不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:物资管理系统 不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:物资管理...
不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:网上淘书吧 不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:网上淘书吧 不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:网上淘书吧 ...
5个Javaweb项目+mysql数据库脚本
javaweb项目源代码,含文档注释.很适合初学者以及初级程序员,物流信息网
不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:图书馆管理系统 不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:图书馆管理系统 不错的可用来练手、课程设计、毕业设计的Javaweb项目源码:图书...
JavaWeb 项目 必胜客在线订餐系统 项目需求及源码