和传统的JSP一样,在flex中,有的时候也需要实现文件上传和下载的功能,但是在flex里文件的上传和下载的实现相对来说比较复杂,如何实现,请看下面。
由于flex是一个比较新的技术,在研究的时候,还是按着JSP的方式去尝试,在开始之初,主要有以下几种思路:
A、利用ftp的方式进行文件的上传和下载,需要利用flex的socket接口。
B、利用webService的方式来进行文件的上传和下载
C、利用flex+sevlet+fileupload组件实现文件的上传和下载
在通过比较后,最后选择了第三种,用Flex+sevlet的方式来完成文件上传和下载的功能,理由如下(与上面的思路相对应):
A、涉及到了流的操作,实现起来比较复杂,出现错误的几率比较高
B、关于flex端的可参考的资料比较少,并且还需要启动webservice服务
C、这个技术比较成熟,从flex2.0开始,在flex端已经可以引用FileReference类了,并且在java端有成熟的组件可以使用,所以最后考虑使用该种方法来处理。
一、文件的上传
1、Flex端
A、使用到的类介绍:
FileReference 类提供了在用户计算机和服务器之间上载和下载文件的方法。 操作系统对话框会提示用户选择要上载的文件或用于下载的位置。它主要能实现一个文件的上传。
FileReferenceList 类提供了让用户选择一个或多个要上载的文件的方法。 FileReferenceList 对象将用户磁盘上的一组本地文件(一个或多个文件)表示为 FileReference 对象的数组。
B、使用 FileReferenceList 类 实现多文件上传:
1) 将该类实例化:var myFileRef = new FileReferenceList();
2) 调用 FileReferenceList.browse() 方法,该方法将打开一个对话框,让用户选择一个或多个要上载的文件:myFileRef.browse();
3) 在成功调用 browse() 方法之后,使用 FileReference 对象数组来填充 FileReferenceList 对象的 fileList 属性。
对 fileList 数组中的每个元素调用 FileReference.upload()
代码如下:

/** *//**
* 执行上传操作
* */
private function upLoadFiles():void

{
try

{
selectFileList.browse(new Array(imageFilter, textFilter));
selectFileList.addEventListener(Event.SELECT, selectHandler1);
}
catch (error:Error)

{
Alert.show("文件选择出现错误,请选择正确的文件");
}
}

/** *//**
* 如果文件被选中,则执行该方法
* */
function selectHandler1(event:Event):void

{
var request:URLRequest = new URLRequest("FileUploadServlet");
var upLoadFile:FileReference;
var upLoadFileList:FileReferenceList = FileReferenceList(event.target);
var selectedFileArray:Array = upLoadFileList.fileList;
login =(testPress)(PopUpManager.createPopUp( this, testPress , true));
for (var i:uint = 0; i < selectedFileArray.length; i++)

{
upLoadFile = FileReference(selectedFileArray[i]);
upLoadFile.addEventListener(Event.COMPLETE, UpLoadcompleteHandler);
upLoadFile.addEventListener(ProgressEvent.PROGRESS, progressHandler);
try

{
upLoadFile.upload(request);
}
catch (error:Error)

{
Alert.show(error.message.toString());
}
}
}
function UpLoadcompleteHandler(event:Event):void

{
var upLoadFiles:FileReference = FileReference(event.target);
var fileNames = upLoadFiles.name;
//Alert.show('文件'+fileNames+'上传成功')
login.myLabels.text = '文件'+fileNames+'上传成功';
}
private function progressHandler(e:ProgressEvent):void

{
var proc: uint = e.bytesLoaded / e.bytesTotal * 100;
login.bar.setProgress(proc, 100);
login.bar.label= "当前进度: " + " " + proc + "%";
}
testPress.mxml
<?xml version="1.0" encoding="utf-8"?>
<mx:TitleWindow xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" width="528" height="236">
<mx:Script>
<![CDATA[
import mx.managers.PopUpManager;
public function clickMe():void {
PopUpManager.removePopUp(this);
}
]]>
</mx:Script>
<mx:ProgressBar id="bar" labelPlacement="bottom" themeColor="#F20D7A"
minimum="0" visible="true" maximum="100" label="当前进度: 0%"
direction="right" mode="manual" width="200" x="154" y="84"/>
<mx:Button x="221" y="135" label="关闭" click = "clickMe();"/>
<mx:Label x="173" y="27" id="myLabels" width="157"/>

</mx:TitleWindow>

