zoukankan      html  css  js  c++  java
  • 使用ajaxfileupload.js上传文件

      一直以来上传文件都是使用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; 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; } }

     存在问题:

        IE下有的浏览器会存在返回的值变为下载json文件的问题,把dataType修改为text,后台代码的请求类型也修改为text/html; charset=utf-8以及返回的头也是text/html; charset=utf-8

  • 相关阅读:
    Python学习之列表
    Python学习笔记
    Linux基础命令总结
    CentOS6.6安装mysql-5.7.25二进制安装包简易教程
    执行 cobbler get-loaders报错
    windows下 Qt 安装 taglib 获取媒体信息windows
    Qt dropEvent和dragEnterEvent问题
    Qt---去掉标题栏后,最大化应用程序窗口时,窗口遮住了任务栏的问题
    Qt 单击任务栏图标实现最小化
    Qt 无边框窗口的两种实现
  • 原文地址:https://www.cnblogs.com/liaoweipeng/p/5754502.html
Copyright © 2011-2022 走看看