您好,
会员登录 快速注册
退出 ( 条未读消息)
关于本站 意见反馈 首页

公告:小宅博客网可以开发票了,需要发票的,去群里找群主哈!!
全部文章分类
  • 人工智能 >

  • 编程语言 >

  • WPF系列 >

  • ASP.NET系列 >

  • Linux >

  • 数据库 >

  • 嵌入式 >

  • WEB技术 >

  • PLC系列 >

  • 微服务与框架 >

  • 小宅DIY >

  • 学习资料 >

OpenCv基础 ANN车牌识别 yolov5车牌识别 指针式仪表识别 ROS系列 YOLO Halcon Detectron2 昇腾AI ChatGPT在线体验 英伟达JETSON ChatGLM ChatTTS FunASR 地平线 ByteTrack 魔搭社区 LangChain
C C# C++ Python Java Go
WPF
ASP.NET小功能 GPS定位系统-MVC GPS定位系统-VUE ASP.NET WebRTC
Linux Linux内核 Shell MakeFile
MySql SqlServer Oracle
STM8 STM32 51单片机
VUE入门 HTML JavaScript CSS layui镜像网站 ElementUi中文官网 element-plus 图标
三菱 欧姆龙 西门子 施耐德 松下 台达
IOTSharp IOTGateway ABP FRAMEWORK Docker
亚克力音响 编程仙途:智驭万法
面试题与技巧 Python入门技能树 微软C#教程
首页 编程之美 工具下载 全国就业 流量地图 文心一言
C#
内容简介 1、C#环境下使用EF操作MySql 2、实现串口通信 3、TCP通信 4、读写SqlServer数据库 5、读写ini配置文件 6、实现远程升级 7、调用打印机 8、AES数据加密与解密 AES加解密(RijndaelManaged版) 9、FTP的上传和下载 10、封装dll到exe 11、重写Button控件 12、重写Labeld控件 13、重写DataGridView控件 14、重写TabControl控件 15、重写ProgressBar控件 16、加载状态弹窗设计 17、模拟按键精灵 18、24种数据校验算法 19、C#如何调用opencv 20、地图上显示GPS坐标 21、使用EPPlus导出/导入xlsx格式的Excel报表和曲线图 22、exe程序生成安装包 23、DataGridView控件列控制 24、json解析 25、自定义委托事件 26、xml文件的生成与读取 27、DataGridView实现翻页效果 28、如何实现CAD dxf文件的读取 29、StopWatch的使用 30、Async与Await 同步与异步操作 31、关闭登录窗体打开主窗体的方法 32、SQLite数据库的操作 33、MD5数据加密 34、DES数据加密与解密 35、获取本地IP地址 36、打开与保存文件 37、静态图表显示(曲线图) 38、动态图表显示(曲线图) 39、根据公网IP获取地址信息 40、List转DataTable 41、C#下实现Ping操作 42、父窗体中嵌入子窗体 43、获取MySql数据库列表 44、WebSocket通讯 45、Mqtt客户端与服务端通讯 46、使用QRCode生成二维码 47、AForge调用摄像头 48、Emgu.CV调用摄像头 49、获取以太网网卡IP 50、DataGridView全选与定位 51、如何获取系统中所有程序的句柄 遍历指定目录下的所有文件 ​NPOI Excel报表的导入与导出 常用正则表达式字符串格式判断 Task和Thread的启停操作 C# 一些常用小功能1 C# 一些常用小功能2 如何使用C#来发送QQ邮件 Aspose.Slides文档格式转换 C# GDI+ 画心形 跳动动画 使用Remoting实现RPC RabbitMQ.消息发布与订阅 .Net Core 微信/支付宝 官方Demo C# OCR图片文字识别 Quartz 计划任务 文字语音播报 winform基于百度地图的电子围栏、路径规划、小车导航实现 Visual Studio C盘数据迁移,解决C盘空间不足的问题 Kafka通讯(Kafka-Net版) Kafka通讯(Confluent.Kafka版) 获取变量Description描述 C# 将PDF文档转换为Word文档 C# MVC 多图片上传预览
C# 将PDF文档转换为Word文档
黄瓜炒鸡蛋 CSDN C#