2、JAVA端
接受Flex端的请求,在JAVA端利用apache的fileupload类库实现上传功能。代码如下:
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Iterator;
import java.util.List;
import java.util.Properties;

import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.FileUploadException;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;

public class FileUploadServlet extends HttpServlet


{

// private String uploadPath = "D:\\upload\\";
private String path = "file_path.properties";
private String skStr = "";
private String uploadPath = "";
private int maxPostSize = 1000 * 1024 * 1024;

public void doPost(HttpServletRequest req, HttpServletResponse res) throws ServletException,
IOException

{
String filePathaa = this.getServletConfig().getServletContext().getRealPath("/");

Properties p = loadProperties(path);

uploadPath = p.getProperty("filepath");

res.setContentType("text/html;charset=UTF-8");
req.setCharacterEncoding("UTF-8");

DiskFileItemFactory factory = new DiskFileItemFactory();
factory.setSizeThreshold(1024*20);

ServletFileUpload upload = new ServletFileUpload(factory);
upload.setSizeMax(maxPostSize);
try

{
List fileItems = upload.parseRequest(req);
Iterator iter = fileItems.iterator();
while (iter.hasNext())

{
FileItem item = (FileItem) iter.next();
if (!item.isFormField())

{
String name = item.getName();

try

{
File skFile = new File(uploadPath + name);
if (skFile.exists())

{
skFile.delete();
item.write(new File(uploadPath + name));

}
else

{
item.write(new File(uploadPath + name));
}

} catch (Exception e)

{
e.printStackTrace();
}
}
}
} catch (FileUploadException e)

{
e.printStackTrace();
}

}

public Properties loadProperties(String path) throws IOException

{


分享到:
相关推荐
这涉及文件上传、下载流处理以及版权保护策略。 6. **界面设计**:Flex提供了丰富的组件库,如Button、TextInput、List等,用于构建美观的用户界面。开发者可以自定义组件样式,实现响应式布局,适应不同设备。 7....
7. **发布部署**:将最终的项目文件上传至服务器,确保可以在网络上访问。 #### 五、扩展学习资源 - **在线教程**:利用W3School、MDN Web Docs等在线资源进行深入学习。 - **开源项目**:参考GitHub上的优秀开源...
西门子S7-200 Smart PLC与昆仑通态触摸屏控制三台台达变频器通讯方案,西门子S7-200 Smart PLC与昆仑通态触摸屏控制三台台达变频器通讯方案,西门子s7 200smart与3台台达VFD-M变频器通讯目标:用触摸屏和西门子smart 控制3台台达变频器通讯 器件:西门子s7 200 smart PLC,3台台达VFD-M变频器,昆仑通态触摸屏(带以太网),中途可以加路由器 控制方式:触摸屏与plc以太网通讯,PLC与变频器通讯485口相连 功能:触摸屏控制变频器设定频率,启停,读取输出频率,电压 说明:是程序,非硬件。 程序有注释,变频器设置,接线都有,一应俱全 ,核心关键词:西门子s7 200smart; 台达VFD-M变频器; 昆仑通态触摸屏; 以太网通讯; PLC与变频器485通讯; 频率设定; 启停控制; 输出频率读取; 电压读取; 程序注释; 变频器设置; 接线。,西门子PLC与台达变频器通讯控制程序:触摸屏操作,频率设定与读取
移动端多端运行的知识付费管理系统源码,TP6+Layui+MySQL后端支持,功能丰富,涵盖直播、点播、管理全功能及礼物互动,基于UniApp跨平台开发的移动端知识付费管理系统源码:多端互通、全功能齐备、后端采用TP6与PHP及Layui前端,搭载MySQL数据库与直播、点播、管理、礼物等功能的强大整合。,知识付费管理系统源码,移动端uniApp开发,app h5 小程序一套代码多端运行,后端php(tp6)+layui+MySQL,功能齐全,直播,点播,管理,礼物等等功能应有尽有 ,知识付费;管理系统源码;移动端uniApp开发;多端运行;后端php(tp6);layui;MySQL;直播点播;管理功能;礼物功能,知识付费管理平台:全功能多端运行系统源码(PHP+Layui+MySQL)
PMSM永磁同步电机仿真中的三电平SVPWM矢量控制与双环矢量控制策略研究——基于Matlab平台,基于Matlab的三电平SVPWM矢量控制PMSM永磁同步电机双环矢量控制仿真研究,PMSM永磁同步电机仿真三电平SVPWM矢量控制matlab PMSM双环矢量控制传统三电平 ,PMSM永磁同步电机; 三电平SVPWM矢量控制; 双环矢量控制; MATLAB仿真。,PMSM仿真与三电平SVPWM矢量控制:双环策略与传统三电平对比研究
三菱FX3U与力士乐VFC-x610变频器通讯案例详解:PLC控制下的变频器操作与设置程序,含接线方式及昆仑通态触摸屏操作指南,三菱FX3U与力士乐VFC-x610变频器通讯案例详解:接线、设置与程序注解,实现频率设定、启停控制与实时数据读取功能。,三菱FX3U与力士乐VFC-x610变频器通讯程序三菱FX3U与力士乐VFC-x610变频器通讯案例程序,有注释。 并附送程序,有接线方式,设置。 器件:三菱FX3U的PLC,力士乐VFCx610变频器,昆仑通态,威纶通触摸屏。 功能:实现频率设定,启停控制,实际频率读取等。 ,三菱FX3U;力士乐VFC-x610变频器;通讯程序;案例程序;注释;接线方式;设置;频率设定;启停控制;实际频率读取;昆仑通态;威纶通触摸屏。,三菱FX3U与力士乐VFC-x610变频器通讯程序及案例:频率控制与读取实践
基于八自由度车辆模型的四轮转向系统横摆角速度控制仿真研究:滑模控制算法的高效表现参考说明,基于滑模控制算法的四轮转向系统横摆角速度控制Simulink仿真模型研究,四轮转向系统横摆角速度控制simulink仿真模型,利用滑模控制算法,基于八自由度车辆模型,控制有比较好的效果,附参考说明。 ,四轮转向系统; 横摆角速度控制; Simulink仿真模型; 滑模控制算法; 八自由度车辆模型; 控制效果,八自由度车辆四轮转向滑模控制横摆角速度仿真研究
内容概要:本文介绍了一系列使用 Python 生态内的不同库和模块,如随机选择、图像处理库(PIL)、动画生成工具(Matplotlib),ASCII 艺术,以及音频播放库(pygame)创建与国庆节日相关的数字资源。这些资源包括祝福文本、静态图像、动态动画、文本艺术形式,以及音乐播放。每个代码示例都简洁而易懂,便于使用者快速复制并进行个性化的修改以适用于各种场合。 适合人群:对 Python 基础有掌握的技术爱好者、程序员、教师或者学生群体。 使用场景及目标:本篇文章提供的实例旨在帮助开发者通过编程的方式为特定节日营造氛围,同时也是一种编程技能练习的方法。目的是让用户学会综合利用各个 Python 库的功能,增强程序间的交流能力,并提升自身对 Python 语言的应用熟练度。 其他说明:尽管例子简单直接但涵盖内容广泛,在实际应用时可以根据个人需要调整或拓展所提供的基础模板。此外文中并未详细探讨涉及到的具体库的基础安装方法,所以可能需要预先确保拥有正确环境才能顺利运行全部示例代码。
整车试验项目清单及DVP模型:全面涵盖整车、系统及零部件,精准掌握开发阶段,助力产品参考开发,整车试验项目清单及DVP模型:涵盖整车、系统与零部件,明确开发阶段参考指南,整车试验项目清单,整车DVP模型,包含整车、系统及零部件,并 给出了项目开展阶段。 可作为整车产品开发参考 ,整车试验项目清单; 整车DVP模型; 整车、系统及零部件; 项目开展阶段,整车DVP模型试验及开发项目清单参考
毕业设计
本资源提供了一套基于OpenCV和Dlib库的完整C++源码,专注于实时人脸识别应用开发。该项目结合了OpenCV的图像处理能力和Dlib的人脸识别技术,实现了多种人脸检测与识别功能,适用于各种实时监控和身份验证场景。 关键功能包括: 人脸检测与标记:从图片中自动检测并标记所有人脸,帮助快速识别和定位。 人脸特征点标记:识别并标记图片中所有人脸的68个特征点,提供详细的人脸特征分析。 特征点绘制与编号:在图片中检测人脸并绘制其特征,同时对68个特征点进行编号,便于进一步处理和分析。 目标人物识别: 从指定lib目录中的图片中识别目标人物,实现特定人物的快速识别。 从视频流中识别出lib目录下的目标人物,适用于动态监控场景。 从摄像监控中实时识别目标人物,实现实时安全监控和身份验证。 非特定目标识别:支持识别非特定目标,增强系统的适应性和识别能力。 项目优势: 高效的C++实现:利用C++与OpenCV、Dlib的结合,实现高效、快速的人脸识别处理。 实时应用支持:支持从静态图片到动态视频流的多种输入形式,满足实时应用需求。
疫情数据可视化分析系统采用Django框架,基于mysql开发,实现了首页、个人中心、用户管理、员工管理、疫情信息管理、核酸检测管理、检测预约管理、检测结果管理、行程信息管理、系统管理等内容进行管理
Java使用JNA、JNI两种不同方式调用DLL、SO动态库方式读写读写15693协议ICODE标签、富士通MB89R118标签示例源码,轻松读写块内数据,改写兼容芯片SLIX1830的UID等操作,支持Windows系统,同时支持龙芯Mips、LoongArch、海思麒麟鲲鹏飞腾Arm、海光兆芯x86_Amd64等架构平台的国产统信、麒麟等Linux系统,内有jna-4.5.0.jar包,vx13822155058 qq954486673
台达DVP PLC与力士乐VFC-x610变频器通讯程序详解:从接线到昆仑通态界面实现控制功能全攻略,台达DVP PLC与力士乐变频器通讯编程指南:接线、设置与昆仑通态程序全解析,台达DVP PLC与3台力士乐VFC-x610变频器通讯程序 程序带注释,并附送昆仑通态程序,有接线方式,设置。 器件:台达DVP ES系列的PLC,3台力士乐VFC-x610系列变频器,昆仑通态 功能:实现频率设定,启停控制,实际频率读取等,状态读取指示 ,台达DVP PLC; 力士乐VFC-x610变频器; 昆仑通态; 通讯程序; 注释; 接线方式; 频率设定; 启停控制; 实际频率读取; 状态读取指示,台达DVP PLC与力士乐变频器通讯程序:带注释与接线设置,实现频率控制与状态指示
Fanuc数据采集中文API
Cruise纯电动汽车与增程混动汽车Simulink联合仿真模型搭建与策略研究,Cruise纯电动汽车与增程混动汽车仿真模型:Simulink联合搭建的整车及策略模型详解,cruise纯电动汽车、增程混动汽车仿真模型,simulink联合仿真,模型均亲自搭建。 提供整车模型及策略模型 ,cruise纯电动汽车; 增程混动汽车仿真模型; simulink联合仿真; 模型搭建; 整车模型; 策略模型,基于Simulink联合仿真:Cruise纯电动与增程混动汽车模型搭建与实践
nodejs windows版安装包
在 GEE(Google Earth Engine)中,XEE 包是一个用于处理和分析地理空间数据的工具。以下是对 GEE 中 XEE 包的具体介绍: 主要特性 地理数据处理:提供强大的函数和工具,用于处理遥感影像和其他地理空间数据。 高效计算:利用云计算能力,支持大规模数据集的快速处理。 可视化:内置可视化工具,方便用户查看和分析数据。 集成性:可以与其他 GEE API 和工具无缝集成,支持多种数据源。 适用场景 环境监测:用于监测森林砍伐、城市扩展、水体变化等环境问题。 农业分析:分析作物生长、土地利用变化等农业相关数据。 气候研究:研究气候变化对生态系统和人类活动的影响。
路径规划人工势场法及其改进算法Matlab代码实现,路径规划人工势场法及其改进算法Matlab代码实现,路径规划人工势场法以及改进人工势场法matlab代码,包含了 ,路径规划; 人工势场法; 改进人工势场法; MATLAB代码; 分隔词“;”。,基于Matlab的改进人工势场法路径规划算法研究
三菱FX3U与台达VFD变频器通讯指南:全程案例解析与接线设置讲解(含实用视频与程序附件),三菱FX3U与台达VFD变频器通讯指南:从编程教程到实际使用(包含接线与设置方法,实用案例程序和设置手册),三菱FX3U与台达VFD M变频器通讯教程。 三菱FX3U与台达VFD变频器通讯案例程序全程讲解,有注释。 讲解实用,自制视频。 并附送程序,有接线方式,设置。 器件:三菱FX3U的PLC,485BD板,台达VFD M变频器,昆仑通态,威纶通触摸屏。 功能:实现频率设定,启停控制,实际频率读取等。 ,教程;通讯案例;注释;程序附送;接线方式;设置;三菱FX3U PLC;485BD板;台达VFD M变频器;昆仑通态;威纶通触摸屏;频率设定;启停控制;实际频率读取。,三菱FX3U与台达VFD M变频器通讯全攻略:程序详解与实用操作指南