简介
        新的Flex2.0类库里提供了文件类,方便了上传/下载文件。下面的程序demo演示了Flex2.0生成flash来访问本地文件,在flash里上传用户选择的文件到服务器,flash客户端可以处理文件上传进度等多个事件,服务器端是C#写的文件接收模块,把用户上传的文件保存在服务器上。
        Demo演示了ProgressEvent.PROGRESS, Event.SELECT 2个事件的处理方法。

        顺便提一下关于JSP的接收Flex上传文件的方法(很多网友问过这个问题),我建议使用Jakarta Commons FileUpload的文件上传组件,详见:http://jakarta.apache.org/commons/fileupload/

测试效果

Flex2.0文件上传功能(Flex2.0正式版)


Flex2.0文件上传功能(Flex2.0正式版)

测试环境

操作系统:windows2003 Server
Flex版本:Flex 2.0
Flash版本: flash Player 9
WEB服务器:
          IIS 6.0
         .net FrameWork 1.1


客户端代码:FileUpload.mxml

Flex2.0文件上传功能(Flex2.0正式版)<?xml version="1.0" encoding="utf-8"?>
Flex2.0文件上传功能(Flex2.0正式版)
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"
Flex2.0文件上传功能(Flex2.0正式版)    xmlns
="*" creationComplete="init();">
Flex2.0文件上传功能(Flex2.0正式版)    
<mx:Script>
Flex2.0文件上传功能(Flex2.0正式版)        
<![CDATA[
Flex2.0文件上传功能(Flex2.0正式版)            import flash.net.FileReference;
Flex2.0文件上传功能(Flex2.0正式版)            import mx.controls.Alert;
Flex2.0文件上传功能(Flex2.0正式版)            import mx.events.CloseEvent;
Flex2.0文件上传功能(Flex2.0正式版)            import flash.events.*;
Flex2.0文件上传功能(Flex2.0正式版)
Flex2.0文件上传功能(Flex2.0正式版)            private var file: FileReference;
Flex2.0文件上传功能(Flex2.0正式版)
Flex2.0文件上传功能(Flex2.0正式版)            private function init(): void{
Flex2.0文件上传功能(Flex2.0正式版)                Security.allowDomain("*");
Flex2.0文件上传功能(Flex2.0正式版)                file = new FileReference();
Flex2.0文件上传功能(Flex2.0正式版)                file.addEventListener(ProgressEvent.PROGRESS, onProgress);
Flex2.0文件上传功能(Flex2.0正式版)                file.addEventListener(Event.SELECT, onSelect);
Flex2.0文件上传功能(Flex2.0正式版)            }
Flex2.0文件上传功能(Flex2.0正式版)
Flex2.0文件上传功能(Flex2.0正式版)            private function upload(): void{
Flex2.0文件上传功能(Flex2.0正式版)                file.browse();
Flex2.0文件上传功能(Flex2.0正式版)            }
Flex2.0文件上传功能(Flex2.0正式版)            
Flex2.0文件上传功能(Flex2.0正式版)            private function onSelect(e: Event): void{
Flex2.0文件上传功能(Flex2.0正式版)                Alert.show("上传 " + file.name + " (共 "+Math.round(file.size)+" 字节)?",
Flex2.0文件上传功能(Flex2.0正式版)                           "确认上传",
Flex2.0文件上传功能(Flex2.0正式版)                           Alert.YES|Alert.NO,
Flex2.0文件上传功能(Flex2.0正式版)                           null,
Flex2.0文件上传功能(Flex2.0正式版)                           proceedWithUpload);
Flex2.0文件上传功能(Flex2.0正式版)            }
Flex2.0文件上传功能(Flex2.0正式版)            
Flex2.0文件上传功能(Flex2.0正式版)            private function onProgress(e: ProgressEvent): void{
Flex2.0文件上传功能(Flex2.0正式版)                lbProgress.text = " 已上传 " + e.bytesLoaded 
Flex2.0文件上传功能(Flex2.0正式版)                    + " 字节,共 " + e.bytesTotal + " 字节";
Flex2.0文件上传功能(Flex2.0正式版)                var proc: uint = e.bytesLoaded / e.bytesTotal * 100;
Flex2.0文件上传功能(Flex2.0正式版)                bar.setProgress(proc, 100);
Flex2.0文件上传功能(Flex2.0正式版)                 bar.label= "当前进度: " + " " + proc + "%";
Flex2.0文件上传功能(Flex2.0正式版)            }
Flex2.0文件上传功能(Flex2.0正式版)            
Flex2.0文件上传功能(Flex2.0正式版)            private function proceedWithUpload(e: CloseEvent): void{
Flex2.0文件上传功能(Flex2.0正式版)                if (e.detail == Alert.YES){
Flex2.0文件上传功能(Flex2.0正式版)                    var request: URLRequest = new URLRequest("http://localhost/JZService/WebForm1.aspx");
Flex2.0文件上传功能(Flex2.0正式版)                    try {
Flex2.0文件上传功能(Flex2.0正式版)                        file.upload(request);
Flex2.0文件上传功能(Flex2.0正式版)                    } catch (error:Error) {
Flex2.0文件上传功能(Flex2.0正式版)                        trace("上传失败");
Flex2.0文件上传功能(Flex2.0正式版)                    }
Flex2.0文件上传功能(Flex2.0正式版)                    
Flex2.0文件上传功能(Flex2.0正式版)                }
Flex2.0文件上传功能(Flex2.0正式版)            }
Flex2.0文件上传功能(Flex2.0正式版)        
]]>
Flex2.0文件上传功能(Flex2.0正式版)    
</mx:Script>
Flex2.0文件上传功能(Flex2.0正式版)    
Flex2.0文件上传功能(Flex2.0正式版)    
<mx:Canvas width="100%" height="100%">
Flex2.0文件上传功能(Flex2.0正式版)        
<mx:VBox width="100%" horizontalAlign="center">
Flex2.0文件上传功能(Flex2.0正式版)            
<mx:Label id="lbProgress" text="上传"/>
Flex2.0文件上传功能(Flex2.0正式版)             
<mx:ProgressBar id="bar" labelPlacement="bottom" themeColor="#F20D7A"
Flex2.0文件上传功能(Flex2.0正式版)                minimum
="0" visible="true" maximum="100" label="当前进度: 0%"  
Flex2.0文件上传功能(Flex2.0正式版)                direction
="right" mode="manual" width="200"/>
Flex2.0文件上传功能(Flex2.0正式版)            
<mx:Button label="上传文件" click="upload();"/>            
Flex2.0文件上传功能(Flex2.0正式版)        
</mx:VBox>
Flex2.0文件上传功能(Flex2.0正式版)    
</mx:Canvas>
Flex2.0文件上传功能(Flex2.0正式版)
</mx:Application>



服务端代码:WebForm1.aspx



相关文章: