<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-57  評論-117  文章-1  trackbacks-0

    開發環境:

    System:Windows

    WebBrowser:IE6+、Firefox3+

    JavaEE Server:tomcat5.0.2.8、tomcat6

    IDE:eclipse、MyEclipse 8

    Flex IDE:Flash Builder 4

    BlazeDS:4.5

    開發依賴庫:

    JavaEE5、blazeDS 4.5

    Email:hoojo_@126.com

    Blog:http://blog.csdn.net/IBM_hoojo

    http://hoojo.cnblogs.com/

     

    一、準備工作

    1、 首先要提供相關的jar包

    Java服務器端需要提供BlazeDS相關的配置和jar包

    下載地址:http://opensource.adobe.com/wiki/display/blazeds/download+blazeds+trunk

    下載后,解壓你可以看到這樣的一個目錄

    clip_image002

    Docs就是文檔

    Resource是源碼

    SampleDB是示例用的數據庫,可以運行startdb.bat來啟動數據庫

    Tomcat是內置的tomcat,如果你沒有tomcat的話可以使用它,在tomcat的webapps目錄中有samples示例

    blazeds.war就是blazeDS的核心文件、庫,你可以把這個war放到tomcat的webapps目錄下,就會自動解壓。當然你也可以自己手動解壓。

    Blazeds-spring.war是和spring整合的配置

    Ds-console.war是blazeDS的控制臺程序

    Samples.war是官方提供的示例

    Samples-spring.war是spring和blazeDS的整合示例

    二、部署服務器端程序

    1、新建一個JavaWeb Project工程,然后在WEB-INF/lib目錄中添加如下jar包

    clip_image004

    這些jar包可以在blazeds.war包中的lib目錄中可以找到

    2、 然后你需要將blazeds.war包中的WEB-INF目錄下的flex目錄復制到當前工程的WEB-INF下

    3、 將blazeds.war包中的WEB-INF目錄下的web.xml的配置,添加到當前工程的web.xml文件中

    4、 最后基本的樣式如下

    clip_image006

    5、 最后你發布當前工程,如果沒有錯誤就表明你服務器端部署成功了。

    6、 編寫一個HelloWorld的java程序。代碼如下

    package com.hoo.flex;
     
    /**
     * <b>function:</b> HelloWorld Example
     * @author hoojo
     * @createDate 2011-8-31 下午06:11:27
     * @file HelloWorld.java
     * @package com.hoo.flex
     * @project BlazeDSServer
     * @blog http://blog.csdn.net/IBM_hoojo
     * @email hoojo_@126.com
     * @version 1.0
     */
    public class HelloWorld {
        
        public HelloWorld() {
        }
        
        public String sayHello(String name) {
            return "[" + name + "] say hello!";
        }
    }

    就一個sayHello方法,接收一個參數。

    三、Flex客戶端程序

    1、創建一個Flex工程,在選擇服務器技術的時候,你需要選擇J2EE。然后勾上使用J2EE技術,然后選擇BlazeDS。點擊Next下一步

    clip_image008

    2、配置根文件夾,也就是JavaEE服務器端發布程序在tomcat中的位置。我這里是在tomcat的webapps的BlazeDSServer中,BlazeDSServer是我的服務器端程序。根URL是訪問服務器端程序的url;上下文目錄對應工程名稱;最后就是輸出文件夾目錄,這個是Flex的文件最后在tomcat中保存的目錄。

    clip_image010

    3、最后你需要設置服務器端的services-config.xml的路徑到編譯參數中,這個很重要!如果你不設置的話,那么你在后面用RemoteObject調用BlazeDS的時候,就需要設置endpoint。設置如下:

    clip_image012

    -services是參數鍵,后面的字符串是值。我這里是設置BlazeDSServer發布到tomcat目錄中的services-config.xml的路徑。

    4、編譯Flex前端代碼,代碼如下:

    <?xml version="1.0" encoding="utf-8"?>
    <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" viewSourceURL="BlazeDSHelloWorld.mxml" layout="absolute" minWidth="955" minHeight="600">
        <mx:Script>
            <![CDATA[
                import mx.controls.Alert;
                import mx.rpc.AsyncToken;
                import mx.rpc.events.ResultEvent;
                
                private function faultHandler(event: Event): void {
                    Alert.show(event.toString(), event.type);
                }
                
                private function resultHandler(event: ResultEvent): void {
                    //event.result是服務器端返回對象
                    result.text = "Message:" + event.result.toString();
                }
                
                private function sendHandler(): void {
                    helloRemoteObject.sayHello(userName.text);
                }        
            ]]>
        </mx:Script>
        
        <!-- 當工程沒有設置編譯器-service參數 或是-context-root等參數,就需要手動設置endpoint參數 -->
        <mx:RemoteObject 
            id="helloRemoteObject" 
            destination="helloWorld" 
            fault="faultHandler(event)" 
            result="resultHandler(event)"
            showBusyCursor="true"/>
        <mx:Panel x="10" y="10" width="272" height="148" layout="absolute" title="BlazeDS Remote HelloWorld Sample">
            <mx:Label x="10" y="22" text="請輸入名稱"/>
            <mx:TextInput x="70" y="19" id="userName"/>
            <mx:Button x="184" y="45" label="發送" click="sendHandler()"/>
            <mx:Text x="10" y="79" id="result"/>
        </mx:Panel>    
    </mx:Application>

    首先你需要將Java服務器端的HelloWorld程序配置在flex的remoting-config.xml中,配置如下:

    <?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>
        
        <destination id="helloWorld">    
            <properties>    
                <source>com.hoo.flex.HelloWorld</source>    
            </properties>    
        </destination> 
    </service>

    上面mxml代碼中的RemoteObject的destination對應的就是remoting-config.xml配置文件中的destination的id。這個是一一對應的,然后在sendHandler方法中,helloRemoteObject對應的就是RemoteObject的id,而sayHello方法對應的就是配置在remoting-config.xml中的destination的source的Java服務器端代碼的公有方法。添加完配置后,需要重啟tomcat。

    運行上面的flex程序后,如果輸入參數后,點擊發送,可以看到服務器端返回的消息就說明BlazeDS整合Flex成功了。

    作者:hoojo
    出處:
    blog:http://blog.csdn.net/IBM_hoojo
             http://hoojo.cnblogs.com
    本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。


    版權所有,轉載請注明出處 本文出自:
    分享道版權所有,歡迎轉載,轉載請注明出處,謝謝

    評論:
    # re: BlazeDS 整合 Flex HelloWorld 示例[未登錄] 2011-09-16 20:59 | Lee
    這東西弄過一次。  回復  更多評論
      
    # re: BlazeDS 整合 Flex HelloWorld 示例 2011-09-17 08:58 | tbw
    還沒有弄過這東西呢   回復  更多評論
      
    主站蜘蛛池模板: 亚洲国产精品人久久电影| 亚洲AV永久无码精品| 波多野结衣视频在线免费观看| 精品国产综合成人亚洲区| 日韩激情无码免费毛片| 亚洲成a人片在线观看无码专区| 两个人看的www免费视频| 一级女人18片毛片免费视频| 一级毛片免费毛片一级毛片免费| 成年女人18级毛片毛片免费 | 国产在线a免费观看| 日韩毛片无码永久免费看| 亚洲AV成人一区二区三区在线看 | 国产亚洲av片在线观看播放| 1000部无遮挡拍拍拍免费视频观看 | 免费v片在线观看品善网| 国产亚洲蜜芽精品久久| 亚洲爆乳AAA无码专区| 九九热久久免费视频| 亚洲一区综合在线播放| 处破痛哭A√18成年片免费| 国产成人精品日本亚洲网址| 丝瓜app免费下载网址进入ios| 69av免费观看| 亚洲精品久久无码| 亚洲精品字幕在线观看| 成人免费男女视频网站慢动作 | 粉色视频免费入口| 亚洲成人激情在线| 暖暖在线日本免费中文| 国内永久免费crm系统z在线| 亚洲 日韩经典 中文字幕 | 亚洲bt加勒比一区二区| 国产福利在线观看免费第一福利| 亚洲福利在线播放| 亚洲AV色欲色欲WWW| 亚洲免费精彩视频在线观看| 国产免费69成人精品视频| 在线免费中文字幕| av无码东京热亚洲男人的天堂| 亚洲第一街区偷拍街拍|