使用smartupload组件实现jsp+jdbc上传下载文件实例解析


Posted in Javascript onJanuary 05, 2017

SmartUpload组件只有5个分别是:File、Files、Request、SmartUpload、SmartUploadException类,其中,File代表用户上传的文件,Files代表用户上传的多个文件,Request相当于HttpServletRequest的功能,用于获取表单数据,SmartUpload是最核心的类,负责文件上传下载,SmartUploadException是自定义异常。

   SmartUpload的基本使用思路如下:

jsp前台代码表单提交

<form action="" method="post" name="form1" onSubmit="r" enctype="multipart/form-data"> 
<input type="file" name="img" size="34"></td> 
</form>
//创建SmartUpload的实例 
SmartUpload su = new SmartUpload(); 
//初始化,如果是在Servlet中使用,则调用另一个重载方法:initialize(ServletConfig, HttpServletRequest, HttpServletResponse) 
su.initialize(pageContext); 
//完成上传操作 
su.upload(); 
//将上传的文件保存到指定的文件夹。参数1表示文件保存的路径,参数2是可选选项 
su.save("uploads/", SmartUpload.SAVE_VIRTUAL);

在save方法中,有三个常量:SAVEAS_PHYSICAL,SAVEAS_VIRTUAL,SAVEAS_AUTO,意义分别是:

SAVEAS_PHYSICAL表明以操作系统的根目录为文件根目录另存文件,SAVEAS_VIRTUAL表明以Web应用程序的根目录为文件根目录另存文件,SAVEAS_AUTO则表示让组件决定,当Web应用程序的根目录存在另存文件的目录时,它会选择SAVEAS_VIRTUAL,否则会选择SAVEAS_PHYSICAL。   

 如果希望给文件重命名(这是经常遇到的问题),可以调用File类的saveAs方法保存单个的文件,代码如下: 

SmartUpload su = new SmartUpload(); 
su.initialize(pageContext); 
//指定扩展名 
su.setAllowedFilesList("bmp,jpg,bng,gif"); 
//指定大小 
su.setMaxFileSize(1 * 1024 * 1024); 
su.upload(); 
//单独保存文件,用UUID名称保存 
Files files = su.getFiles(); 
for(int i = 0; i < files.getCount(); i ++){ 
 File f = files.getFile(i); 
 if(!f.isMissing()){ 
 //保存单个文件,参数1为文件名,参数2为可选选项。 
 f.saveAs("uploads/" +  
  UUID.randomUUID().toString() + "." + 
  f.getFileExt(), 
  SmartUpload.SAVE_VIRTUAL); 
 } 
}

 使用SmartUpload实现文件下载就更简单了,不再直接和数据流打交道,非常贴心的设计。SmartUpload定义了一个名为downloadFile()的方法,该方法的参数指定要下载的文件即可。当然,在此之前要先调用setContentDisposition(null),参数为null表示告知浏览器下载文件。代码如下:  

SmartUpload su = new SmartUpload(); 
su.initialize(pageContext); 
su.setContentDisposition(null); //表示这是一个下载操作 
su.downloadFile("uploads/fa79a56a-5e64-407d-a22b-8606d512b447.jpg");

smartupload组件包下载地址:http://download.csdn.net/detail/qq_24886937/9729267

以上所述是小编给大家介绍的使用smartupload组件实现jsp+jdbc上传下载文件实例解析,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
15款优秀的jQuery导航菜单插件分享
Jul 19 Javascript
jQuery 借助插件Lavalamp实现导航条动态美化效果
Sep 27 Javascript
jquery和javascript中如何将一元素的内容赋给另一元素
Jan 09 Javascript
jQuery实现简单的间隔向上滚动效果
Mar 09 Javascript
Bootstrap入门书籍之(五)导航条、分页导航
Feb 17 Javascript
分享12个实用的jQuery代码片段
Mar 09 Javascript
jQuery原理系列-css选择器的简单实现
Jun 07 Javascript
jquery实现ajax提交表单信息的简单方法(推荐)
Aug 24 Javascript
AngularJS入门教程之与服务器(Ajax)交互操作示例【附完整demo源码下载】
Nov 02 Javascript
JS根据生日月份和日期计算星座的简单实现方法
Nov 24 Javascript
js调用刷新界面的几种方式
May 03 Javascript
vue 项目打包时样式及背景图片路径找不到的解决方式
Nov 12 Javascript
javascript解析ajax返回的xml和json格式数据实例详解
Jan 05 #Javascript
Node.js中文件操作模块File System的详细介绍
Jan 05 #Javascript
Extjs让combobox写起来简洁又漂亮
Jan 05 #Javascript
JS实现给对象动态添加属性的方法
Jan 05 #Javascript
bootstrap datetimepicker实现秒钟选择下拉框
Jan 05 #Javascript
JavaScript实现数组降维详解
Jan 05 #Javascript
jQuery解析返回的xml和json方法详解
Jan 05 #Javascript
You might like
Terran兵种介绍
2020/03/14 星际争霸
PHP 和 HTML
2006/10/09 PHP
echo, print, printf 和 sprintf 区别
2006/12/06 PHP
php获取mysql字段名称和其它信息的例子
2014/04/14 PHP
分享一段php获取linux服务器状态的代码
2014/05/27 PHP
PHP实现正则表达式分组捕获操作示例
2018/02/03 PHP
Javascript面象对象成员、共享成员变量实验
2010/11/19 Javascript
js判断变量是否未定义的代码
2020/03/28 Javascript
JS对img标签进行优化使用onerror显示默认图像
2014/04/24 Javascript
使用Node.js为其他程序编写扩展的基本方法
2015/06/23 Javascript
jQuery中通过ajax的get()函数读取页面的方法
2016/02/29 Javascript
JavaScript知识点总结(十六)之Javascript闭包(Closure)代码详解
2016/05/31 Javascript
React Native 图片查看组件的方法
2018/03/01 Javascript
解决循环中setTimeout执行顺序的问题
2018/06/20 Javascript
vue-cli history模式实现tomcat部署报404的解决方式
2019/09/06 Javascript
Javascript摸拟自由落体与上抛运动原理与实现方法详解
2020/04/08 Javascript
[57:50]DOTA2上海特级锦标赛主赛事日 - 4 胜者组决赛Secret VS Liquid第二局
2016/03/05 DOTA
分享Python文本生成二维码实例
2016/01/06 Python
视觉直观感受若干常用排序算法
2017/04/13 Python
pyttsx3实现中文文字转语音的方法
2018/12/24 Python
详解python路径拼接os.path.join()函数的用法
2019/10/09 Python
Django-migrate报错问题解决方案
2020/04/21 Python
html5 自定义播放器核心代码
2013/12/20 HTML / CSS
HTML5 canvas基本绘图之图形组合
2016/06/27 HTML / CSS
澳大利亚优质的家居用品和生活方式公司:Bed Bath N’ Table
2019/04/16 全球购物
M.M.LaFleur官网:美国职业女装品牌
2020/10/27 全球购物
经济管理专业自荐信
2013/12/30 职场文书
《小白兔和小灰兔》教学反思
2014/02/18 职场文书
优秀会计求职信
2014/07/04 职场文书
党委班子纠正“四风”问题整改措施
2014/10/28 职场文书
2015年社区综治工作总结
2015/04/21 职场文书
幼儿园大班教师评语
2019/06/21 职场文书
员工保密协议范本,您一定得收藏!很有用!
2019/08/08 职场文书
Python中相见恨晚的技巧
2021/04/13 Python
vue+element ui实现锚点定位
2021/06/29 Vue.js
详解pytorch创建tensor函数
2022/03/22 Python