文章作者:黄瓜炒鸡蛋

促销:¥0

价格:¥0

配送方式: 购买后立即生效(如购买异常,请联系站长)
付款之后一定要等待自动跳转结束,否则购买可能会失败
  • 0 天

    有效期

  • 0

    总销量

  • 0

    累计评价

C# MVC 多图片上传预览

CSDN原文章链接:https://blog.csdn.net/wuyanEdwardElrid/article/details/131398491


一.效果图:

0a5e87278e244442927131b16322a10a.png

开发框架:MVC,Layui 列表主界面这里就不展示了,可以去看看这篇文章:Layui项目实战,这里讲的是“上传Banner”界面功能: 其中包括,多文件上传,预览,后台接收,保存,仅此而已


二.项目代码:

1.前端Html代码


head头部代码块: 注意:这里引用的是Layui和jQuery插件,不过重点功能还是在jQuery,Layui只是起到样式效果

<head>
    <meta name="viewport" content="width=device-width" />
    <title>PushCircleBanner</title>
    <link href="~/Scripts/layui/css/layui.css" rel="stylesheet" />
    <script src="~/Scripts/jquery-3.3.1.js"></script>
    <script src="~/Scripts/layui/layui.js"></script>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        .box {
            width: 80%;
            height: 80vh;
            margin: auto;
        }
            .box p {
                height: 30px;
                margin: 10px;
            }
        #file{
            display:none;
        }
        .ImgsBox img{
            width:100px;
            height:100px;
        }
        .select,input{
            width:200px;
        }
    </style>
</head>


body代码块: 注意:这里既然是文件上传,重点自然是input["file"],multiple="multiple"多文件上传,accept=".png,.jpg,.jpeg,.bmp,.gif,.jfif,.ico "限制允许选择的文件类型

<div class="box">
        <p>性别:</p>
        <p class="layui-input-inline">
            <select name="sex" class="sex layui-input select">
                <option value="0" selected>全部</option>
                <option value="1">男</option>
                <option value="2">女</option>
            </select>
        </p>
        <p>是否去重:</p>
        <p class="layui-input-inline">
            <select name="isDistinct" class="isDistinct layui-input select">
                <option value="0" selected>否</option>
                <option value="1">是</option>
            </select>
        </p>
        <p>图片上传:</p>
            <p>
            <input type="button" class="layui-btn" name="name" onclick="$('#file').click()" value="上传" />
            <input id="file" type="file" multiple="multiple" name="img" value="上传" accept=".png,.jpg,.jpeg,.bmp,.gif,.jfif,.ico " onchange="PushFiles()" />
            </p>
        <p><input type="button" class="layui-btn submit" onclick="Save()" value="保存" /></p>
        
    <div class="ImgsBox">
    </div>

</div>


Js代码块:

注意:PushFiles方法,由点击显示的上传按钮,再触发隐藏的input["file"]按钮的点击方法,改变files值后触发该方法,实现多文件上传效果,也是这里前端界面展示的重点

<script>
        var files;
        function PushFiles() {
            $('.ImgsBox').html('');
            files = document.getElementById('file').files;
            if (files && files.length > 0) {
                for (var i = 0; i < files.length; i++) {
                    var file = files[i];
                    var URL = window.URL || window.webkitURL;
                    var imgURL = URL.createObjectURL(file);
                    console.log(imgURL);
                    var img = $('<img src="" />');
                    img.attr('src', imgURL);
                    $('.ImgsBox').append(img);
                }
                
            }
        }


注意:Save方法,由点击保存按钮触发,js的FormData对象进行表单参数收集,ajax再通过文件传输的方式,提交到后台

function Save() {
            if (files && files.length > 0) {
                var formData = new FormData();
                formData.append('sex', $('.sex').val());
                formData.append('isDistinct', $('.isDistinct').val());
                for (var i = 0; i < files.length; i++) {
                    formData.append('img_'+i,files[i] );
                }
                $.ajax({
                    url: '/Circle/PushBanner',
                    data: formData,
                    type: 'POST',
                    cache: false,//这个参数是jquery特有的,不进行序列化,因为我们不是json格式的字符串,而是要传文件
                    processData: false, //注意这里一定要设置contentType:false,不然会默认为传的是字符串,这样文件就传不过去了
                    contentType: false,
                    //dataType: "json",
                    success: function (res) {
                        if (res.code == 0) {
                            var index = parent.layer.getFrameIndex(window.name);//先得到当前iframe层的索引   
                            parent.layer.close(index);//再执行关闭
                        } else {
                            alert(res.msg);
                        }
                    }
                })
            } else {
                alert("请选择上传文件!");
            }
            
        }
    </script>


