使用ajaxfileupload.js实现上传文件功能


Posted in Javascript onAugust 13, 2016

一直以来上传文件都是使用form表单上传文件,也看到过有人使用js上传文件,不过看起来蛮简单的也就没有怎么去理会。今天突然要使用这种方式上传文件,期间还遇到点问题。因此就记录下来,方便以后遇到这样的问题可以查看。

首先就是引入js和ajaxfileupload的文件,这个不需要多说。

然后就是ajax请求后台地址。代码如下: 

<div class="btn-file-box pos-rel">
   <input type="file" id="upload" name="upload" style="font-size: 0;opacity: 0;width: 100%;height: 100%;position: absolute;left: 0;top: 0;"/>
 <span class="btn ">选择文件</span>
 </div> 


$("#upload").on("change",function(){
    $.ajaxFileUpload({
      url : '/test/user/imgUpload',//后台请求地址
      type: 'post',//请求方式 当要提交自定义参数时,这个参数要设置成post
      secureuri : false,//是否启用安全提交,默认为false。 
      fileElementId : 'upload',// 需要上传的文件域的ID,即<input type="file">的ID。
      dataType : 'json',//服务器返回的数据类型。可以为xml,script,json,html。如果不填写,jQuery会自动判断。如果json返回的带pre,这里修改为json即可解决。
      success : function (json, status) {//提交成功后自动执行的处理函数,参数data就是服务器返回的数据。
         alert(json.retMsg);
      },
      error : function (json, status, e) {//提交失败自动执行的处理函数。
        
      }
    });
  });

前台代码完成就开始开发后台代码了。

package com.roc.test;import java.io.File;import java.util.List;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.ws.rs.Consumes;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.QueryParam;
import javax.ws.rs.core.Context;
import javax.ws.rs.core.MediaType;
import net.sf.json.JSONObject;
import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;
import org.jboss.resteasy.annotations.providers.jaxb.json.BadgerFish;
import org.springframework.stereotype.Controller;import net.sf.json.JSONObject;/**
 * 上传文件
 * @author liaowp
 *
 */
@Controller
@Path("/user")
public class UploadImg {
  
