使用localResizeIMG3+WebAPI实现手机端图片上传

前言

惯例~惯例~昨天发表的使用OWIN作为WebAPI的宿主..嗯..有很多人问..是不是缺少了什么 - - 好吧,如果你要把OWIN寄宿在其他的地方...代码如下:

namespace ConsoleTest
{
    class Program
    {
        static void Main(string[] args)
        {
            string baseAddress = "http://localhost:9000/"; // 管道地址
            //开启管道监听
            WebApp.Start<Startup>(url: baseAddress);
            Console.WriteLine("开启成功!");
            // Create HttpCient and make a request to api/values 
                ////创建HTTP客户
                //HttpClient client = new HttpClient();
                //var response = client.GetAsync(baseAddress + "api/values").Result;
                //Console.WriteLine(response);
                //Console.WriteLine(response.Content.ReadAsStringAsync().Result);
            

            Console.ReadLine();
        }
    }
}

闲话不多说~让我们开始今天的内容,!

写过上传图片的都知道,在HTML5没出来以前,我们做上传图片预览,必须要先上传到服务器,然后在由服务器来反馈给客户端预览,这样..既不科学也会占用大量的服务器资源.

在BS迅速发展的今天,是时候来改变了..(咳咳,装下B..)

今天我们主要的内容是使用HTML5实现本地预览图片,然后在使用localResizeIMG3+AJAX的形式把图片传到我们昨天的WebAPI~然后存在服务器.

介绍一下localResizeIMG3 嗯..这是一个开源框架..主要目的是:没有蛀牙!!(咳咳,串戏了..),呃,是通过JS把图片压缩(可设置压缩率)成base64字符串 使其可以通过AJAX参数的形式直接上传.

localResizeIMG3 的开源地址:https://github.com/think2011/localResizeIMG3/releases

AJAX..WebAPI..需要我多说么? - -,

下面我们来看实现效果:

说明:我这里的压缩率设置为0.1..你们懂的..(好吧,不懂的话..其实就是我也说了手机端嘛,节省流量,~图片质量还行吧..)

正文开始

首先我们来看看WebAPI的实现代码~我的风格..你们懂的..不解释太多,都在注释里了..

  [HttpPost]
        public List<string> DoSaveImages([FromBody]JObject imgJObject)
        {
            List<string> list = new List<string>();
            for (int i = 1; i < 4; i++)
            {
                string img = "img" + i;
                if (imgJObject.Value<JObject>(img).Value<int>("size") > 0)
                {
                    //获取base64位数据流
                    var base64 = imgJObject.Value<JObject>(img).Value<string>("base64");
                    Regex reg = new Regex("data:image/(.*);base64,");
                    //正则替换
                    base64 = reg.Replace(base64, "");
                    //转换为byte数组
                    byte[] arr = Convert.FromBase64String(base64);
                    //转换为内存流
                    var ms = new MemoryStream(arr);
                    //转换为bitmap图片对象
                    var bmp = new Bitmap(ms);
                    //生成图片名称
                    string dizhi = DateTime.Now.ToString("yyyyMMddHHmmssffff");
                    var path = GetMapPath("~/Upimages/") + dizhi + ".jpg";
                    //存入服务器
                    bmp.Save(path);
                    string website = "http://" + HttpContext.Current.Request.Url.Authority;
                    list.Add(website + "/Upimages/" + dizhi + ".jpg");

                }
            }
            return list;
            
        }

下面我们来看看前端JS的代码~(重点~)

首先我们来看看HTML5直接客户端预览图片的代码:

 // 选择图片,读取地址预览的辅助函数
        //采用HTML5 FileReader接口 兼容IE9以上..
        function readURL(input, tmpimg) {

            if (input.files && input.files[0]) {
                var reader = new FileReader();
                //注册onload事件
                reader.onload = function (e) {
                    if (!/image/.test(e.target.result)) {
                        alert('请上传图片格式...');
                        return false;
                    }
                    tmpimg.attr('src', e.target.result);
                }
                //读取文件成为二进制流
                reader.readAsDataURL(input.files[0]);
            }
        }

