DWR3.0 文件上传
引自:http://tyyler.blog.51cto.com/4030931/730599
java方法中的参数必须是BufferedImage,InputStream,FileTransfer三种中其中一个,
一般推荐使用FileTransfer,可以获取文件名、文件大小、和内置的inputStream。
后台实现文件上传方法
public String fileUploadForDwr(ArrayList<FileTransfer> fileTransfer) {
String tmp = "error";
String fileName = ""; // 文件名
String newFileName = ""; // 新文件名
InputStream streamIn = null;
OutputStream streamOut = null;
long size = 1024 * 1024 * 5;
if(fileTransfer.size() > size){
return "文件不得大于5M";
}
WebContext webContext = WebContextFactory.get();
String saveurl = webContext.getHttpServletRequest().getSession()
.getServletContext().getRealPath("/upload");
for (FileTransfer obj : fileTransfer) {
if (obj.getFilename() != null && !obj.getFilename().equals("")) {
fileName = obj.getFilename();
if (fileName.lastIndexOf("\\") > -1) {
fileName = fileName
.substring(fileName.lastIndexOf("\\") + 1);
}
System.out.println(fileName);
newFileName = ""
+ fileName.substring(fileName.indexOf("."));
try {
streamIn = obj.getInputStream();
streamOut = new FileOutputStream(new File(saveurl,
newFileName));
int bytesRead = 0;
byte[] buffer = new byte[81920];
while ((bytesRead = streamIn.read(buffer, 0, 81920)) != -1) {
streamOut.write(buffer, 0, bytesRead);
}
streamOut.close();
streamIn.close();
tmp="success";
} catch (FileNotFoundException ex) {
} catch (IOException e) {
// TODO: handle exception
} finally {
streamIn = null;
streamOut = null;
}
}
}
return tmp;
}
前台调用页面:
<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>dwr3 文件上传</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<script type="text/javascript" src="/dwr/engine.js"></script>
<script type="text/javascript" src="/dwr/util.js"></script>
<script type="text/javascript" src="/dwr/interface/dwrFileUtil.js"></script>
<script type="text/javascript">
//解决谷歌浏览器无法上传的问题
var isChrome = (/\bchrome\b/).test(navigator.userAgent.toLowerCase());
dwr.engine.transport.iframe.loadingComplete = function(batchId) {
var batch = dwr.engine._batches[batchId];
if(!isChrome)
if (batch) dwr.engine.batch.validate(batch);
};
function uploadFile(){
var file=dwr.util.getValue("attach");
var str="123"
var fileArr = new Array();//注意这里是用的集合,无论一个附件还是多个附件都可以了
fileArr[0] = file;
dwrFileUtil.fileUploadForDwr(fileArr,{callback:function (data){back(str,data)}});
}
function back(tmp,data){
alert(3);
alert(tmp+""+data);
}
</script>
</head>
<body>
<input type="file" name="attach">
<br />
<input type="button" name="btnSub" onclick="uploadFile()" value="文件上传">
</body>
</html>
DWR 配置:
<create creator="new" javascript = "dwrFileUtil">
<param name="class" value="FileUpload" />
<include method = "fileUploadForDwr" />
</create>
分享到:
相关推荐
标题 "dwr3.0 文件上传" 涉及到的是Direct Web Remoting(DWR)框架的一个关键特性,即在Web应用中实现文件的上传功能。DWR是一款开源JavaScript库,它允许JavaScript代码直接调用Java服务器端的方法,从而在浏览器...
在“EXTJS+DWR3.0实现文件上传”这个主题中,我们将探讨如何结合这两者来实现一个高效且用户友好的文件上传功能。在实际的Web应用中,文件上传是一个常见的需求,例如在社交媒体平台上传图片、在文档分享网站上传...
DWR 3.0 提供了一种方便的方法来处理文件上传。首先,你需要在客户端(HTML页面)创建一个`<input type="file">`元素,让用户选择要上传的文件。然后,你可以编写一个JavaScript函数,利用DWR的API来调用服务器上的...
文件上传是 DWR 3.0 中一项非常实用的功能。为了实现文件上传,首先需要准备以下几个文件包: - **dwr.jar**:这是 DWR 的核心库。 - **commons-fileupload-1.2.jar**:用于处理文件上传。 - **commons-io-1.3.1.jar...
DWR学习资料 :DWR 3.0 上传文件.txt DWR3.0反向Ajax示例.txt DWR3.0学习笔记.txt DWR3.0学习网址.txt dwr分页.doc DWR分页代码.doc DWR中文文档.doc DWR中文文档.pdf dwr做comet的完整实现.doc Spring整合DWR comet ...
例如,创建一个名为`FileUploadService`的类,其中有一个`uploadFile`方法接收`Part`类型的参数,这是Java Servlet 3.0及以上版本支持的文件上传API。 2. 在`dwr.xml`中暴露这个接口:配置DWR,允许JavaScript调用`...
例如,可以有一个`FileUploadService`接口,其中有一个`uploadFile`方法接收`Part`对象,这是Servlet 3.0引入的用于处理文件上传的API。 3. **映射JavaScript对象**:在DWR的`dwr.xml`配置文件中,将`...
在本项目“dwrupload”中,重点是实现基于DWR3.0的异步文件和图片上传功能。 DWR3.0是一个开源框架,它提供了在浏览器端与服务器端进行动态交互的能力,使得开发者能够使用JavaScript直接调用服务器端的Java方法,...
1. **Uploadify 3.0**:这是一个JavaScript库,允许用户在网站上实现方便、友好的文件上传功能。Uploadify 3.0提供了批量上传、进度条显示、错误处理等功能,大大优化了用户体验。它通过Flash和HTML5技术支持跨...
在OA系统中,DWR增强了用户体验,使得用户无需刷新页面就能实时获取服务器数据,如工作流状态更新、异步文件上传等,提高了交互性和响应速度。 这些技术的组合,构建了一个高效、灵活且易于维护的OA系统。Struts...
- **文档管理**:文件上传、下载、共享,版本控制。 - **会议管理**:预约、通知、记录。 - **日程安排**:个人及团队的日程规划。 - **公告通知**:发布、订阅公司内部消息。 - **项目管理**:跟踪项目进度,分配...
OA办公自动化管理系统是一款基于Struts1.2、Hibernate3.0、Spring2和DWR的综合性企业级应用解决方案,旨在帮助企业实现高效、便捷的办公管理。该系统具备以下功能: 1. 用户管理:支持用户注册、登录、权限分配、...
在这个项目中,用户可以进行审批流程、上传下载文件、发起会议等操作,实现无纸化办公,减少人力成本。 4. **数据库设计**: 数据库文件是系统运行的基础,包含表结构、数据和索引等。SQL Server是一个强大的关系...
文档管理模块提供文件上传、下载、分享等功能,方便信息的存储和交流;日程安排则帮助用户规划工作,提醒重要事件;通知公告模块则可以及时发布公司政策、活动等信息,确保信息的传播。 在开发过程中,需要遵循软件...
* Struts2:MVC 与 struts 体系、Action 和 Result、国际化和标签库、文件上传、下载、类型转换和输入检验、拦截器与插件开发 * Hibernate:ORM 与持久化映射、关系映射、继承映射、延迟加载、性能调优、HQL 查询、...
- Smartupload/Servlet/MVC:文件上传、请求处理、模型视图控制器设计模式。 - **开源框架**:逐步学习Struts 1.x、AJAX、Hibernate、Spring、Struts 2.0、JSF、DWR、JSON、JQuery等框架,掌握其核心原理和应用场景...