2.后台C#代码

注意:下面的后台代码块,只要把间隔的注意提示去掉,就能拼接出完整的后台代码

/// <summary>
/// 图片批量上传
/// </summary>
/// <returns></returns>
public ActionResult PushBanner()
{


后台登录校验

if (!(Session["account"] is AccountModel account))
            return Json(new { code = -1, msg = "登录异常" }, JsonRequestBehavior.AllowGet);


获取前端传输参数:

StringBuilder msg = new StringBuilder();
        int error = 0;
        AliyunOssProvider aliyunOss = new AliyunOssProvider();
        string suffix = string.Empty;
        var files = Request.Files;	//ajax传输文件
        var sex = Request.Form["sex"] == null ? 0 : int.Parse(Request.Form["sex"]);
        var isDistinct = Request.Form["isDistinct"] == null ? 0 : int.Parse(Request.Form["isDistinct"]);


多文件循环保存:

for (int i = 0; i < files.Count; i++)
        {
            var type = files[i].ContentType;
            if (type.Contains("image"))
            {
                switch (type)
                {
                    case "image/jpeg":
                        suffix = ".jpg";
                        break;
                    case "image/png":
                        suffix = ".png";
                        break;
                    case "image/bmp":
                        suffix = ".bmp";
                        break;
                    case "image/gif":
                        suffix = ".gif";
                        break;
                    case "image/pipeg":
                        suffix = ".jfif";
                        break;
                    case "image/x-icon":
                        suffix = ".ico";
                        break;
                    default:
                        error++;
                        var obj = new {
                            code = -1,
                            msg = "检测到非指定文件格式(jpg/png/bmp/gif/ico/jfif)"
                        };
                        msg.AppendLine(JsonHelper.SerializeObject(obj));
                        continue;
                        //return Json(new { result = false, messge = "请将图片转化为(jpg/png/bmp/gif/ico/jfif)格式然后上传!" });
                }
                if (string.IsNullOrWhiteSpace(suffix))
                {
                    error++;
                    var obj = new
                    {
                        code = -1,
                        msg = "检测到非指定文件格式(jpg/png/bmp/gif/ico/jfif)"
                    };
                    msg.AppendLine(JsonHelper.SerializeObject(obj));
                    continue;
                }
                var file = "banner/";
                var fileName = DateTime.Now.ToStampDateTime() + "_"+i + suffix;


阿里云图床文件存储,底层不予展示:

try
                {
                    var absoluteUri = aliyunOss.UploadObject(files[i].InputStream, file + fileName);
                }
                catch (Exception e)
                {
                    error++;
                    var obj = new { code = -2, message = "文件上传失败" };
                    msg.AppendLine(JsonHelper.SerializeObject(obj));
                    //return Json(new { result = false, message = "上传失败" });
                }


Banner信息存数据库:(底层是数据库保存语句)

var res = new CircleBll().AddCircleBanners(
                    new Model.CircleBanner() {
                        ImgUrl = AppConfig.AliyunUrl + file + fileName,
                        Sex = sex.ToString(),
                        IsDistinct = isDistinct.ToString(),
                        OperatorId = account.UserId.ToString()
                    }
                );
                if (!res)
                {
                    error++;
                    var obj = new { code = -3, message = "圈子Banner数据库存储失败" };
                }
            }
        }
        return error == 0 ? Json(new { code = 0, msg = "",data = true })
        : Json(new { code = error * -1,msg = msg.ToString(),data = false });
    }



C# 将PDF文档转换为Word文档

友情链接: CSDN激萌の小宅 95知识库 自考题库 罗分明个人网络博客 精益编程leanboot

小宅博客  www.bilibili996.com All Rights Reserved. 备案号: 闽ICP备2024034575号

