十二12 发表于 2017-2-6 08:23:07

BlazeDS配置过程和注意事项(tomcat,eclipse,FB plugin)

  首先,网上已经有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;   
   
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 ,首次打开会有加载提示,稍慢,以后则很快! 输入字符,点击按钮,顺利地话你就可以看到返回的字符串了!!!
  最关键的注意事项已经表述如上,祝你好运!!! 
页: [1]
查看完整版本: BlazeDS配置过程和注意事项(tomcat,eclipse,FB plugin)