使用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 18 Javascript
JSON 教程 json入门学习笔记
Sep 22 Javascript
Bootstrap表格和栅格分页实例详解
May 20 Javascript
angular2中router路由跳转navigate的使用与刷新页面问题详解
May 07 Javascript
[原创]jquery判断元素内容是否为空的方法
May 04 jQuery
浅谈node.js 命令行工具(cli)
May 10 Javascript
JavaScript实现异步图像上传功能
Jul 12 Javascript
boostrap模态框二次弹出清空原有内容的方法
Aug 10 Javascript
js继承的这6种方式!(上)
Apr 23 Javascript
vue-router二级导航切换路由及高亮显示的实现方法
Jul 10 Javascript
js实现简单点赞操作
Mar 17 Javascript
JavaScript中使用Spread运算符的八种方法总结
Jun 18 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
浅谈关于JavaScript的语言特性分析
2013/04/11 Javascript
JavaScript中的cacheStorage使用详解
2015/07/29 Javascript
详解AngularJS实现表单验证
2015/12/10 Javascript
Node.js的项目构建工具Grunt的安装与配置教程
2016/05/12 Javascript
jQuery中fadein与fadeout方法用法示例
2016/09/16 Javascript
bootstrap下拉列表与输入框组结合的样式调整
2016/10/08 Javascript
js获取浏览器高度 窗口高度 元素尺寸 偏移属性的方法
2016/11/21 Javascript
微信小程序 form组件详解及简单实例
2017/01/10 Javascript
JavaScript实现的搜索及高亮显示功能示例
2017/08/14 Javascript
Javascript数组方法reduce的妙用之处分享
2019/06/10 Javascript
微信小程序实现滚动加载更多的代码
2019/12/06 Javascript
[04:11]2014DOTA2国际邀请赛 CIS遗憾出局梦想不灭
2014/07/09 DOTA
python 字符串格式化代码
2013/03/17 Python
Python实现把utf-8格式的文件转换成gbk格式的文件
2015/01/22 Python
详解Python中最难理解的点-装饰器
2017/04/03 Python
Python做智能家居温湿度报警系统
2018/09/25 Python
python bmp转换为jpg 并删除原图的方法
2018/10/25 Python
ubuntu上安装python的实例方法
2019/09/30 Python
Python3常用内置方法代码实例
2019/11/18 Python
python3读取csv文件任意行列代码实例
2020/01/13 Python
Python如何测试stdout输出
2020/08/10 Python
Django haystack实现全文搜索代码示例
2020/11/28 Python
iPhoneX安全区域(Safe Area)底部小黑条在微信小程序和H5的屏幕适配
2020/04/08 HTML / CSS
美容师的职业规划书
2013/12/27 职场文书
《窗前的气球》教学反思
2014/04/07 职场文书
文明城市标语
2014/06/16 职场文书
火箭队口号
2014/06/18 职场文书
2015年员工试用期工作总结
2014/12/12 职场文书
小数乘法教学反思
2016/02/22 职场文书
python tkinter模块的简单使用
2021/04/07 Python
python 用递归实现通用爬虫解析器
2021/04/16 Python
golang 如何通过反射创建新对象
2021/04/28 Golang
Python激活Anaconda环境变量的详细步骤
2021/06/08 Python
MySQL 使用索引扫描进行排序
2021/06/20 MySQL
mysql使用instr达到in(字符串)的效果
2022/04/03 MySQL
Java实现经典游戏泡泡堂的示例代码
2022/04/04 Java/Android