使用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编程起步(第五课)
Jan 10 Javascript
JavaScript在IE中“意外地调用了方法或属性访问”
Nov 19 Javascript
JavaScript 关键字屏蔽实现函数
Aug 02 Javascript
javascript与asp.net(c#)互相调用方法
Dec 13 Javascript
window.open不被拦截的实现代码
Aug 22 Javascript
js实现字符串的16进制编码不加密
Apr 25 Javascript
详解JavaScript的Polymer框架中的通知交互
Jul 29 Javascript
通过node-mysql搭建Windows+Node.js+MySQL环境的教程
Mar 01 Javascript
BootStrap的Datepicker控件使用心得分享
May 25 Javascript
原生js实现点击轮播切换图片
Feb 11 Javascript
JavaScript实现轮播图特效
Apr 10 Javascript
arcgis.js控制地图地体的显示范围超出区域自动弹回(实现思路)
Jan 28 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
yii的CURD操作实例详解
2014/12/04 PHP
PHP如何通过AJAX方式实现登录功能
2015/11/23 PHP
php实现图片上传并利用ImageMagick生成缩略图
2016/03/14 PHP
PHP环形链表实现方法示例
2017/09/15 PHP
php实现的中秋博饼游戏之掷骰子并输出结果功能详解
2017/11/06 PHP
PHP中PDO事务处理操作示例
2018/05/02 PHP
input+select(multiple) 实现下拉框输入值
2009/05/21 Javascript
为指定元素增加样式的js代码
2009/12/09 Javascript
初学js插入节点appendChild insertBefore使用方法
2011/07/04 Javascript
基于javascript 闭包基础分享
2013/07/10 Javascript
查询json的数据结构的8种方式简介
2014/03/10 Javascript
IE下使用jQuery重置iframe地址时内存泄露问题解决办法
2015/02/05 Javascript
JS实现很酷的水波文字特效实例
2015/02/26 Javascript
js clearInterval()方法的定义和用法
2015/11/11 Javascript
详解Vue.js动态绑定class
2016/12/20 Javascript
jQuery插件echarts实现的多折线图效果示例【附demo源码下载】
2017/03/04 Javascript
如何编写一个d.ts文件的步骤详解
2018/04/13 Javascript
vue+express 构建后台管理系统的示例代码
2018/07/19 Javascript
详解VUE单页应用骨架屏方案
2019/01/17 Javascript
详解wepy开发小程序踩过的坑(小结)
2019/05/22 Javascript
javascript执行上下文、变量对象实例分析
2020/04/25 Javascript
Vuex中的Mutations的具体使用方法
2020/06/01 Javascript
在Echarts图中给坐标轴加一个标识线markLine
2020/07/20 Javascript
创建与框架无关的JavaScript插件
2020/12/01 Javascript
JavaScript实现点击切换验证码及校验
2021/01/10 Javascript
[40:05]LGD vs Winstrike 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/18 DOTA
python的多重继承的理解
2017/08/06 Python
python打包压缩、读取指定目录下的指定类型文件
2018/04/12 Python
python多线程+代理池爬取天天基金网、股票数据过程解析
2019/08/13 Python
python实现实时视频流播放代码实例
2020/01/11 Python
Python log模块logging记录打印用法解析
2020/01/20 Python
Python列表推导式实现代码实例
2020/09/09 Python
AmazeUI 点击元素显示全屏的实现
2020/08/25 HTML / CSS
《给予树》教学反思
2016/03/03 职场文书
Python基于百度API识别并提取图片中文字
2021/06/27 Python
Redis Lua脚本实现ip限流示例
2022/07/15 Redis