1、spring代码如下
public ModelAndView upload(HttpServletRequest request,
HttpServletResponse response) throws Exception{
try{
String uploadDir = getServletContext().getRealPath("/upload");
File dirPath = new File(uploadDir);
if (!dirPath.exists()) {
dirPath.mkdirs();
}
MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
CommonsMultipartFile file = (CommonsMultipartFile) multipartRequest.getFile("filedata");//这里是表单的名字,在swfupload.js中this.ensureDefault("file_post_name", "filedata");
InputStream stream = file.getInputStream();
String fileName = file.getOriginalFilename();
fileName = new String(fileName.getBytes(),"utf-8");
String fileNameFull = uploadDir + Constants.FILE_SEP + fileName;
OutputStream bos = new FileOutputStream(fileNameFull);
int bytesRead = 0;
byte[] buffer = new byte[8192];
while ((bytesRead = stream.read(buffer, 0, 8192)) != -1) {
bos.write(buffer, 0, bytesRead);
}
bos.close();
// close the stream
stream.close();
}catch(Exception e){
e.printStackTrace();
}
return new ModelAndView("checkReport/checkReportSearchTable");//这里要制定返回页,如果返回Null,上传没问题,但是上传完毕后,页面会弹出404错误
}
2、jsp页面
首先要引入两个js文件(必须的)
<script type="text/javascript" src="scripts/js/swfupload.js"></script>
<script type="text/javascript" src="scripts/js/handlers.js"></script>
var swfu;
window.onload = function(){
swfu = new SWFUpload({
// Backend Settings
upload_url: "unitProductValueController.html?method=upload", //上传或解析处理类的URL
// File Upload Settings
file_size_limit : 0, // 限制上传文件的大小, 0表示不受限制
file_types : "*.xls;*.txt;*.pdf;*.doc;*.xlsx;*.docx", // 上传文件类型,多个文件用分号隔开
file_types_description : "", // 上传文件类型描述
file_upload_limit : "0", // 限制上传文件选择的个数, "0"表示不受限制
file_queue_error_handler : fileQueueError,
file_dialog_complete_handler : fileDialogComplete,
upload_progress_handler : uploadProgress, //上传过程中调用的方法
upload_error_handler : uploadError, //上传错误调用的方法
upload_success_handler : uploadSuccess,
upload_complete_handler : uploadComplete, //上传完成调用的方法
//post_params : {
// 'state':'1234567'
//},
//post_params :{};
// Button settings
button_image_url : "", // Relative to the SWF file
button_placeholder_id : "spanButtonPlaceholder",//html标签ID,如DIV或SPAN
button_width: 100,
button_height: 22,
button_text : '<u>添加附件</u>',//生成的按钮内容
button_text_style : '.button {font-size: 14pt;cursor:pointer;text-align:right} .buttonSmall { font-size: 10pt;cursor:pointer;text-align:right }',
button_text_top_padding: 1,
button_text_left_padding: 45,
// Flash Settings
flash_url : "<psmis:webRoot/>scripts/js/swfupload.swf", // Relative to this file
//上传或解析过程中,显示进度信息
custom_settings : {
upload_target : "divFileProgressContainer"
},
// Debug Settings
debug: false
});
}
3、html部分,加一个form表单即可,注意红色部分
<form action="unitProductValueController.html?method=upload" id="formMessage" method="post"
enctype="multipart/form-data">
<table width="100%" id="messageTable" border="1" cellpadding="0" cellspacing="0" style="border-collapse:collapse" bordercolor="#1372A0">
<tr>
<td colspan="2" style="height:30px;">
<span id="enterpriseName"></span>
</td>
</tr>
<tr>
<td style="text-align:right">邮件类型:</td>
<td style="height:30px;width: 80%;">
<span style="float:left;" id="messageTypeSpan">
<input type="radio" name="messageType" value="1" checked="checked" id="messageType1" style="border:0px"><label for="messageType1">催报邮件</label>
<input type="radio" name="messageType" value="2" id="messageType2" style="border:0px"><label for="messageType2">重报邮件</label>
</span>
</td>
</tr>
<tr>
<td style="text-align:right">主题:</td>
<td style="height:30px;text-align:center">
<input type="text" name="subject" name="subject" style="width:98%">
</td>
</tr>
<tr>
<td style="text-align:right">
<div id="swfu_container" style="margin: 0px 5px;">
<div>
<span id="spanButtonPlaceholder"></span>
</div>
</div>
</td>
<td style="height:30px;">
<div id="divFileProgressContainer" style="height: 30px;float:left;margin-left:4px;"></div>
</td>
</tr>
<tr>
<td style="text-align:right;vertical-align:top;padding-top:3px;">邮件内容:</td>
<td valign="top" >
<textarea name="emailContent" id="emailContent" style="height:150px;width:350px;border:0px solid #000000;float:left "></textarea>
<select multiple="multiple" id="consignee" name="consignee" size="9" style="vertical-align:top;float:right;margin-right:5px;width:120px;">
<option>模板1</option>
<option>模板2</option>
<option>模板3</option>
</select>
</td>
</tr>
<tr>
<td align="right" colspan="2">
<input type="button" name="ibtnSearch" value="发送" id="ibtnSearch" class="com_btn2" onclick="saveMessage()"/>
<input type="button" name="iBtnSaveQuery" value="重置"
id="iBtnSaveQuery" class="com_btn2" onclick="document.getElementById('textarea').value='';" />
</td>
</tr>
</table>
</form>
分享到:
相关推荐
Java基于Spring+SpringMVC+MyBatis实现的学生信息管理系统源码,SSM+Vue的学生管理系统。 Java基于Spring+SpringMVC+MyBatis实现的学生信息管理系统源码,SSM+Vue的学生管理系统。 Java基于Spring+SpringMVC+...
基于springmvc+Hibernate实现的在线购物商城.zip基于springmvc+Hibernate实现的在线购物商城.zip基于springmvc+Hibernate实现的在线购物商城.zip基于springmvc+Hibernate实现的在线购物商城.zip基于springmvc+...
在本文中,我们将深入探讨如何使用Spring MVC框架与SWFUpload库来实现文件的异步上传功能。异步上传能够显著提升用户体验,因为它允许用户在上传文件时继续使用其他页面功能,无需等待整个上传过程完成。 **Spring ...
SpringMVC+BUI实现文件上传实例,虽然本工程的名称是first_maven_project,但是确实是SpringMVC+BUI实现文件上传实例源码,请放心下载,实例详解请访问博主博客:http://blog.csdn.net/u013142781
完善的Spring+SpringMVC+Mybatis+easyUI后台管理系统(RESTful API+redis).zip 完善的Spring+SpringMVC+Mybatis+easyUI后台管理系统(RESTful API+redis).zip 完善的Spring+SpringMVC+Mybatis+easyUI后台管理系统...
Spring+SpringMVC+MyBatis+Shiro+MySQL+Redis+Maven+EasyUI+Bootstrap实现的通用权限管理系统。 Spring+SpringMVC+MyBatis+Shiro+MySQL+Redis+Maven+EasyUI+Bootstrap实现的通用权限管理系统 Spring+SpringMVC+...
javaweb课设基于SpringBoot+SpringMVC+Mybatis实现的手机销售后台管理系统源码.zipjavaweb课设基于SpringBoot+SpringMVC+Mybatis实现的手机销售后台管理系统源码.zipjavaweb课设基于SpringBoot+SpringMVC+Mybatis...
《图书管理系统SpringMvc+Mybatis实现详解》 在IT领域,构建高效、稳定的软件系统是至关重要的。本项目“图书管理系统”就是这样一个实例,它利用了SpringMvc和Mybatis两大主流框架,为图书管理提供了全面的解决...
这是一款基于SpringMVC + MyBatis实现的小说系统, 目前只有wap端。 前端采用vue的框架cube-ui, 采用前后端分离的结构,系统中针对数据接口安全做了一定的限制, 很大程度上保证了数据的安全性。 这是一款基于...
各类图表的展示(折线图,饼图,直方图等),使用了layui的弹出层、菜单、文件上传、富文本编辑、日历、选项卡、数据表格等 Oracle关系型数据库以及非关系型数据库(Redis),Oracle 性能调优(PL/SQL语言,SQL查询...
"Shiro+SpringMVC+Redis+MySQL实现单点登录"是一个典型的系统安全架构,它整合了多个技术组件来构建一个高效、可靠的单点登录(Single Sign-On, SSO)解决方案。以下是关于这个主题的详细知识点: 1. **Apache ...
基于Spring+SpringMVC+Mybatis架构的博客系统:博客管理、图表数据、日志分析、访问记录、图库管理、资源管理、友链通知等。良好的页面预加载,无限滚动加载,文章置顶,博主推荐等。提供 用户端+管理端 的整套系统...
SpringBoot版本的SpringMVC+Freemarker上传案例,地址是localhost:8888/photo/index进入上传页面,默认是三个文件,自己可以屏蔽两个文件就是单个文件的状态了,首先在电脑的D盘新建一个upload的文件夹,...
table(数据列表展示)+ Bootstrap-Export(各种报表导出SQL,Excel,pdf等)框架,整合Echars,各类图表的展示(折线图,饼图,直方图等),使用了layui的弹出层、菜单、文件上传、富文本编辑、日历、选项卡、数据...
基于SpringMVC+Spring+MyBatis+Maven项目案例 基于SpringMVC+Spring+MyBatis+Maven项目案例 基于SpringMVC+Spring+MyBatis+Maven项目案例 基于SpringMVC+Spring+MyBatis+Maven项目案例 基于SpringMVC+Spring+MyBatis...
1. **SpringMVC的角色**:在权限管理中,SpringMVC可以通过拦截器(Interceptor)实现对请求的预处理。拦截器可以在请求到达目标控制器之前执行某些操作,如检查用户登录状态、验证权限等。通过自定义拦截器,我们...
SpringMVC+Spring+Mybatis集成开发环境SpringMVC+Spring+Mybatis集成开发环境SpringMVC+Spring+Mybatis集成开发环境SpringMVC+Spring+Mybatis集成开发环境SpringMVC+Spring+Mybatis集成开发环境SpringMVC+Spring+...
基于spring+springMvc+mybatis 开发的企业门户网站基于spring+springMvc+mybatis 开发的企业门户网站,适合具有一定编程基础,比如计算机专业的大学生或者1-3年工作经验的开发人员。手写简化版 Spring 框架,了解 ...
2. **spring-servlet.xml**:SpringMVC的配置文件,包括视图解析器、数据源、事务管理器、Bean的定义等。 3. **hibernate.cfg.xml**:Hibernate的配置文件,包含了数据库连接信息和实体类的映射配置。 4. **实体类**...
在本项目中,“后台界面实时获取用户输入内容,springMVC+Ajax实现(源码)”是一个典型的应用案例,它结合了SpringMVC框架与Ajax技术,使得后台能够即时响应用户的前端输入,无需每次提交都刷新整个页面。...