  @Path("/imgUpload")
  @POST
  @Produces("application/json; charset=utf-8")
  @Consumes(MediaType.MULTIPART_FORM_DATA ) 
  @BadgerFish
  public JSONObject upload(@QueryParam("orderId") String orderId,@Context HttpServletRequest request,@Context HttpServletResponse response) {
    JSONObject jsonobj = new JSONObject();
    String file_path=request.getSession().getServletContext().getRealPath("/")+File.separator+"corpfile"+File.separator;//文件存储路径  
    String upload_file_path="";
    File file =new File(file_path);  
    if(!file.exists() && !file.isDirectory()){ //如果文件夹不存在则创建    
       file.mkdir();
       upload_file_path=file_path;
    }else{
       upload_file_path=file_path;
    }
    DiskFileItemFactory factory = new DiskFileItemFactory(); // 设置工厂 
    factory.setRepository(new File(file_path));// 设置文件存储位置
    factory.setSizeThreshold(2048 * 1024);// 设置大小,如果文件小于设置大小的话,放入内存中,如果大于的话则放入磁盘中
    ServletFileUpload upload = new ServletFileUpload(factory);
    upload.setHeaderEncoding("utf-8");// 这里就是中文文件名处理的代码,其实只有一行
    String fileName = "";
    List<FileItem> list;
    JSONObject jsonobj = new JSONObject();
    try {
      list = upload.parseRequest(request);
      for (FileItem item : list) {
        if (item.isFormField()) {
          String name = item.getFieldName();
          String value = item.getString("utf-8");
        } else {
          String name = item.getFieldName();
          String value = item.getName();
          fileName =name + ".jpg";
          if (item.getSize() > 10485760) {//您好,上传文件要小于10M!
            jsonobj.put("retCode","100");
            jsonobj.put("retMsg","您好,上传文件要小于10M!"):
          } else {//上传成功
            item.write(new File(upload_file_path, fileName));
            System.out.println(File.separator + "corpfile" + File.separator + fileName);
            jsonobj.put("retCode","0");
            jsonobj.put("retMsg","您好,上传成功!");
          }
        }
      }
    } catch (Exception e) {//上传失败
      e.printStackTrace();
      jsonobj.put("retCode","9999");

 jsonobj.put("retMsg","您好,文件上传失败,");
    }
    return jsonobj;
  }

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript实现禁止后退的方法
Dec 27 Javascript
jQuery 美元符冲突的解决方法
Mar 28 Javascript
js动画效果制件让图片组成动画代码分享
Jan 14 Javascript
JavaScript函数参数使用带参数名的方式赋值传入的方法
Mar 19 Javascript
jQuery插件slick实现响应式移动端幻灯片图片切换特效
Apr 12 Javascript
浅谈jQuery中的$.extend方法来扩展JSON对象
Feb 12 Javascript
微信小程序 setData使用方法及常用错误解决办法
May 11 Javascript
JavaScript高阶函数_动力节点Java学院整理
Jun 28 Javascript
jQuery中的$是什么意思及 $. 和 $().的区别
Apr 20 jQuery
JavaScript+HTML5 canvas实现放大镜效果完整示例
May 15 Javascript
Express 配置HTML页面访问的实现
Nov 01 Javascript
详解datagrid使用方法(重要)
Nov 06 Javascript
几种二级联动案例(jQuery\Array\Ajax php)
Aug 13 #Javascript
漂亮! js实现颜色渐变效果
Aug 12 #Javascript
jQuery ztree实现动态树形多选菜单
Aug 12 #Javascript
jquery表格datatables实例解析 直接加载和延迟加载
Aug 12 #Javascript
jquery插件uploadify多图上传功能实现代码
Aug 12 #Javascript
Javascript中的对象和原型(二)
Aug 12 #Javascript
JavaScript中的对象和原型(一)
Aug 12 #Javascript
You might like
PHP中查询SQL Server或Sybase时TEXT字段被截断的解决方法
2009/03/10 PHP
php的memcache类分享(memcache队列)
2014/03/26 PHP
浅谈PHP定义命令空间的几个注意点(推荐)
2016/10/29 PHP
php获取linux命令结果的实例
2017/03/13 PHP
Yii2框架可逆加密简单实现方法
2017/08/25 PHP
PHP+RabbitMQ实现消息队列的完整代码
2019/03/20 PHP
文本加密解密
2006/06/23 Javascript
javascript xml为数据源的下拉框控件
2009/07/07 Javascript
用jQuery模拟页面加载进度条的实现代码
2011/12/19 Javascript
js URL参数的拼接方法比较
2012/02/15 Javascript
js中substring和substr的详细介绍与用法
2013/08/29 Javascript
JavaScript获取路径设计源码
2014/05/22 Javascript
DOM基础教程之事件对象
2015/01/20 Javascript
javascript动态生成树形菜单的方法
2015/11/14 Javascript
JS弹出层遮罩,隐藏背景页面滚动条细节优化分析
2016/04/29 Javascript
javaScript生成支持中文带logo的二维码(jquery.qrcode.js)
2017/01/03 Javascript
jquery easyui dataGrid动态改变排序字段名的方法
2017/03/02 Javascript
angular+bootstrap的双向数据绑定实例
2017/03/03 Javascript
vue技术分享之你可能不知道的7个秘密
2018/04/09 Javascript
解决koa2 ctx.render is not a function报错问题
2018/08/07 Javascript
JavaScript 性能提升之路(推荐)
2019/04/10 Javascript
Vue起步(无cli)的啊教程详解
2019/04/11 Javascript
详解Python文本操作相关模块
2017/06/22 Python
Python实现简单石头剪刀布游戏
2021/01/20 Python
python3利用ctypes传入一个字符串类型的列表方法
2019/02/12 Python
opencv转换颜色空间更改图片背景
2019/08/20 Python
Python嵌入C/C++进行开发详解
2020/06/09 Python
DVF官方网站:美国时装界尊尚品牌
2017/08/29 全球购物
药学专业大学生自荐信
2013/09/28 职场文书
酒店管理毕业生自荐信
2013/10/24 职场文书
教师简历自我评价
2014/02/03 职场文书
11月升旗仪式讲话稿
2014/02/15 职场文书
张丽莉事迹观后感
2015/06/16 职场文书
课文《燕子》教学反思
2016/02/17 职场文书
浅谈css实现背景颜色半透明的两种方法
2021/12/06 HTML / CSS
python 详解turtle画爱心代码
2022/02/15 Python