- 浏览: 43067 次
- 性别:
- 来自: 广州
最新评论
-
hzs275481430:
就是讲拓扑图的太少了!
Flex值得一看参考资源 -
igogo007:
无外乎一下几点:
1.包少了
2.包多了
3.包重复了
4. ...
框架整合错误解决方法 -
zolyton:
creationComplete="Init()&q ...
Flex 弹出窗口的例子 -
yexin218:
有点复杂哦
一个Flex做的登陆控件 -
bobkingdom:
精!惊!这么好的贴子居然无人顶,寻寻觅觅好久了,FLEX加载 ...
Flex加载swf的几个要点
FLex 的 Remote Object 之我的实践 (详细教程看我上传的文档)
正文:
一.环境和工具:
Jdk1.6.0
MyEclipse6.5和FlexBuilder3 beta2 插件版
Tomcat 6.0
lcds251(全称为:Flex Data Service
下载地址:http://www.adobe.com/cfusion/tdrc/index.cfm?product=flex)
Windows XP SP2
二.开发前的准备:
下载lcds并安装(注意:由于我使用了Tomcat6.0,所以安装时我选择的是Flex Data Services J2EE web application这一选项,如果选择了JRun的下面的配置可以省去JRun自带Tomcat的).
进入安装目录,将flex.war,samples.war和flex-admin.war拷贝到Tomcat的webapps下,启动tomcat会自动解压的.
如图所示:
(3)为了让Tomcat能与FDS共同工作,还必须安装JOTM(Java Open Transaction Manager)下载地址:http://jotm.objectweb.org/download/index.html(目前的版本是:2.0.10) 下载后解压,将其中lib 目录下的jar文件(13个)全部拷贝到Tomcat的lib目录中.这样,Tomcat就能够解析编译MXML文件,并支持Remoting通信.
三.入门教程
1. 新建FlexLCDS工程
File -> new -> Flex Project …
注:以下设置绝大多数都可以在项目属性中可以修改。
. 向导界面
说明:Java source folder就是你自己java业务源码存放的根目录,在FB3里,LCDS项目旨在将Java J2ee项目和FlexLcds项目混合。
当然如果你不选择 combined 两个在一起,那么就麻烦些:要么你再单独新建一个Flex项目,而这个项目只写java代码。要么再建一个J2ee工程写java代码,而这个项目只写Flex代码,但最后要把Java编译后的class文件放到这个项目下的webroot\web-inf\classes目录中。即不管怎样,最后发布时,java编译后的class文件必须和lcds部署的项目在一起。(听起来绕昏头了?那就在一个工程里吧)
2). 向导界面2
说明:Target runtime实际上没什么用(后来我删除了配置文件里的对应信息,也没问题),但是不指定就不能继续,如果这里显示的是<none>那么就新建一个Tomcat的runtime,简单的只需要指定tomcat的安装目录即可。
Content folder实际上就是最终编译后的容器目录,因此,Lcds的flex.war文件将会发布到 该目录 下的web-inf下的flex目录中。同时因为教程采用的是MyEclipse,他默认的就是发布WebRoot里的内容,为了自动化,因此这里改为了WebRoot(这也是java开发的习惯)
Flex WAR file 指的是安装了lcds后的flex.war文件的路径
Compilation options指定了flex文件的编译方式,选择推荐的在FlexBuilder里编译吧,虽然开发时多耗点时间,但是在发布后不会占用服务器的编译处理时间,对用户来说是有好处的。
Output folder 指的是Flex编译后的swf和html等文件存放的路径,这里改为了WebRoot\bin
3). 向导界面3
说明:Main source folder 是flex的源码存放根目录,当然和java源码分开了。
Output folder URL 是在开发过程中运行和调试的请求路径,这个与发布无关,不会影响任何你在程序中使用的路径,但是能使开发方便
注意:FlexBuilder3这里存在bug,新建工程时,部分自定义的属性并没有保存下来,而必须在新建后的项目属性中更改,后面有说明到
放心这些设置都可以在以后修改。
4). 新建完成的项目结构看起来是这样的
2. 用MyEclipse添加Web容器
之前说到了,MyEclipse是很好用的J2EE的开发插件,其中就包含了部署功能。我们可以抛开烦琐的手动部署,交由MyEclipse完成吧,当然,首先得让你的FlexLCDS工程变成为J2EE的Web工程。
1). 向导界面1
注意:不要点快了,把这里的Create web.xml取消,这样就不会覆盖LCDS创建的web.xml文件
现在我们的工程的图标变成了J2EE Web 工程了,这意味着,你可以用MyEclipse来发布它或者添加更多容器,比如hibernate、spring等
部署FlexLCDS工程
有了MyEclipse,那么你就不用手动的部署你的项目了,可以简单的通过
点击工具栏上的这个图标
1). 部署向导1
注意:(如果你的列表中没有服务器,那么就自己建一个)
2). 新建部署Web应用服务器
注意:如果是MyEclipse6.0,则会自带一个Tomcat服务器。如果不是6.0,那么点Edit server connectors…自己添加一个tomcat。
点finish后则会开始部署。成功后会在Deployment status里提示success,并且看到列表中你的项目已经成功部署
修改一下项目的访问路径
打开项目的属性,在这里,我们可以重新修改项目编译和发布的配置,包括先前向导里的设置
修改output folder url
为什么要这么做?
这样每次发布都会自动将编译的最终swf文件直接发布至WebRoot\bin目录下,而下面的output folder url则会在我们启动和调试项目时,直接请求这个路径(这跟发布无关,只是我们在开发过程中会方便些)
修改Flex Server的项目容器属性(非常重要,多数连接路径错误就是这里配置错误)
改成如下配置
说明:
Root url 当然就是你的web服务器的根路径了,Tomcat默认是8080端口,如果改了就自己修改
Context root 就是LCDS工程的名称(注意:如果你分开为两个工程,则这里指的是你J2ee项目的名称,而不是你Flex项目的名称,因为你在请求Java的数据服务),在Flex请求LCDS时,会采用这个作为参数
http://{server.name}:{server.port}/{context.root}/messagebroker/amf
如果Context root错了,那么永远不可能正确的请求LCDS的服务了。
确定后,我们来运行测试一下这个FlexLCDS项目是否能正常访问
启动服务器
稍等片刻,等到服务器完全启动后继续下面的操作
运行访问
注:如果之前的Output folder url配置正确,那么会自动的弹出访问页面,DEBUG时也是一样。
OK,一切顺利,至此,你已经做到了第一步,即,将Flex项目、LCDS服务成功的整合至J2EE web 项目,这样的好处就是今后发布省的麻烦了。
四.常见错误:
(1) [RPC Fault faultString="[MessagingError message='Unknown destination
'UserManager'.']" faultCode="InvokeFailed" faultDetail="Couldn't establish
a connection to 'UserManager'"]
错误原因:remoting-config.xml配置的java类路径错误或java类不存在
解决:配置正确路径。
(2)[ RPC Fault faultString="[MessagingError message='Unknown destination
'UserManager'.']" faultCode="InvokeFailed" faultDetail="Couldn't establish a
connection to'UserManager'"]
错误原因:java版本问题,JRun 4.0支持到jdk1.4.2,不支持1.5
解决:使用jdk1.4.2
(3) [RPC Fault faultString="Cannot create class of type 'UserManager'."
faultCode="Server.ResourceUnavailable" faultDetail="Type 'UserManager' not
found."]
错误原因:remoting-config.xml配置的java类路径错误或java类不存在
解决:配置正确路径。
注:我的这个remoting-config.xml配置的java类应放在
%\fds2\jrun4\servers\default\flex\WEB-INF\classes\下
(4) Unsupported major.minor version 49.0异常;
错误原因:在J2SE1.4的时候编译的是J2SE1.4的字节码形式,在J2SE5.0是5.0的字节码形式,一般只具有向下兼容性,也就是说在J2SE5.0中可以运行J2SE1.4的字节码,但是反过来则不行,在J2SE1.4下运行了J2SE5.0编译出来的字节码,就会出现上面所说的java.lang.UnsupportedClassVersionError错误了。最后,还要注意一点的是,不仅你的class文件要注意,所有在classpath下用到的lib的jar文件的版本也要注意,如果jar文件里面的class以前是高版本JDK编译出来的字节码形式,那也同样会出java.lang.UnsupportedClassVersionError错误的。
解决:原来是Eclipse里面的设置有了点问题(不知道什么时候被改了)。打开Window--->Preferences,选择里面的Java里面的Compiler,修改右面的Compiler compliance level:的值为1.4。
另外:
我在网上看到的错误,但我这里没发生的:
1.could't invoke XXX method(例如调用具体RO的GetQuote,误写成getQuote)
原因大概是由于具体RO的函数名写错了,由于MXML语言大量使用参数注释型的方式指定对象属性,导致在引号之内的标记无法被编译器识别,问题被延迟到Run-time时刻发现。
2.Send failed
原因是service-config.xml中的channels定义my-amf的{context.root}在Flex Builder编译器参数中未指定其context-root,导致编译的swf文件可能有误;
如图:
解决方法:将Context root路径改为你的项目名称路径, 如图
3.Ljava.lang.NoSuchMethodError...
原因是RO对应的Java代码中可能出现调用不存在的方法。例如某个RO对应Java类Ticker在其函数中GetQuote中new一个StockQuote实例StockQuote x = new StockQuote(param1,param2),但StockQuote类只有一个空参数的构造函数,因此NoSuchMethodError错误被传递到Flex调用RO的客户端。为什么会出现Ticker引用不存在的StockQuote构造函数,原因是没有及时同步代码。比如,StockQuote代码修改了,删除了带参数的构造函数,而依赖此类的Ticker没有及时修正。
4.ReferenceError: Error #1056:无法为a创建属性b
这是一个奇怪的问题,所有同步Java对象类的ActionScript类,即通过metadata关键字RemoteClass指定的类。对应Java类的属性名称不能以大写字母开头。
5.RemoteObject使用过程有几个问题也比较麻烦。
1.编译、配置过程烦琐,例如常见的unknown destination问题就是由于编译或配置过程有误造成的。
2. 编写与Java对象对应的ActionScript对象也是一个比较烦琐的过程。可以归为重复性而且意义不大的工作。可以考虑由工具完成此项任务。想象一 下,对于一个面临需求变化且规模较大的项目,要维护ActionScript与对应Java对象的映射,确实不是件令人愉快的事情。
遇到的几个问题:
1.unknown destination
出错原因可能是flex编译器未制定service参数。
解决方法:在Flex Builder或安装FlexBuilder2插件的Eclipse环境中设置编译器参数,选中Flex项目右键,选中properties,再选择Flex Complier,在附加参数中增加相应参数及值。例如下面两个,黑体是修改前,红体字是修改后。
-locale en_US
-locale en_US -context-root=/flex -services="C:\Program Files\Apache Software Foundation\Tomcat 5.0\webapps\flex\WEB-INF\flex\services-config.xml"
2.could't invoke XXX method(例如调用具体RO的GetQuote,误写成getQuote)
原因大概是由于具体RO的函数名写错了,由于MXML语言大量使用参数注释型的方式指定对象属性,导致在引号之内的标记无法被编译器识别,问题被延迟到Run-time时刻发现。
3.Send failed
原因是service-config.xml中的channels定义my-amf的{context.root}在Flex Builder编译器参数中未指定其context-root,导致编译的swf文件可能有误;
解决方法同1
4.Ljava.lang.NoSuchMethodError...
原 因是RO对应的Java代码中可能出现调用不存在的方法。例如某个RO对应Java类Ticker在其函数中GetQuote中new一个 StockQuote实例StockQuote x = new StockQuote(param1,param2),但StockQuote类只有一个空参数的构造函数,因此NoSuchMethodError错误 被传递到Flex调用RO的客户端。为什么会出现Ticker引用不存在的StockQuote构造函数,原因是没有及时同步代码。比如, StockQuote代码修改了,删除了带参数的构造函数,而依赖此类的Ticker没有及时修正。
5.ReferenceError: Error #1056: 无法为 a 创建属性 b
这是一个奇怪的问题,所有同步Java对象类的ActionScript类,即通过metadata关键字RemoteClass指定的类。对应Java类的属性名称不能以大写字母开头。
例如,StockQuote类在java
java 代码
package com.stockquote;
public class StockQuote {
public StockQuote(){}
public String getCompany(){
return Company;
}
public void setCompany(String company){
this.Company = company;
}
public double getPrice(){
return price;
}
public void setPrice(double price){
this.price = price;
}
private String Company;
private double price;
}
在ActionScrpit中,Company和price必须以小写开头,否则会出错,即无法在Flex调用端反序列该字段。
java 代码
package com.stockquote{
[Bindable]
[RemoteClass(alias="com.stockquote.StockQuote")]
public class StockQuote{
function StockQuote () {
// Constructor code if needed
trace(this);
}
public function getCompany():String{
return Company;
}
public function setCompany(company:String ):void{
this.Company = company;
}
public function getPrice():Number{
return price;
}
public function setPrice(price:Number):void{
this.price = price;
}
public var Company:String;
public var price:Number;
}
}
如上代码,会导致以下错误。
ReferenceError: Error #1056: 无法为 com.stockquote.StockQuote 创建属性 company。
- 我的flex第一步.rar (470.7 KB)
- 下载次数: 109
发表评论
-
一些Flex开源项目的整理
2008-11-29 13:01 1021Adobe APIs 主要包含corelib, mappr, ... -
Flex 弹出窗口的例子
2008-11-19 20:11 2617<?xml version="1.0" ... -
flex3的全屏
2008-11-19 19:26 1753关键字: FullScreen 在浏览器中或独立的播放器中使 ... -
一个Flex做的登陆控件
2008-11-17 19:03 2899最近在学习Flex,之前一直在忙,没空整理一下,现在有空整理整 ... -
初学Flex的一点小小经验
2008-11-17 18:40 15391. Flex结合tomcat Flex只是个运行库或者说 ... -
flex 3 学习小结(状态效果篇)
2008-11-17 13:23 34331 登陆+验证码 <?xml version=&q ... -
Flex学习笔记——关于Flex里的事件
2008-11-17 13:16 3214事件是Flex重要的部分, ... -
Flex值得一看参考资源
2008-11-17 12:53 30451. Flexboxhttp://flexbox.mrinal ... -
Flex中给按钮设置icon图标的例子
2008-11-17 12:47 6231在按钮中嵌入icon图标有两种方法。第一种是在Flex应用中创 ... -
Flex上传文件功能
2008-11-17 12:39 1657upload.mxml <?xml version= ... -
Flex实现QQ网页提取天气信息
2008-11-17 12:26 12221、预备知识 Flex是Adobe提供的基于Flash环境的R ... -
Flex加载swf的几个要点
2008-11-17 10:41 2742今天折腾了大半天Flash与Flex3的配合,特总结一下心得体 ... -
关于Flex中自定义事件
2008-11-17 10:30 1560事件是一个非常有用的功能,通常用于信息传递交互大大提高程序编 ...
相关推荐
flex第一步
### Flex第一步知识点解析 #### 一、Flex简介与特性 Flex是一种开源的Web应用程序开发框架,主要用于构建跨浏览器和跨平台的应用程序。Flex基于Flash Player和Adobe AIR运行时环境,可以创建高性能且丰富的互联网...
《Flex第一步》是一本针对Adobe Flex初学者的入门教程,旨在帮助读者快速掌握Flex开发的基础知识和技能。这本书包含了从基本概念到实际应用的全面介绍,涵盖了ActionScript、MXML、Flex组件、数据绑定以及Flex应用...
本资源有完整的FLEX第一步光盘源代码,包括flex许多实例,其中还有不错的项目实例
在"flex第一步全部源码"中,"library.swf"是一个预编译的SWF文件,它是Flex应用的核心组成部分。SWF是Adobe Flash Player或Adobe AIR播放的二进制文件格式,包含编译后的ActionScript代码和图形资源。"library.swf...
第13、14、15章各自包括了一个完整的程序,这些程序的服务端脚本和Flex程序代码是分开存放的。其中Flex程序代码放在FlexSource文件夹中,服务端Remoting程序代码放在JavaSource或phpSource文件夹中。其它章的服务端...
在本文中,我们将深入探讨“Flex第一步”源码,了解如何使用Flex进行基本开发,以及如何通过源码学习其工作原理。 首先,让我们理解Flex的基本概念。Flex是一个开源的开发框架,主要用于构建基于Flash Player或...
Flex第一步源代码全 在IT领域,Flex是一种用于构建富互联网应用程序(Rich Internet Applications, RIA)的技术,它由Adobe公司开发,主要基于ActionScript和MXML。本资源集成了Flex开发的“第一步”源码,这对于...
这个“Flex第一步源码”压缩包可能是针对初学者或开发者的一个入门教程,包含了一些基本的Flex应用程序示例和源代码。 在Flex开发中,ActionScript是主要的后端编程语言,类似于JavaScript,而MXML则是一种声明式...
本压缩包文件“flex第一步所有源码”提供了学习和理解Flex开发的基础资料,包括源代码和可能的说明文件,帮助初学者迈出Flex编程的第一步。 Flex的主要组成部分包括Flex SDK、Flex Builder(现已更名为Flash ...
Flex是Adobe公司推出的一种用于构建富互联网应用程序(RIA, Rich Internet Applications)的开源框架,它主要基于Flash Player或Adobe AIR运行环境。本资料主要聚焦在Flex 2的应用开发,特别是结合ActionScript 3.0...
Flex第一步光盘源码,作者邱彦林; 内容简介 Flex是开发富互联网应用程序(Rich Internet Application,缩写为RIA)的利器,目前已广泛应用于各种商业领域,如电子商务、行政管理,企业业务流程自动化等方面。本书全面...
《Flex第一步:基于ActionScript3.0的Flex2应用开发》讲述的:Flex是开发富互联网应用程序(RichInternetApplication,缩写为RIA)的利器,目前已广泛应用于各种商业领域,如电子商务、行政管理,企业业务流程自动化等...
Flex第一步prat1.rar Flex第一步prat1.rar
Flex第一步prat1.rar Flex第一步prat1.rar
flex第一步案例11-15
Flex第一步系统开发源码
本章"Flex 第一步 Chapter_3"将深入探讨如何使用Flex进行应用开发,尤其针对初学者,旨在帮助他们快速掌握Flex的基础知识。 在Flex 2的应用开发中,ActionScript 3.0扮演了核心角色。与前一版本相比,ActionScript ...