zoukankan      html  css  js  c++  java
  • ajax如何上传文件(整理)

    ajax如何上传文件(整理)

    一、总结

    一句话总结:用FormDataFormData+ajax=异步上传二进制文件

        <form enctype="multipart/form-data">
            <p>上传csv文件<input type="file" id="csv_file" name="csv_file"/></p>
            <button id="import">导入</button>
        </form>
        <script type="application/javascript">
            $("#import").click(function () {
                var files = $('#csv_file').prop('files');
                var data = new FormData();
                data.append('csv_file', files[0]);
    
                $.ajax({
                    type: 'POST',
                    url: "http://xxxx/import_csv",
                    data: data,
                    cache: false,
                    processData: false,
                    contentType: false,
                    success: function (ret) {
                        alert(ret);
                    }
                });
            });
        </script>

    1、FormData是什么?

    利用 FormData 对象,可以通过JavaScript键值对来模拟一系列表单控件,还可以使用 XMLHttpRequestsend() 方法来异步提交表单。

    与普通的Ajax相比,使用FormData 的最大优点就是可以异步上传二进制文件

    2、FormData+ajax上传文件的注意事项?

    $.ajax({
        url: "upload.ashx",
        type: "POST",
        data: formData,
        /**
        *必须false才会自动加上正确的Content-Type
        */
        contentType: false,
        /**
        * 必须false才会避开jQuery对 formdata 的默认处理
        * XMLHttpRequest会对 formdata 进行正确的处理
        */
        processData: false,
        success: function (data) {

    二、文件的上传(表单上传和ajax文件异步上传)

    项目中用户上传总是少不了的,下面就主要的列举一下表单上传和ajax上传!注意: context.Request.Files不适合对大文件进行操作,下面列举的主要对于小文件上传的处理!

    资源下载:

    一.jQuery官方下载地址:https://jquery.com/download/

    一.表单上传:

    html客户端部分:

    <form action="upload.ashx" method="post" enctype="multipart/form-data">
            选择文件:<input type="file" name="file1" /><br />
            <input type="submit" value="上传" />
        </form>

    一般处理程序服务器端:

      public void ProcessRequest(HttpContext context)
            {
                context.Response.ContentType = "text/plain";
                HttpPostedFile file1 = context.Request.Files["file1"];
                helper.uploadFile(file1, "~/upload/");//这里就是对相应方法进行调用
                context.Response.Write("ok");//提示执行成功
            }

    上传代码的封装:

    /// <summary>
            /// 上传图片
            /// </summary>
            /// <param name="file">通过form表达提交的文件</param>
            /// <param name="virpath">文件要保存的虚拟路径</param>
            public static void uploadImg(HttpPostedFile file,string virpath)
            {          
                if (file.ContentLength > 1024 * 1024 * 4)
                {
                    throw new Exception("文件不能大于4M");
                }
                string imgtype = Path.GetExtension(file.FileName);
                if(imgtype!=".jpg"&&imgtype!=".jpeg")  //图片类型进行限制
                {
                    throw new Exception("请上传jpg或JPEG图片");
                }
                using (Image img = Bitmap.FromStream(file.InputStream))
                {
                    string savepath = HttpContext.Current.Server.MapPath(virpath+file.FileName);
                    img.Save(savepath);
                }
            }
            /// <summary>
            /// 上传文件
            /// </summary>
            /// <param name="file">通过form表达提交的文件</param>
            /// <param name="virpath">文件要保存的虚拟路径</param>
            public static void uploadFile(HttpPostedFile file, string virpath)
            {
                if (file.ContentLength > 1024 * 1024 * 6)
                {
                    throw new Exception("文件不能大于6M");
                }
                string imgtype = Path.GetExtension(file.FileName);
                //imgtype对上传的文件进行限制
                if (imgtype != ".zip" && imgtype != ".mp3")
                {
                    throw new Exception("只允许上传zip、rar....文件");
                }
                string dirFullPath=  HttpContext.Current.Server.MapPath(virpath);
                if (!Directory.Exists(dirFullPath))//如果文件夹不存在,则先创建文件夹
                {
                    Directory.CreateDirectory(dirFullPath);
                }
                file.SaveAs(dirFullPath + file.FileName);
            }

    二.Ajax文件异步上传:

     注明:既然有了表单上传为什么又要ajax上传呢?因为表单上传过程中,整个页面就刷新了!ajax异步上传就可以达到只刷新局部位置,下面就简单看看ajax上传吧!

    html客户端部分:

    <head> 
    <script src="jquery-2.1.4.js"></script>
        <script>
            $(function () {
                $("#upload").click(function () {
                    $("#imgWait").show();
                    var formData = new FormData();
                    formData.append("myfile", document.getElementById("file1").files[0]);   
                    $.ajax({
                        url: "upload.ashx",
                        type: "POST",
                        data: formData,
                        /**
                        *必须false才会自动加上正确的Content-Type
                        */
                        contentType: false,
                        /**
                        * 必须false才会避开jQuery对 formdata 的默认处理
                        * XMLHttpRequest会对 formdata 进行正确的处理
                        */
                        processData: false,
                        success: function (data) {
                            if (data.status == "true") {
                                alert("上传成功!");
                            }
                            if (data.status == "error") {
                                alert(data.msg);
                            }
                            $("#imgWait").hide();
                        },
                        error: function () {
                            alert("上传失败!");
                            $("#imgWait").hide();
                        }
                    });
                });
            });
        </script>
    </head>
    <body>   
            选择文件:<input type="file" id="file1" /><br />
            <input type="button" id="upload" value="上传" />
            <img src="wait.gif" style="display:none" id="imgWait" />   
    </body>

    一般处理程序服务器端:

    public void ProcessRequest(HttpContext context)
            {
                context.Response.ContentType = "text/html";
                if (context.Request.Files.Count > 0)
                {
                    HttpPostedFile file1 = context.Request.Files["myfile"];
                    helper.uploadFile(file1, "~/upload/");  //这里引用的是上面封装的方法
                    WriteJson(context.Response, "true", "");
                }
                else
                {
                    WriteJson(context.Response, "error", "请选择要上传的文件");
                }
            }

    json代码封装:

    public static void WriteJson(HttpResponse response,
               string status1, string msg1, object data1 = null)
            {
                response.ContentType = "application/json";
                var obj = new { status = status1, msg = msg1, data = data1 };
                string json = new JavaScriptSerializer().Serialize(obj);
                response.Write(json);
            }
    参考:文件的上传(表单上传和ajax文件异步上传) - 风雪幻林 - 博客园
    https://www.cnblogs.com/fengxuehuanlin/p/5311648.html

    三、ajax实现文件上传

    没有使用插件

    一、单文件上传

    <!DOCTYPE html>
    <html>
    <head lang="en">
        <meta charset="UTF-8">
        <script src="https://cdn.bootcss.com/jquery/1.10.2/jquery.min.js"></script>
        <title></title>
    </head>
    <body>
    <form id="uploadForm" enctype="multipart/form-data">
        文件:<input id="file" type="file" name="file"/>
    </form>
    <button id="upload">上传文件</button>
    </body>
    <script type="text/javascript">
        $(function () {
            $("#upload").click(function () {
                var formData = new FormData($('#uploadForm')[0]);
                $.ajax({
                    type: 'post',
                    url: "http://192.168.1.101:8080/springbootdemo/file/upload",
                    data: formData,
                    cache: false,
                    processData: false,
                    contentType: false,
                }).success(function (data) {
                    alert(data);
                }).error(function () {
                    alert("上传失败");
                });
            });
        });
    </script>
    </html>

    二、多文件上传

    <!DOCTYPE html>
    <html>
    <head lang="en">
        <meta charset="UTF-8">
        <script src="https://cdn.bootcss.com/jquery/1.10.2/jquery.min.js"></script>
        <title></title>
    </head>
    <body>
    <form id="uploadForm" enctype="multipart/form-data">
        文件:<input type="file" name="file" multiple="multiple"/><br>
    </form>
    <button id="upload">上传文件</button>
    </body>
    <script type="text/javascript">
        $(function () {
            $("#upload").click(function () {
                var formData = new FormData($('#uploadForm')[0]);
                $.ajax({
                    type: 'post',
                    url: "http://192.168.1.101:8080/springbootdemo/file/uploadFiles",
                    data: formData,
                    cache: false,
                    processData: false,
                    contentType: false,
                }).success(function (data) {
                    alert(data);
                }).error(function () {
                    alert("上传失败");
                });
            });
        });
    </script>
    </html>

    这个是多选上传,关键是multiple="multiple"这个属性,另外使用的接口也是多文件上传的接口。

    当然也可以使用单文件上传的模式,多次选择就可以了,只不过接口也是iyaoshiyong多文件上传的接口。

    <!DOCTYPE html>
    <html>
    <head lang="en">
        <meta charset="UTF-8">
        <script src="https://cdn.bootcss.com/jquery/1.10.2/jquery.min.js"></script>
        <title></title>
    </head>
    <body>
    <form id="uploadForm" enctype="multipart/form-data">
        文件:<input type="file" name="file"/><br>
        文件:<input type="file" name="file"/><br>
        文件:<input type="file" name="file"/><br>
    </form>
    <button id="upload">上传文件</button>
    </body>
    <script type="text/javascript">
        $(function () {
            $("#upload").click(function () {
                var formData = new FormData($('#uploadForm')[0]);
                $.ajax({
                    type: 'post',
                    url: "http://192.168.1.101:8080/springbootdemo/file/uploadFiles",
                    data: formData,
                    cache: false,
                    processData: false,
                    contentType: false,
                }).success(function (data) {
                    alert(data);
                }).error(function () {
                    alert("上传失败");
                });
            });
        });
    </script>
    </html>

    测试都通过了!!!

    参考:ajax实现文件上传 - CSDN博客
    https://blog.csdn.net/xxkalychen/article/details/77844542

    四、通过Ajax方式上传文件(input file),使用FormData进行Ajax请求

    <div  >
        <input type="file" name="FileUpload" id="FileUpload">
        <a class="layui-btn layui-btn-mini" id="btn_uploadimg">上传图片</a>
    </div>
    

      

     <script type="text/jscript">
    
            $(function () {
                $("#btn_uploadimg").click(function () {
                    var fileObj = document.getElementById("FileUpload").files[0]; // js 获取文件对象
                    if (typeof (fileObj) == "undefined" || fileObj.size <= 0) {
                        alert("请选择图片");
                        return;
                    }
                    var formFile = new FormData();
                    formFile.append("action", "UploadVMKImagePath");   
                    formFile.append("file", fileObj); //加入文件对象
    
                    //第一种  XMLHttpRequest 对象
                    //var xhr = new XMLHttpRequest();
                    //xhr.open("post", "/Admin/Ajax/VMKHandler.ashx", true);
                    //xhr.onload = function () {
                    //    alert("上传完成!");
                    //};
                    //xhr.send(formFile);
    
                    //第二种 ajax 提交
    
                    var data = formFile;
                    $.ajax({
                        url: "/Admin/Ajax/VMKHandler.ashx",
                        data: data,
                        type: "Post",
                        dataType: "json",
                        cache: false,//上传文件无需缓存 
                        processData: false,//用于对data参数进行序列化处理 这里必须false
                        contentType: false, //必须 
                        success: function (result) {
                            alert("上传完成!");
                        },
                    }) 
                }) 
            })
    
        </script>
    

      补充 IE8 不支持.files 写法

     
    参考:通过Ajax方式上传文件(input file),使用FormData进行Ajax请求 - 初吻给了糖 - 博客园
    https://www.cnblogs.com/LoveTX/p/7081515.html
     
     

    五、jquery ajax上传文件(php)

    例子:在页面上传一个csv文件,web服务器端用php解析上传的csv文件并入库
    前端页面代码:

        <form enctype="multipart/form-data">
            <p>上传csv文件<input type="file" id="csv_file" name="csv_file"/></p>
            <button id="import">导入</button>
        </form>
        <script type="application/javascript">
            $("#import").click(function () {
                var files = $('#csv_file').prop('files');
                var data = new FormData();
                data.append('csv_file', files[0]);
    
                $.ajax({
                    type: 'POST',
                    url: "http://xxxx/import_csv",
                    data: data,
                    cache: false,
                    processData: false,
                    contentType: false,
                    success: function (ret) {
                        alert(ret);
                    }
                });
            });
        </script>
    

    form的enctype必须是multipart/form-data才可以上传多个文件,ajax通过FormData来上传数据,ajax的cache、processData、contentType均要设置为false。
    cache设为false是为了兼容ie8,防止ie8之前版本缓存get请求的处理方式。
    contentType设置为false原因:https://segmentfault.com/a/1190000007207128
    processData:要求为Boolean类型的参数,默认为true。默认情况下,发送的数据将被转换为对象(从技术角度来讲并非字符串)以配合默认内容类型"application/x-www-form-urlencoded"。如果要发送DOM树信息或者其他不希望转换的信息,请设置为false。

    php代码:

                $uploadFile = $_FILES['csv_file'];
                $fileName = $uploadFile['tmp_name'];
                $fHandle = fopen($fileName, 'r');
                while ($data = fgetcsv($fHandle)) {
                    //入库处理
                }
                fclose($fHandle);
    

    php通过$_FILES读取上传的文件,通过tmp_name可以获取上传文件路径,通过fgetcsv函数读取csv文件数据


    参考:jquery ajax上传文件 - 简书
    https://www.jianshu.com/p/380661f02997
     
     
     
     
     
     
  • 相关阅读:
    用Groovy处理JMeter变量
    用Groovy处理JMeter断言和日志
    选择手动测试还是自动化测试?
    从单元测试标准中学习
    利用ThreadLocal解决线程同步问题
    JSON基础
    Java中interface属性和实例方法
    集成测试、单元测试、系统测试
    异步查询转同步加redis业务实现的BUG分享
    《深入理解java虚拟机》读书笔记三——第四章
  • 原文地址:https://www.cnblogs.com/Renyi-Fan/p/9581951.html
Copyright © 2011-2022 走看看