Flex TXT文件导入

       在上一篇文章中,我们做了一个文件上传、导入组件,其实就是一个文件选择并上传的组件,该组件是基于Blazeds来实现的。本文利用该组件实现Flex客户端Txt文件的导入,并将导入的txt文本数据展现到Flex客户端的AdvancedDataGrid中,其它文件格式如excel等导入同理。

    假设Txt文件内容如下,该文件没有抬头,分别表示用户ID、用户名称、用户IP

103 胡宝强   192.168.12.44

10403   胡建平   192.168.67.192

10405   刘小强   192.168.17.102

10407   许云峰   192.168.28.22

    上文中提到的组件中其文件导入方法为public function importFile(headers:Array):Boolean,该方法调用的是blazeds 服务的public Object[] importFile(byte[] content, List header, String fileType)方法,为此需要实现该方法。该方法核心就是txt文件的生成,txt文件的解析,代码如下:

    public Object[] importFile(byte[] content, List header, String fileType)throws Exception{

       Object[] result = new Object[0];

       String pathname = "/usr/temp/temp01.txt";

       //write file

       FileOutputStream stream = new FileOutputStream(file);

       stream.write(content);

       stream.close();

       //read file

       result = parseTXT(header, pathname);

       file.delete();

       return result;

    }

    private static Object[] parseTXT(List header, String filepath){

       try{

           FileReader reader = new FileReader(filepath);

           BufferedReader br = new BufferedReader(reader);

           String content = null;

           Map map = new HashMap();

           List dataList = new ArrayList();

           while((content = br.readLine()) != null) {

              String[] values = content.split("/t");

              map = new HashMap();

              for(int i=0; i<header.size(); i++){

                  if(i>=values.length){

                     map.put(header.get(i), null);

                  }else{

                     map.put(header.get(i), values[i]);

                  }

              }

              dataList.add(map);

           }

           br.close();

           reader.close();

           return dataList.toArray();

       }catch(Exception e){

           throw new AppException(e);

       }

    }

 

客户端建立一个Flex Application,关键是使用文件导入组件,并将导入结果展示到表格中显示,代码如下:

<?xml version="1.0" encoding="utf-8"?>

<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"

              xmlns:s="library://ns.adobe.com/flex/spark"

              xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600" xmlns:services="services.*"

              width="561" height="292" creationComplete="init()" xmlns:fileupload="fileupload.*">

    <s:layout>

       <s:BasicLayout/>

    </s:layout>

 

    <fx:Script>

       <![CDATA[

           import mx.controls.Alert;

           import mx.rpc.events.FaultEvent;

           import mx.rpc.events.ResultEvent;

           import event.FileImportEvent;

           private var file:FileReference = new FileReference();

           //

           protected function init():void{

              file.addEventListener(Event.SELECT, selectHandler);

              file.addEventListener(Event.COMPLETE, completeHandler);

           }

          

           private function completeHandler(event:Event):void {

              //trace("completeHandler: " + event);

           }

 

           private function selectHandler(event:Event):void {

              this.txtFileInfo.text = file.name;

              this.txtFileInfo.toolTip = "文件大小: "+file.size/1000+ "K";

              //

              file.load();

           }

           //

           protected function btnImport_clickHandler(event:MouseEvent):void

           {

              if(StringUtil.isEmpty(txtFileInfo.text)){

                  Alert.show("请选择文件!");

                  return;

              }

              var data:ByteArray = file.data;

              var type:String = file.type;

              responder.token = ro.importFile(data,[ "user_id","login_name","login_ip"],type);

           }

 

 

           protected function responder_resultHandler(event:ResultEvent):void

           {

              adg1.dataProvider = event.result;

           }

 

 

           protected function responder_faultHandler(event:FaultEvent):void

           {

              Alert.show(event.fault.faultString);

           }

       ]]>

    </fx:Script>

 

    <fx:Declarations>

       <s:RemoteObject id="ro" destination=" fileUpDownloadService" showBusyCursor="true"/>

       <s:CallResponder id="responder" result="responder_resultHandler(event)" fault="responder_faultHandler(event)"/>

    </fx:Declarations>

    <fileupload:FileImporter id="fileImporter" fileFilter="*.txt" x="10" y="30" fault="fileImporter_faultHandler(event)"

        result="fileImporter_resultHandler(event)"/>

    <s:Button id="btnImport" label="导入" x="435" y="10" click=" btnImport_clickHandler(event)"/>

 

    <mx:AdvancedDataGrid id="adg1" x="14" y="75" width="537" height="207">

       <mx:columns>

           <mx:AdvancedDataGridColumn dataField="user_id" headerText="工号"/>

           <mx:AdvancedDataGridColumn dataField="login_name" headerText="用户登录名"/>

           <mx:AdvancedDataGridColumn dataField="login_ip" headerText="用户登录IP"/>

       </mx:columns>

    </mx:AdvancedDataGrid>

</s:Application>

 

 

你可能感兴趣的:(function,String,object,HashMap,Flex,application)