网站经营许可证  福建省福州市 Copyright©2021-2025 版权所有

小宅博客
首页 智能家居 地图定位
公告:小宅博客网可以开发票了,需要发票的,去群里找群主哈!!

文章作者:黄瓜炒鸡蛋

促销:¥0

价格:¥0

配送方式: 购买后立即生效(如购买异常,请联系站长)
付款之后一定要等待自动跳转结束,否则购买可能会失败
  • 0 天

    有效期

  • 0

    总销量

  • 0

    累计评价

C# MVC 多图片上传预览

CSDN原文章链接:https://blog.csdn.net/wuyanEdwardElrid/article/details/131398491


一.效果图:

0a5e87278e244442927131b16322a10a.png

开发框架:MVC,Layui 列表主界面这里就不展示了,可以去看看这篇文章:Layui项目实战,这里讲的是“上传Banner”界面功能: 其中包括,多文件上传,预览,后台接收,保存,仅此而已


二.项目代码:

1.前端Html代码


head头部代码块: 注意:这里引用的是Layui和jQuery插件,不过重点功能还是在jQuery,Layui只是起到样式效果

<head>
    <meta name="viewport" content="width=device-width" />
    <title>PushCircleBanner</title>
    <link href="~/Scripts/layui/css/layui.css" rel="stylesheet" />
    <script src="~/Scripts/jquery-3.3.1.js"></script>
    <script src="~/Scripts/layui/layui.js"></script>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        .box {
            width: 80%;
            height: 80vh;
            margin: auto;
        }
            .box p {
                height: 30px;
                margin: 10px;
            }
        #file{
            display:none;
        }
        .ImgsBox img{
            width:100px;
            height:100px;
        }
        .select,input{
            width:200px;
        }
    </style>
</head>


body代码块: 注意:这里既然是文件上传,重点自然是input["file"],multiple="multiple"多文件上传,accept=".png,.jpg,.jpeg,.bmp,.gif,.jfif,.ico "限制允许选择的文件类型

<div class="box">
        <p>性别:</p>
        <p class="layui-input-inline">
            <select name="sex" class="sex layui-input select">
                <option value="0" selected>全部</option>
                <option value="1">男</option>
                <option value="2">女</option>
            </select>
        </p>
        <p>是否去重:</p>
        <p class="layui-input-inline">
            <select name="isDistinct" class="isDistinct layui-input select">
                <option value="0" selected>否</option>
                <option value="1">是</option>
            </select>
        </p>
        <p>图片上传:</p>
            <p>
            <input type="button" class="layui-btn" name="name" onclick="$('#file').click()" value="上传" />
            <input id="file" type="file" multiple="multiple" name="img" value="上传" accept=".png,.jpg,.jpeg,.bmp,.gif,.jfif,.ico " onchange="PushFiles()" />
            </p>
        <p><input type="button" class="layui-btn submit" onclick="Save()" value="保存" /></p>
        
    <div class="ImgsBox">
    </div>

</div>


Js代码块:

注意:PushFiles方法,由点击显示的上传按钮,再触发隐藏的input["file"]按钮的点击方法,改变files值后触发该方法,实现多文件上传效果,也是这里前端界面展示的重点

<script>
        var files;
        function PushFiles() {
            $('.ImgsBox').html('');
            files = document.getElementById('file').files;
            if (files && files.length > 0) {
                for (var i = 0; i < files.length; i++) {
                    var file = files[i];
                    var URL = window.URL || window.webkitURL;
                    var imgURL = URL.createObjectURL(file);
                    console.log(imgURL);
                    var img = $('<img src="" />');
                    img.attr('src', imgURL);
                    $('.ImgsBox').append(img);
                }
                
            }
        }


注意:Save方法,由点击保存按钮触发,js的FormData对象进行表单参数收集,ajax再通过文件传输的方式,提交到后台

