`

Flex + Servlet 上传文件

阅读更多

引言:首先声明一下,这篇文章中的内容多是来自于网上,由于自己又整合了一下,Flex 页面:
FileUpload. mxml
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" xmlns="*" creationComplete="init();">
<mx:Script>
<![CDATA[
import flash.net.FileReference;
import mx.controls.Alert;
import mx.events.CloseEvent;
import flash.events.*;

private var file: FileReference;

private function init(): void{
Security.allowDomain("*");
file = new FileReference();
file.addEventListener(ProgressEvent.PROGRESS, onProgress);
file.addEventListener(Event.SELECT, onSelect);
}

private function upload(): void{
var imageTypes:FileFilter = new FileFilter("Images (*.jpg, *.jpeg, *.png)", "*.jpg;*.jpeg;*.png");
var allTypes:Array = new Array(imageTypes);
file.browse(allTypes);
file.browse();
}

private function onSelect(e: Event): void{
Alert.show("上传 " + file.name + " (共 "+Math.round(file.size)+" 字节)?",
"确认上传",
Alert.YES|Alert.NO,
null,
proceedWithUpload);
}

private function onProgress(e: ProgressEvent): void{
lbProgress.text = " 已上传 " + e.bytesLoaded
+ " 字节,共 " + e.bytesTotal + " 字节";
var proc: uint = e.bytesLoaded / e.bytesTotal * 100;
bar.setProgress(proc, 100);
bar.label= "当前进度: " + " " + proc + "%";
}

private function proceedWithUpload(e: CloseEvent): void{
if (e.detail == Alert.YES){
var request: URLRequest = new URLRequest("http://localhost:8080/SchoolSystem-war/FileUploadServlet");
try {
file.upload(request);
} catch (error:Error) {
trace("上传失败");
}

}
}
]]>
</mx:Script>

<mx:Canvas width="100%" height="100%" x="10" y="170" fontSize="15">
<mx:VBox width="100%" horizontalAlign="center">
<mx:Label id="lbProgress" text="上传"/>
<mx:ProgressBar id="bar" labelPlacement="bottom" themeColor="#F20D7A"
minimum="0" visible="true" maximum="100" label="当前进度: 0%"
direction="right" mode="manual" width="200"/>

<mx:Button label="上传文件" click="upload();"/>
</mx:VBox>
</mx:Canvas>
</mx:Application>

Servlet 页面:
FileUpload. java
import java.io.File;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.Iterator;
import java.util.List;

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 = "E:\\upload\\";

// 限制文件的上传大小
private int maxPostSize = 100 * 1024 * 1024;

public FileUploadServlet() {
super();
}

public void destroy() {
super.destroy();
}

protected void processRequest(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
System.out.println("Access !");
response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();


//保存文件到服务器中
DiskFileItemFactory factory = new DiskFileItemFactory();
factory.setSizeThreshold(4096);
ServletFileUpload upload = new ServletFileUpload(factory);
upload.setSizeMax(maxPostSize);
try {
List fileItems = upload.parseRequest(request);
Iterator iter = fileItems.iterator();
while (iter.hasNext()) {
FileItem item = (FileItem) iter.next();
if (!item.isFormField()) {
String name = item.getName();
System.out.println(name);
try {
item.write(new File(uploadPath + name));
SaveFile s = new SaveFile();
s.saveFile(name);
} catch (Exception e) {
e.printStackTrace();
}
}
}
} catch (FileUploadException e) {
e.printStackTrace();
System.out.println(e.getMessage() + "结束");
}
}

// <editor-fold defaultstate="collapsed" desc="HttpServlet methods. Click on the + sign on the left to edit the code.">

protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
processRequest(request, response);
}


protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
processRequest(request, response);
}


public String getServletInfo() {
return "Short description";
}
// </editor-fold>
}

虽然只引入了fileupload包 不过要想实际运行还要在工程里添加commons-io包,不然无法上传

因为使用的是apache的fileupload包,实际测试中在tomcat下可以正常使用,在jboss上则报错无法上传,为解决次问题,特别写了一个jsp文件并使用了smartupload上传组件,这样可以在jboss实现flex上传

分享到:
评论
1 楼 王慧迪 2010-08-27  
你的SaveFile 好像不能用诶 

相关推荐

    Flex4.6+java+servlet上传图片例子+图片上传预览

    这个"Flex4.6+java+servlet上传图片例子+图片上传预览"的项目,结合了前端的Flex技术和后端的Java Servlet,为我们提供了一个完整的解决方案。下面将详细解释这个项目的各个组成部分及其工作原理。 首先,让我们来...

    Flex+Java Servlet处理文件上传

    Flex+Java Servlet处理文件上传 关于上传文件

    Flex+Java 文件上传

    在本文中,我们将深入探讨如何实现Flex与Java Servlet结合进行文件上传。首先,我们需要了解Flex是一种基于Adobe AIR的开源框架,用于构建富互联网应用程序(RIA),而Java Servlet是Java平台上的一个标准,用于处理...

    flex + servlet 多文件上传

    本示例主要涉及了`Flex`和`Servlet`技术的结合,用于实现多文件上传的功能。`Flex`是一种基于Adobe Flash Player或Adobe AIR运行时的富互联网应用程序(RIA)开发框架,而`Servlet`则是Java Web开发中的服务器端组件...

    flex+java文件上传

    Flex和Java文件上传技术是Web应用中常见的功能,主要用于用户在网页端上传本地文件到服务器。Flex是一款由Adobe公司开发的开源框架,主要用于构建富互联网应用程序(Rich Internet Applications,RIA)。它基于...

    Flex+Java Servlet文件上传实例

    【标题】"Flex+Java Servlet文件上传实例"指的是一个结合了Adobe Flex前端技术和Java Servlet后端技术的文件上传系统。Flex是一种基于ActionScript和Flash Player的开放源代码框架,用于构建富互联网应用程序(RIA)...

    Flex+Java Servlet处理文件上传.doc

    Flex+Java Servlet处理文件上传

    Flex+Servlet断点续传Demo

    综上所述,Flex+Servlet断点续传Demo涉及了客户端和服务端的交互、文件分块、状态管理、错误处理等多个方面,通过这个Demo,开发者可以学习到如何在实际项目中实现高效、可靠的文件上传功能。在压缩包中的"upload...

    Flex+Java多文件上传

    在压缩包“Flex+java上传组件2”中,可能包含了Flex客户端的源代码(如.mxml和.as文件)以及Java服务器端的处理代码(如Servlet或Java类)。开发者可以参考这些源码学习如何实现多文件上传,也可以直接在自己的项目...

    flex+java文件上传完整实例

    在Java端,主要涉及Servlet来接收和处理来自Flex的文件上传请求。关键知识点包括: 1. **Commons FileUpload库**:Apache Commons FileUpload是一个流行的Java库,用于处理multipart/form-data类型的HTTP请求,这是...

    flex4+servlet批量上传

    4. **返回响应**:在Servlet处理完文件后,向Flex客户端返回一个响应,告知文件上传的状态,如成功、失败或部分成功。 在Flex4应用中,还需要处理上传进度显示、错误处理等用户体验优化。例如,可以监听...

    Flex和Servlet结合上传文件

    这里我们关注的是如何将Adobe Flex与Java的Servlet技术相结合,实现用户友好的文件上传界面。Flex作为一个强大的富客户端开发框架,可以提供美观且交互性强的用户界面,而Servlet则是Java Web应用中的标准组件,用于...

    Flex+Java+BlazeDS多文件上传

    标题“Flex+Java+BlazeDS多文件上传”涉及到的技术栈是Adobe Flex、Java和BlazeDS,这三种技术在Web应用开发中常用于构建富客户端应用和实现服务器端的数据交互。下面将详细阐述这些技术及其在多文件上传场景中的...

    Flex+Java 实现文件上传

    总的来说,理解和实现Flex与Java结合的文件上传功能需要掌握前端的Flex编程、后端的Java Servlet或Spring MVC技术,以及HTTP协议的基础知识。同时,熟悉文件I/O操作、安全性考量和用户界面设计也是必不可少的。通过...

    flex + java上传

    Flex和Java上传是一种常见的Web应用程序开发技术,用于在客户端(通常是浏览器)和服务器之间传输大文件。Flex是一种基于Adobe Flash Player的开源框架,用于构建富互联网应用(RIA),而Java则提供后端处理能力。本...

    Flex+java上传开发工具包

    这是一个专门针对文件上传的Java库,它通常与流行的Servlet框架如Spring、Struts等结合使用。这个库提供了处理多部分HTTP请求的能力,这是在HTML表单中进行文件上传时的标准格式。它支持大文件上传、断点续传、进度...

Global site tag (gtag.js) - Google Analytics