Flex+seam 文件上传

本文介绍了一个使用Flex技术实现的文件上传组件的具体实现细节,包括MXML代码示例及Java Servlet端的处理逻辑。该组件支持文件选择、上传进度显示等功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Flex:
FileUpload.mxml
<?xml version="1.0" encoding="utf-8"?>
<mx:Canvas xmlns:mx="http://www.adobe.com/2006/mxml">


<mx:Script>
<![CDATA[
import com.gptri.core.GlobalParam;
import flash.net.FileReference;
import com.gptri.gpweb.component.StatusEnum;
import org.granite.tide.events.TideUIEvent;
private var fileRef:FileReference =new FileReference();;

private var gp:GlobalParam=GlobalParam.getInstance();

public function get fileName():String
{
return fileRef.name;
}

private function fileBrowse():void
{
fileRef.addEventListener(Event.SELECT, selectHandler);
fileRef.addEventListener(ProgressEvent.PROGRESS, onProgress);
fileRef.addEventListener(Event.COMPLETE, completeHandler);
var gifFilter:FileFilter=new FileFilter("PowerPoint", "*.ppt", "PPT");
fileRef.browse([gifFilter]);
}
private function onProgress(e:ProgressEvent):void
{
var proc:uint=e.bytesLoaded / e.bytesTotal * 100;
dispatchEvent(new TideUIEvent("statusChange", "当前进度: " + " " + proc + "%", StatusEnum.WORKING));
}
private function selectHandler(event:Event):void
{
var request:URLRequest=new URLRequest(gp.sysHost + "FileUploadServlet");
fileRef=FileReference(event.target);

fileRef.upload(request);

}

private function completeHandler(event:Event):void
{
dispatchEvent(new Event("uploadComplete"));
}
]]>
</mx:Script>

<mx:Button click="fileBrowse()" label="上传文件" fontSize="12"/>
</mx:Canvas>

Application

public function init():void
{
fileUpload.addEventListener("uploadComplete", uploadComplete);
}
[Observer("uploadComplete")]
public function uploadComplete(e:Event):void
{

weekReportSearch.uploadPPT(uploadPPTResult);
}
private function uploadPPTResult(e:TideResultEvent):void
{
dispatchEvent(new TideUIEvent("statusChange", e.result as String, StatusEnum.WORKING));
CursorManager.removeBusyCursor();
}
<cs:FileUpload id="fileUpload"/>



java Servelet :需要common-io,commons-fileupload包


import java.io.File;
import java.io.IOException;
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 = "D:\\upload\\";
// 限制文件的上传大小
private int maxPostSize = 100 * 1024 * 1024;

public FileUploadServlet() {

super();
}

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

public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// 保存文件到服务器中
response.setContentType("text/html; charset=UTF-8");
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();
request.getSession().setAttribute("uploadFile",
uploadPath + name);
System.out.println(name);
try {
item.write(new File(uploadPath + name));
} catch (Exception e) {
e.printStackTrace();
}
}
}
} catch (FileUploadException e) {
e.printStackTrace();
}
}

public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}

public void init() throws ServletException {
// Put your code here
}
}

seam 组件

@Name("weekReportSearch")
@Scope(EVENT)
@TideEnabled
public class WeekReportSearchingAction {
@In
private EntityManager entityManager;

@In(required = false)
private String uploadFile;
public String uploadPPT() {
//SlideShow ppt = new SlideShow(new HSLFSlideShow(uploadFile));
// Put your code here
}



配置文件:
web.xml中添加
	<servlet>

<servlet-name>FileUploadServlet</servlet-name>
<servlet-class>com.gptri.gpweb.service.util.FileUploadServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>FileUploadServlet</servlet-name>
<url-pattern>/FileUploadServlet</url-pattern>
</servlet-mapping>
<filter>
<filter-name>Seam Multipart Filter</filter-name>
<filter-class>org.jboss.seam.web.MultipartFilter</filter-class>
</filter>

<filter-mapping>
<filter-name>Seam Multipart Filter</filter-name>
<url-pattern>*.seam</url-pattern>
</filter-mapping>


components.xml 添加
  <web:multipart-filter create-temp-files="true"
max-request-size="104857600"
url-pattern="*.seam"/>
资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在当今的软件开发领域,自动化构建与发布是提升开发效率和项目质量的关键环节。Jenkins Pipeline作为一种强大的自动化工具,能够有效助力Java项目的快速构建、测试及部署。本文将详细介绍如何利用Jenkins Pipeline实现Java项目的自动化构建与发布。 Jenkins Pipeline简介 Jenkins Pipeline是运行在Jenkins上的一套工作流框架,它将原本分散在单个或多个节点上独立运行的任务串联起来,实现复杂流程的编排与可视化。它是Jenkins 2.X的核心特性之一,推动了Jenkins从持续集成(CI)向持续交付(CD)及DevOps的转变。 创建Pipeline项目 要使用Jenkins Pipeline自动化构建发布Java项目,首先需要创建Pipeline项目。具体步骤如下: 登录Jenkins,点击“新建项”,选择“Pipeline”。 输入项目名称和描述,点击“确定”。 在Pipeline脚本中定义项目字典、发版脚本和预发布脚本。 编写Pipeline脚本 Pipeline脚本是Jenkins Pipeline的核心,用于定义自动化构建和发布的流程。以下是一个简单的Pipeline脚本示例: 在上述脚本中,定义了四个阶段:Checkout、Build、Push package和Deploy/Rollback。每个阶段都可以根据实际需求进行配置和调整。 通过Jenkins Pipeline自动化构建发布Java项目,可以显著提升开发效率和项目质量。借助Pipeline,我们能够轻松实现自动化构建、测试和部署,从而提高项目的整体质量和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值