好了,下面我们来看看关键的 上传图片的代码:

  //定义多图存储数组
        var img_data = {

            img1: {
                base64: "",
                size: 0
            },
            img2: {
                base64: "",
                size: 0
            },
            img3: {
                base64: "",
                size: 0
            }
        }
        $(function () {
            $(".choseimg input").change(function () {
                var $me = $(this);
                var index = $(this).attr("img");
                var $img = $me.parent().find('img');
                readURL(this, $img);
                //使用LEZ转换图片
                lrz(this.files[0], {
                    quality: 0.1,      //设置压缩率             
                    done: function (results) {
                        img_data[index].base64 = results.base64;
                        img_data[index].size = results.base64Len;
                        
                    }
                });
            });
        })
        //确定上传
        function Submit() {
            $.ajax({
                cache: true,
                type: "POST",
                url: 'api/Values/DoSaveImages',
                data: JSON.stringify(img_data)
                ,
                contentType: 'application/json',
                async: true,
                error: function (request) {
                    alert("出现异常,请联系客服");
                },
                success: function (data) {
                    for (var i = 0; i < data.length; i++) {
                        $("#upimage").append(' <img src="' + data[i] + '" />');
                    }
                }
            });
        }

这样,我们就完成使用localResizeIMG3+WebAPI实现手机端图片上传的全部功能~

我这里是多图上传所以定义了数组,大家可以根据需求对数据进行处理~

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏开发与安全

VS2008 + Opencv2.1 读取图片像素输出至Excel文件

系统环境: win 7 + VS2008 + Opencv2.1 + Excel 2010 思路:先通过Opencv库函数读取图片存储至IplImage结构体中...

2918
来自专栏圣杰的专栏

Razor Page Library:开发独立通用RPL(内嵌wwwroot资源文件夹)

Razor Page Library 是ASP.NET Core 2.1引入的新类库项目,属于新特性之一,用于创建通用页面公用类库。也就意味着可以将多个Web项...

842
来自专栏WebApiClient

WebApiClient进阶

你应该尽量将得到的myWebApi保持为全局变量,多次请求里共用一个myWebApi实例。如果频繁地每次请求都创建和释放myWebApi,实际等同于短连接到服务...

1570
来自专栏安恒网络空间安全讲武堂

逆向专题 | Writeup分享一

逆向WP分享一 0x01.re4 首先我们先点开运行试玩一下,大意就是让你输入正确的用户名和密码就能拿到flag,接下来进入正题。 ? 丢进IDA中,先shi...

2259
来自专栏盛国存的专栏

A Bite of GoLang(中)

上述的 v 就称为局部变量, sum 称为自由变量,`func(v int) int {

5517
来自专栏ASP.NET MVC5 后台权限管理系统

Fastreport.net 如何在开发MVC应用程序时使用报表

1474
来自专栏圣杰的专栏

ABP入门系列(5)——展现层实现增删改查

这一章节将通过完善Controller、View、ViewModel,来实现展现层的增删改查。最终实现效果如下图: ? 一、定义Controller ABP对A...

2035
来自专栏林德熙的博客

WPF 使用 Edge 浏览器

本文告诉大家如何使用 Windows Community Toolkit 的新控件,在 WPF 使用 Edge 浏览器

1031
来自专栏葡萄城控件技术团队

如何将GridViewEX升级到UWP(Universal Windows Platform)平台

引言 上一篇文章中,我们主要讲解了如何在保证GridView控件的用户体验基础上,扩展GridView生成GridViewEx控件,增加动态添加新分组功能等,本...

2008
来自专栏葡萄城控件技术团队

MVC5:使用Ajax和HTML5实现文件上传功能

引言 在实际编程中,经常遇到实现文件上传并显示上传进度的功能,基于此目的,本文就为大家介绍不使用flash 或任何上传文件的插件来实现带有进度显示的文件上传功能...

39610

扫码关注云+社区