Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 528|回复: 0

MVC文件图片ajax上传轻量级解决方案,使用客户端JSAjaxFileUploader插件01-单文件上传

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-6-18 04:20:18 | 显示全部楼层 |阅读模式

    前段时间做了几个关于图片、文件上传的Demo,使用客户端Query-File-Upload插件和服务端Badkload组件实现多文件异步上传,比如"MVC文件上传04-使用客户端jQuery-File-Upload插件和服务端Backload组件实现多文件异步上传",就Demo而言,效果还算不错,但到了实际项目,发现使用Query-File-Upload插件和服务端Badkload组件与项目比较难融合,有"重"的感觉。相比而言,JSAjaxFileUploader这款插件比较"轻量级",它可以帮我们实现单个文件或多个文件的异步上传和管理,并且有不错的客户端效果,它的Demo在这里

     

    本篇源码在github,先看效果:

    ● 上传文件显示进度条:

    上传进度条

     

    ● 停止上传按钮和关闭缩略图按钮:

    右上角有停止上传和关闭按钮

     

    ● 限制上传文件的类型:

    文件类型不支持

     

    ● 限制上传文件的尺寸:

    限制上传文件尺寸

     

    ●上传成功后显示缩略图、文件名以及回传信息:

    上传成功显示缩略图文件名和删除链接

    ● 点击界面上的删除按钮,界面删除,同步删除文件夹中文件。
    ● 重新上传文件,界面删除,同步删除文件夹中文件,并界面显示新的缩略图、文件名等。

     

    □ HomeController

    由于需要把保存到文件夹文件的路径、文件名等回传给界面,所以需要一个类,专门负责回传给客户端所需要的信息。

        public class UploadFileResult
        {
            public string FileName { get; set; }
            public int Length { get; set; }
            public string Type { get; set; }
            public bool IsValid { get; set; }
            public string Message { get; set; }
            public string FilePath { get; set; } 
        }

    把上传的文件名改成以时间命名的格式,并保存到文件夹,再把回传信息以json形式传递给视图。关于删除,需要接收来自视图的文件名参数。

            #region 上传单个文件
     
            //显示
            public ActionResult Index()
            {
                return View();
            }
     
            //接收上传
            [HttpPost]
            public ActionResult UploadFile()
            {
                List<UploadFileResult> results = new List<UploadFileResult>();
                foreach (string file in Request.Files)
                {
                    HttpPostedFileBase hpf = Request.Files[file] as HttpPostedFileBase;
                    if (hpf.ContentLength == 0 || hpf == null)
                    {
                        continue;
                    }
     
                    var fileName = DateTime.Now.ToString("yyyyMMddhhmmss") +
                                   hpf.FileName.Substring(hpf.FileName.LastIndexOf('.'));
                    string pathForSaving = Server.MapPath("~/AjaxUpload");
                    if (this.CreateFolderIfNeeded(pathForSaving))
                    {
                        hpf.SaveAs(Path.Combine(pathForSaving, fileName));
                        results.Add(new UploadFileResult()
                        {
                            FilePath = Url.Content(String.Format("~/AjaxUpload/{0}", fileName)),
                            FileName = fileName,
                            IsValid = true,
                            Length = hpf.ContentLength,
                            Message = "上传成功",
                            Type = hpf.ContentType
                        });
                    }
                }
     
                return Json(new
                {
                    name = results[0].FileName,
                    type = results[0].Type,
                    size = string.Format("{0} bytes", results[0].Length),
                    path = results[0].FilePath,
                    msg = results[0].Message
                });
            }    
     
            #region 共用方法
            /// <summary>
            /// 检查是否要创建上传文件夹,如果没有就创建
            /// </summary>
            /// <param name="path">路径</param>
            /// <returns></returns>
            private bool CreateFolderIfNeeded(string path)
            {
                bool result = true;
                if (!Directory.Exists(path))
                {
                    try
                    {
                        Directory.CreateDirectory(path);
                    }
                    catch (Exception)
                    {
                        //TODO:处理异常
                        result = false;
                    }
                }
                return result;
            }
     
            //根据文件名称删除文件
            [HttpPost]
            public ActionResult DeleteFileByName(string name)
            {
                string pathForSaving = Server.MapPath("~/AjaxUpload");
                System.IO.File.Delete(Path.Combine(pathForSaving, name));
                return Json(new
                {
                    msg = true
                });
            }
            #endregion        
     

    □ Home/Index.cshml

    前台视图主要做如下几件事:
    ● 每次上传之前检查表格中是否有数据,如果有,实施界面删除并同步删除文件夹中的文件
    ● 上传成功动态创建表格行显示缩略图、文件名和删除按钮
    ● 点击删除按钮实施界面删除并同步删除文件夹中的文件

    由于表格行是动态生成的,需要对删除按钮以"冒泡"的方式注册事件: $('#tb').on("click", ".delImg", function ()

    <html>
    <head>
        <meta name="viewport" content="width=device-width" />
        <title>Index</title>
        <link href="~/Content/JSAjaxFileUploader/JQuery.JSAjaxFileUploader.css" rel="stylesheet" />
        <script src="~/Scripts/jquery-1.10.2.js"></script>
        <script src="~/Scripts/JSAjaxFileUploader/JQuery.JSAjaxFileUploaderSingle.js"></script>
        <style type="text/css">
            #tb table{
                border-collapse: collapse;              
                width: 600px;         
            }
     
            #tb td {
                text-align: center;
                padding-top: 5px;
                width: 25%;
            }
     
            #tb tr {
                background-color: #E3E3E3;
                line-height: 35px;
            }
     
            .showImg {
                width: 50px;
                height: 50px;
            }
        </style>
        <script type="text/javascript">
            $(function () {
                //隐藏显示图片的表格
                $('#tbl').hide();
     
                $('#testId').JSAjaxFileUploader({
                    uploadUrl: '@Url.Action("UploadFile","Home")',
                    inputText: '选择上传文件',
                    //fileName: 'photo',
                    maxFileSize: 512,    //Max 500 KB file 1kb=1024字节
                    allowExt: 'gif|jpg|jpeg|png',
                    zoomPreview: false,
                    zoomWidth: 360,
                    zoomHeight: 360,
                    beforesend: function (file) {
                        if ($('.imgName').text() != "") {
                            deleteImg();
                            $('#tbl').hide();
                        }
                    },
                    success: function (data) {
                        $('.file_name').html(data.name);
                        $('.file_type').html(data.type);
                        $('.file_size').html(data.size);
                        $('.file_path').html(data.path);
                        $('.file_msg').html(data.msg);
                        createTableTr();
                        $('#tbl').show();
                        $('.showImg').attr("src", data.path);
                        $('.imgName').text(data.name);
                    },
                    error: function (data) {
                        alert(data.msg);
                    }
                });
     
                //点击删除链接删除刚上传图片
                $('#tbl').on("click", ".delImg", function () {
                    deleteImg();
                    //window.location.reload();
                });
            });
     
            //删除图片方法:点击删除链接或上传新图片删除原先图片用到
            function deleteImg() {
                $.ajax({
                    cache: false,
                    url: '@Url.Action("DeleteFileByName", "Home")',
                    type: "POST",
                    data: { name: $('.imgName').text() },
                    success: function (data) {
                        if (data.msg) {
                            //alert("图片删除成功");
                            $('.delImg').parent().parent().remove();
                            
                        }
                    },
                    error: function (jqXhr, textStatus, errorThrown) {
                        alert("出错了 '" + jqXhr.status + "' (状态: '" + textStatus + "', 错误为: '" + errorThrown + "')");
                    }
                });
            }
     
            //创建表格
            function createTableTr() {
                var table = $('#tbl');
                table.append("<tr><td><img class='showImg'/></td><td colspan='2'><span class='imgName'></span></td><td><a class='delImg' href='javascript:void(0)'>删除</a></td></tr>");
            }
        </script>
    </head>
    <body>
        <div id="testId"></div>
        
        <div id="tb">
            <table id="tbl">
                <tbody>         
                </tbody>
            </table>
        </div>
            <div class="file_name"></div>
            <br />
            <div class="file_type"></div>
            <br />
            <div class="file_size"></div>
            <br />
            <div class="file_path"></div>
            <br />
            <div class="file_msg"></div>
    </body>
    </html>
     

     

    另外:
    需要删除源js文件中input元素的multiple属性,使之只能接收单个文件。

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-22 22:03 , Processed in 0.057854 second(s), 27 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表