原生 js 上传图片

 

js

复制代码
<!doctype html>
<html>
<head>
    <meta charset="utf-8">
    <title>js上传图片</title>
</head>
<body>
    <input id="file" type="file">

    <script type="text/javascript">
        window.onload = function myfunction() {
            var input = document.getElementById('file');
            input.onchange = function () {
                var files = this.files;
                for (var i = 0, len = files.length; i < len; i++) {
                    var file = files[i];
                    //file.name || file.fileName  => 文件名称
                    //file.size || file.fileSize  => 文件大小
                    upload_html5(file);
                }
            };
        }

        function upload_html5(file) {
            //html5 上传
            var xhr = new XMLHttpRequest();
            //上传进度事件
            xhr.upload.addEventListener("progress", function (e) { }, false);
            //上传完成(成功)事件
            xhr.addEventListener("load", function (e) {
                //获取服务器响应
                var obj = JSON.parse(e.target.responseText);
                if (obj.code == 200) {
                    alert("上传成功");
                }
                else {
                    alert(obj.message);
                }
            }, false);
            //上传失败事件
            xhr.addEventListener("error", function (e) {
                console.log(e); 
                alert("上传失败");
            }, false);
            //上传中断(取消)事件
            xhr.addEventListener("abort", function (e) {
                alert("上传取消");
            }, false);

            var fd = new FormData;
            //添加要上传的文件对象
            fd.append("file", file);
            fd.append("hallName", '分会场1');
            fd.append("dateTime", '2019-06-21');
            xhr.open("POST", "/Common/UploadFile");
            xhr.send(fd);
        }
    </script>
</body>
</html>
复制代码

 C#

复制代码
        public ActionResult UploadFile()
        {
            var baseDirectory = AppDomain.CurrentDomain.BaseDirectory;
            var directory = string.Format("{0}/Upload/{1}/", baseDirectory, Request.Form["hallName"]);
            if (!Directory.Exists(directory))
                Directory.CreateDirectory(directory);

            var file = Request.Files[0];
            var fileTypes = new string[] { "image/jpeg", "image/gif", "image/png" };
            if (!fileTypes.Contains(file.ContentType))
                return Json(new Response(302, "只可上传图片"));

            Image img = Image.FromStream(file.InputStream);
            var filePath = string.Format("{0}/{1}.jpg", directory, Request.Form["dateTime"]);
            ImageCompress(img, filePath, 50);
            return Json(new Response());
        }
        /// <summary>
        /// 将图片按百分比压缩
        /// </summary>
        public static bool ImageCompress(Image source, string savePath, byte percent)
        {
            var parameters = new EncoderParameters();
            parameters.Param[0] = new EncoderParameter(System.Drawing.Imaging.Encoder.Quality, new long[] { percent });
            try
            {
                ImageCodecInfo[] arrayICI = ImageCodecInfo.GetImageDecoders();
                ImageCodecInfo jpegICIinfo = arrayICI.SingleOrDefault(a => a.FormatDescription.Equals("JPEG", StringComparison.OrdinalIgnoreCase));
                if (jpegICIinfo != null)
                    source.Save(savePath, jpegICIinfo, parameters);
                else
                    source.Save(savePath, source.RawFormat);
                return true;
            }
            catch (Exception ex)
            {
                return false;
            }
            finally
            {
                source.Dispose();
            }
        }
复制代码

 

posted @   一只桔子2233  阅读(257)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
点击右上角即可分享
微信分享提示