function Save() {
            if (files && files.length > 0) {
                var formData = new FormData();
                formData.append('sex', $('.sex').val());
                formData.append('isDistinct', $('.isDistinct').val());
                for (var i = 0; i < files.length; i++) {
                    formData.append('img_'+i,files[i] );
                }
                $.ajax({
                    url: '/Circle/PushBanner',
                    data: formData,
                    type: 'POST',
                    cache: false,//这个参数是jquery特有的,不进行序列化,因为我们不是json格式的字符串,而是要传文件
                    processData: false, //注意这里一定要设置contentType:false,不然会默认为传的是字符串,这样文件就传不过去了
                    contentType: false,
                    //dataType: "json",
                    success: function (res) {
                        if (res.code == 0) {
                            var index = parent.layer.getFrameIndex(window.name);//先得到当前iframe层的索引   
                            parent.layer.close(index);//再执行关闭
                        } else {
                            alert(res.msg);
                        }
                    }
                })
            } else {
                alert("请选择上传文件!");
            }
            
        }
    </script>


2.后台C#代码

注意:下面的后台代码块,只要把间隔的注意提示去掉,就能拼接出完整的后台代码

/// <summary>
/// 图片批量上传
/// </summary>
/// <returns></returns>
public ActionResult PushBanner()
{


后台登录校验

if (!(Session["account"] is AccountModel account))
            return Json(new { code = -1, msg = "登录异常" }, JsonRequestBehavior.AllowGet);


获取前端传输参数:

StringBuilder msg = new StringBuilder();
        int error = 0;
        AliyunOssProvider aliyunOss = new AliyunOssProvider();
        string suffix = string.Empty;
        var files = Request.Files;	//ajax传输文件
        var sex = Request.Form["sex"] == null ? 0 : int.Parse(Request.Form["sex"]);
        var isDistinct = Request.Form["isDistinct"] == null ? 0 : int.Parse(Request.Form["isDistinct"]);


多文件循环保存:

for (int i = 0; i < files.Count; i++)
        {
            var type = files[i].ContentType;
            if (type.Contains("image"))
            {
                switch (type)
                {
                    case "image/jpeg":
                        suffix = ".jpg";
                        break;
                    case "image/png":
                        suffix = ".png";
                        break;
                    case "image/bmp":
                        suffix = ".bmp";
                        break;
                    case "image/gif":
                        suffix = ".gif";
                        break;
                    case "image/pipeg":
                        suffix = ".jfif";
                        break;
                    case "image/x-icon":
                        suffix = ".ico";
                        break;
                    default:
                        error++;
                        var obj = new {
                            code = -1,
                            msg = "检测到非指定文件格式(jpg/png/bmp/gif/ico/jfif)"
                        };
                        msg.AppendLine(JsonHelper.SerializeObject(obj));
                        continue;
                        //return Json(new { result = false, messge = "请将图片转化为(jpg/png/bmp/gif/ico/jfif)格式然后上传!" });
                }
                if (string.IsNullOrWhiteSpace(suffix))
                {
                    error++;
                    var obj = new
                    {
                        code = -1,
                        msg = "检测到非指定文件格式(jpg/png/bmp/gif/ico/jfif)"
                    };
                    msg.AppendLine(JsonHelper.SerializeObject(obj));
                    continue;
                }
                var file = "banner/";
                var fileName = DateTime.Now.ToStampDateTime() + "_"+i + suffix;


阿里云图床文件存储,底层不予展示:

try
                {
                    var absoluteUri = aliyunOss.UploadObject(files[i].InputStream, file + fileName);
                }
                catch (Exception e)
                {
                    error++;
                    var obj = new { code = -2, message = "文件上传失败" };
                    msg.AppendLine(JsonHelper.SerializeObject(obj));
                    //return Json(new { result = false, message = "上传失败" });
                }


Banner信息存数据库:(底层是数据库保存语句)

var res = new CircleBll().AddCircleBanners(
                    new Model.CircleBanner() {
                        ImgUrl = AppConfig.AliyunUrl + file + fileName,
                        Sex = sex.ToString(),
                        IsDistinct = isDistinct.ToString(),
                        OperatorId = account.UserId.ToString()
                    }
                );
                if (!res)
                {
                    error++;
                    var obj = new { code = -3, message = "圈子Banner数据库存储失败" };
                }
            }
        }
        return error == 0 ? Json(new { code = 0, msg = "",data = true })
        : Json(new { code = error * -1,msg = msg.ToString(),data = false });
    }