首先,网上已经有N多的BlazeDS配置的文章了,各种实例、图解也很多,在此笔者在重复简述基本过程的同时,会根据自己的实践过程给出几点很需要注意的事项,希望对新手入门很有帮助!
1 准备: java5(or java 6) eclipse3.3(or 3.4), tomcat5.5(or 6.0) , FlexBuilder plugin (from adobe,FB3_WWEJ_Plugin.exe), BlazeDS (blazeds.war)
2 先交待一下概况: 我们在使用这样的配置开发第一个FLEX应用时,需要在eclipse里建两个project,一个是java web,用于写java类提供数据服务;另一个是flex project,用于生成 swf ; 但是最后运行时我们只需要java web,只要你在新建flex project时把输出目录指向到java web的WebContent就好,免去手工同步的麻烦!
3 安装: 按照1中的顺序,从Java开始安装,一直到FB plugin安装完成停止; BlazeDS其实不需要安装,只需要将相关的jar文件和配置文件拷贝至我们的java web项目的对应目录下即可。
4 分别新建java web项目和flex project项目 ,名称随便,比如我们假设java web叫flexapp,flex project 就叫flex1 !
(1 先建java web项目flexapp;建好java web以后,把blazeds.war (or blazeds.rar) 解压,然后将其中的WEB-INF覆盖我们的javaweb项目flexapp的WEB-INF; 然后在src目录新建包和类,写一个HelloWorld :
package org.demo; public class HelloWorld{ public String sayHello(String name) { System.out.println("Name: " + name); return "Hello , " + name; } }
需要注意的是: java web的classes输出目录也按照习惯指向WEB-INF下的classes目录!!!
然后在WEB-INF/flex/目录下找到 remoting-config.xml,打开后在</service>一行的上面加入:
<destination id="helloworld
"
>
<properties>
<source>org.demo.HelloWolrd
</source>
</properties>
</destination>
主要要将这里的source包路径和最后的类名写对,destination 的id就是下文要用到的!!!
(2 再建flex project flex1,一定记得将输出目录指向上述java web项目flexapp的WebContent,这样swf等会自动同步过来,无需手动拷贝! 在此项目中默认新建的main.mxml中输入以下内容:
<?xml version="1.0" encoding="utf-8"?> <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute"> <mx:Script > <![CDATA[ import mx.rpc.events.FaultEvent; import mx.rpc.events.ResultEvent; [Bindable] private var helloResult:String; private function sayHello():void { ro.sayHello(inputText.text); } private function resultHandler(event:ResultEvent):void { helloResult = event.result as String; } ]]> </mx:Script > <mx:RemoteObject id="ro" destination="helloworld " result="resultHandler(event)" endpoint="/flexapp /messagebroker/amf" /> <mx:HBox x="0" y="10" width="100%"> <mx:Label text="Name:" id="nameLabel" height="20" textAlign="center"/> <mx:TextInput id="inputText" textAlign="center"/> <mx:Button label="say Hello" id="nameButton" click="sayHello()" textAlign="center"/> <mx:Label id="resultLabel" text="{helloResult}" height="22"/> </mx:HBox> </mx:Application>
解释: 此处的destination 就是remoting-config.xml中配置的destination标签的Id,一定要一致!!!
此处的endpoint一定要从/flexapp开始写, flexapp就是我们的Java web项目的名称!!!
(3 在此之前都不需要启动tomcat;完成以上步骤后,即可启动tomcat !
然后访问 http://localhost:18080/flexapp/main.html ,首次打开会有加载提示,稍慢,以后则很快! 输入字符,点击按钮,顺利地话你就可以看到返回的字符串了!!!
最关键的注意事项已经表述如上,祝你好运!!!