html jsp asp.net 通用图片上传实现方法

在实际开发中,无论碰到app上传图片,还是bs前端上传图片,都是一个比较复杂的事情。
当然上传图片可以采用多种模式,例如,tcp/udp分包上传,websocket上传。但是兼容性最高的肯定是基于http通信实现的图片上传。
经过一段时间的研究,实现了通用性的图片上传服务端以及html端。

图片上传的原理,就是基于http的文件数据流上传。前端实现多种多样。
在这里,我就列举一种最简单的模式,使用layui上传,抛砖引玉。各位看官也可以使用h5自带的图片上,实现模式雷同。
不多废话了。上代码:

以下是前端html的核心代码。

    layui.use('upload', function () {
        var $ = layui.jquery
        , upload = layui.upload;
        //普通图片上传
        var uploadInst = upload.render({
            elem: '#test1'
          , url: 'Up.ashx' //改成自己的上传接口,
          , before: function (obj) {
              //预读本地文件示例,不支持ie8
              obj.preview(function (index, file, result) {
                  $('#demo1').attr('src', result); //图片链接(base64)
              });
          }
          , done: function (res) {
              //如果上传失败
              if (res.code > 0) {
                  return layer.msg('上传失败');
              }
              //上传成功
          }
          , error: function () {
              //演示失败状态,并实现重传
              var demoText = $('#demoText');
              demoText.html('<span style="color: #FF5722;">上传失败</span> <a class="layui-btn layui-btn-xs demo-reload">重试</a>');
              demoText.find('.demo-reload').on('click', function () {
                  uploadInst.upload();
              });
          }
        });
    });

至于服务端,目前采用 asp.net的模式实现图片上传接口,实现的功能如下:
1.可是同时支持多张图片的上传。
2.图片会存到服务端img的文件夹下面。
3.上传结果,会以json的模式给出,其中包含了,对应图片的url等关键信息。

                for (int i = 0; i < fileCount; i++)
                {
                    string fileName = HttpContext.Current.Request.Files[i].FileName;
                 
                    string imgFile = "img/" + fileName;
                    string filePath = HttpContext.Current.Server.MapPath(imgFile);
                    byte[] byts = new byte[HttpContext.Current.Request.Files[i].InputStream.Length];
                    HttpContext.Current.Request.Files[i].InputStream.Read(byts, 0, byts.Length);
                    FileStream fStream = new FileStream(filePath, FileMode.Create, FileAccess.Write);
                    BinaryWriter bw = new BinaryWriter(fStream);
                    bw.Write(byts);
                    bw.Close();
                    fStream.Close();

                    CImgmodel imgmodel = new CImgmodel();
                    imgmodel.fileName = fileName;
                    imgmodel.fileUrl = System.Configuration.ConfigurationManager.AppSettings.Get("imgurl").Trim() + fileName;
                    imglist.Add(imgmodel);
                }

服务端核心代码,思路如下:
1.首先根据收到的图片总数,开始循环进行处理图片。
2.使用流的模式将图片读出来,并且写入本地某个文件夹。
3.生成http图片地址,并保存起来。
4.最后,将整个图片上传结果封装成json对象返回到客户端(里面包含图片名字,图片http地址)。
至此大功告成。

因为代码量比较大,如有需要,请点击一下链接去下载完整的代码示例,验证可直接使用到项目中。
上传图片测试代码

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
逐个模块给出以下说明: 一个用户只能在同一时间登陆一次,需要经过电脑ip验证,用户名和密码验证,全部通过才可以进入首页。 用户登录:首先进入首页,显示该用户今天上传的图片。 1.查看图片:显示该用 户上传的所有图片,显示内容:图像描述,图像大小,是否验证,上传时间,查看,删除 2.上传图片:用户可以上传图片,在上传时有预览的功能,如果数据库中已存在上传过的照片,则提醒用户已上传,否则进入等待验证页面,等待后台验证,若验证成功则显示上传的图像,如果失败则提醒用户是否继续等待验证 3.修改口令:用户可以修改自己的密码 4.退出系统:用户退出当前系统,注销 5.团队简介和客户服务主要是显示团队介绍和联系方式 管理员登陆:进入首页,显示今天上传的所有图片,显示内容:编号,id,图像描述,图像大小,是否验证,上传用户,ip,上传时间,查看,删除 1.查看用户:显示用户名,密码,增加时间,上传几张图片,删除 2.增加用户:包括用户名,密码 3.查找用户:根据输入的用户名进行模糊查询,显示内容:用户名,密码,添加时间,上传几张图片,删除 4.查看所有图片:显示编号,id,图像描述,图像大小,是否验证,上传用户,ip,上传时间,查看,操作,其中id,图像描述,图像大小,是否验证,上传用户,ip,上传时间字段具有排序功能 5.查找图片:可以根据用户名和上传日期进行查询 6.查看节点:显示IP地址,删除 7.增加节点:输入客户端的ip地址进行添加 8.退出系统:进行注销 9.团队简介和客户服务:主要是显示团队介绍和联系方式
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值