Uploadify 控件上传图片 + 预览
jquery的Uploadify控件上传图片和预览使用介绍。
在简单的servlet系统中和在SSH框架中,后台处理不同的,在三大框架中图片预览时费了不少力气,所以下面将两种情况都介绍一下。
1,前台代码
script:
- $("#uploadify").uploadify({
- 'langFile' : '<%=request.getContextPath()%>/config/juploadify/uploadifyLang_cn.js',
- 'swf' : '<%=request.getContextPath()%>/config/juploadify/uploadify.swf',
- 'uploader' : '<%=request.getContextPath()%>/UploadAction/uploadImg.action', //图片上传的action方法
- 'queueID' : 'fileQueue',
- 'auto' : true,
- 'multi' : true,
- 'buttonCursor' : 'hand',
- 'fileObjName' : 'uploadify',
- 'buttonText' : '上传图片',
- 'height' : '25',
- 'progressData' : 'percentage',
- 'fileTypeDesc' : '支持格式:jpg/gif/jpeg/png/bmp.',
- 'fileTypeExts': '*.jpg;*.gif;*.jpeg;*.png;*.bmp',//允许的格式
- onUploadSuccess : function(file,data,response) {
- //设置图片预览
- var _arr_val = data.split(",");
- $("#photo").val(_arr_val[1]);
- $("#pic_view").attr("src","<%=request.getContextPath()%>" + _arr_val[1]);
- }
- });
html
- <td width="15%" rowspan="9" align="center">
- <div id="fileQueue" style="width:200px;"></div>
- <input type="file" name="uploadify" id="uploadify" />
- <input type="hidden" name="photo" id="photo" value="">
- <div id="pic_view_div" style="width:150px; height:180px">
- <img src="<%=request.getContextPath()%>/image/nopic.gif" width="150" height="180" id="pic_view">
- </div>
- </td>
2,servlet中后台处理
- public void uploadImg(){
- // 解决服务器端消息返回客户端后中文字符乱码
- response.setHeader("Content-Type", "text/html;charset=UTF-8");
- HttpSession session = request.getSession();
- PrintWriter outs = response.getWriter();
- //获取上传图片的路径
- String savePath = request.getSession().getServletContext().getRealPath("");
- String saveDirectory = savePath + "/Imgupload";
- File file = new File(saveDirectory);
- if (!file.exists()) {
- file.mkdirs();
- }
- //设置图片大小
- if (StringUtils.isBlank(this.fileSizeLimit.toString())) {
- this.fileSizeLimit = "100";// 默认100M
- }
- int maxPostSize = Integer.valueOf(this.fileSizeLimit).intValue() * 1024 * 1024;
- String encoding = "UTF-8";
- MultipartRequest multi = null;
- try {
- multi = new MultipartRequest(request, saveDirectory, maxPostSize, encoding);
- } catch (Exception e) {
- System.out.println("发生异常:" + e.getMessage());
- return;
- }
- //图片预览功能实现
- String _result = "";
- Enumeration files = multi.getFileNames();
- while (files.hasMoreElements()) {
- String name = (String) files.nextElement();
- File f = multi.getFile(name);
- if (f != null) {
- String fileName = multi.getFilesystemName(name);
- String lastFileName = saveDirectory + "/" + fileName;
- result += multi.getOriginalFileName(name) + "," + savePath + "/" + fileName;
- }
- }
- outs.print(_result);
- }
注意:action方法返回的字符串为图片的名称和图片的路径。
3,SSH框架中使用
- package cn.com.zzcy.base.action;
- import java.io.File;
- @Namespace("/UploadAction")
- public class UploadAction {
- private File uploadify;
- public File getUploadify() {
- return uploadify;
- }
- public void setUploadify(File uploadify) {
- this.uploadify = uploadify;
- }
- private String uploadifyFileName;
- public String getUploadifyFileName() {
- return uploadifyFileName;
- }
- public void setUploadifyFileName(String uploadifyFileName) {
- this.uploadifyFileName = uploadifyFileName;
- }
- /**
- * 上传图片
- * @throws IOException
- */
- @Action("uploadImg")
- public void uploadImg(){
- HttpServletRequest request = ServletActionContext.getRequest();
- HttpServletResponse response = ServletActionContext.getResponse();
- String savePath = request.getSession().getServletContext().getRealPath("");
- PrintWriter out = null;
- String resultStr = "";
- String extName = "";// 扩展名
- String newFileName = "";// 新文件名
- try {
- response.setCharacterEncoding("utf-8");
- out = response.getWriter();
- //获取文件的扩展名
- if (uploadifyFileName.lastIndexOf(".") >= 0) {
- extName = uploadifyFileName.substring(uploadifyFileName.lastIndexOf("."));
- }
- //根据当前时间生成新的文件名称
- String nowTime = new SimpleDateFormat("yyyymmddHHmmss").format(new Date());// 当前时间
- newFileName = nowTime + extName;
- //设置文件保存路径
- String param = request.getParameter("param");
- savePath = savePath + "/ImgUpload/"+param+"/";
- File file = new File(savePath);
- if(!file.exists()){
- file.mkdirs();
- }
- uploadify.renameTo(new File(savePath+newFileName));
- resultStr = uploadifyFileName+","+"/ImgUpload/"+param+"/"+newFileName;
- } catch (IOException e) {
- e.printStackTrace();
- }finally{
- out.print(resultStr);
- }
- }
- }
注意:要定义局部变量并提供set方法,这样图片的名称和信息才能自动注入进入。
这里通过request方法获取不到图片信息。。。
4,实现的效果图如下:
原文出自:http://blog.csdn.net/lishuangzhe7047/article/details/41803175
Uploadify 控件上传图片 + 预览的更多相关文章
- jquery实现上传图片预览(需要浏览器支持html5)
jquery实现上传图片预览(需要浏览器支持html5) <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN&q ...
- HTML5上传图片预览
<!DOCTYPE html> <html> <head> <title>HTML5上传图片预览</title> <meta http ...
- HTML5上传图片预览功能
HTML5上传图片预览功能 HTML代码如下: <!-- date: 2018-04-27 14:41:35 author: 王召波 descride: HTML5上传图片预览功能 --> ...
- JS 上传图片 + 预览功能(一)
JS 上传图片 + 预览功能 <body> <input type="file" id="fileimg1" style="disp ...
- js兼容火狐显示上传图片预览效果
js兼容火狐显示上传图片预览效果[谷歌也适用] <!doctype html> <html> <head> <meta content="text/ ...
- 通过HTML5 FileReader实现上传图片预览功能
原文:http://www.htmleaf.com/ziliaoku/qianduanjiaocheng/201706224590.html 在上传图片到服务器之前,我们希望可以预览一下要上传的图片. ...
- 去除ckeditor上传图片预览中的英文字母
去除ckeditor上传图片预览中的英文字母 CKEDITOR.replace('text', { filebrowserImageUploadUrl : 'upload_img.do', langu ...
- HTML5 上传图片预览
html5出现之前如果需要上传图片预览 一般都是先上传到服务器然后远程预览 html5出现之后 有个filereader 解决了这问题 //选中图片之后 $("#fileAddPic&q ...
- [ASP.NET]使用uploadify上传图片,并在uploadify按钮上生成预览图
目录 需求 主要代码 总结 需求 项目中有用到uploadify上传插件,给的原型就是上传成功后替换原来的图片.没办法需求在那儿,也不能修改需求吧,只能想办法解决问题了. 主要代码 修改uploadi ...
随机推荐
- JBoss部署项目log4j配置会造成死锁问题,浏览器访问一直pending状态
今天将项目部署到JBoss服务器上,部署成功后,浏览器访问页面一直在等待响应. 查了很长时间,最后在服务器上通过jstack pid命令查看Java堆栈信息,发现了有两个线程死锁. 看到造成死锁的原因 ...
- WinSCP列出’/’目录项出错
无法获得目录列表 如图所示,使用百度云虚拟机时,FTP连接服务器,出现错提示,官方给出的说法是使用其他的FTP进行连接,但是之前成功连接过,查找资料后说是打开过png,mp3等媒体文件,切换路径时出错 ...
- L009-oldboy-mysql-dba-lesson09
L009-oldboy-mysql-dba-lesson09 mysql> grant replication salve,replication client on *.* to ‘repl_ ...
- mysql---用户管理
#创建用户king , 登陆密码为1234 create user 'king' identified by '1234'; #查看创建用户的语句,即上面那条创建用户的语句 show grants f ...
- apache配置网站目录的读写权限
分享下apache中配置网站目录文件权限的方法. 假设http服务器运行用户和用户组是www,网站用户为centos,网站根目录是/home/centos/web. 操作方法与步骤:1,首先,设定网站 ...
- EditorLineEnds.ttr 受影响的D版本 Delphi 8-2010
http://stackoverflow.com/questions/25295980/delphi-2006-2010-error-cannot-create-file-c-users-admin- ...
- C#.Net EF实体框架入门视频教程
当前位置: 主页 > 编程开发 > C_VC视频教程 > C#.Net EF实体框架入门视频教程 > kingstone金士顿手机内存卡16G仅65元 1.EF实体框架之增加查 ...
- BitSet
前几天干了一件比较无聊的事儿——抄了一遍C++ STL bitset的源代码,把不懂的宏定义去掉了,发现(暂时)还能用,嘿嘿. #ifndef BITSET_H #define BITSET_H #i ...
- UITableViewCell 重合问题解决方法
这两天做ios遇到一个UITableViewCell 数据重合的问题,原因:引起这个问题的主要原因是,重用cell.之前cell上的内容未被清空,而又增加新增内容所致.从网上查了一些解决方法,比如: ...
- 预告:准备开个坑,集中学习一下esp32模块
对这个模块有兴趣的可以关注我以后的更新,寒假会抽空写几篇心得.