C# 异步上传图片案例

简介: 好久没写博客了,都感觉自己快堕落了!今天随性写一篇关于异步上传图片的程序及插件!说是程序及插件,其实程序占大头,所谓的插件只是两个JS。分别为:jquery.html5upload.js 和 jquery.

好久没写博客了,都感觉自己快堕落了!今天随性写一篇关于异步上传图片的程序及插件!

说是程序及插件,其实程序占大头,所谓的插件只是两个JS。分别为:jquery.html5upload.js 和 jquery.MultiFile.js 

下载地址为:http://files.cnblogs.com/files/chenwolong/upload.rar

其实也没什么好说的,直接上源代码吧!

HTML展示如下:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="LLYY.WebForm1" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title></title>
    <script src="usercenter/js/jquery-1.11.1.min.js"></script>
    <script type="text/javascript" src="usercenter/js/jquery-1.11.1.min.js"></script>
    <script src="usercenter/js/jquery.html5upload.js" type="text/javascript"></script>
    <script src="usercenter/js/jquery.MultiFile.js" type="text/javascript"></script>
    
</head>
<body>
    <form id="form1" runat="server">
        <div>
            <input id="mainPicNum" name="mainPicNum" type="file"  class="" accept="gif|jpg|jpeg|png|bmp|pic" maxlength="1" onchange="change()"  />
        </div>
        <div id="result" style="padding-top:5px;">

        </div>
    </form>
</body>
</html>
<script type="text/javascript">
    $(function () {
        var result = document.getElementById("result");
        var input = document.getElementById("mainPicNum");

        if (typeof FileReader === 'undefined') {
            result.innerHTML = "抱歉,你的浏览器不支持 FileReader,请使用火狐浏览器,或其他兼容浏览器!";
            input.setAttribute('disabled', 'disabled');
        }

        $("#mainPicNum").MultiFile({
            afterFileSelect: function (element, value, master_element) {
                readFile.call(element);
            },
            afterFileRemove: function (element, value, master_element) {
                $('img').each(function () {
                    if ($(this).data('src') && (element.files[0].name == $(this).data('src'))) {
                        $(this).remove();
                    }
                });
            }
        });

        function readFile() {
            var file = this.files[0];
            if (!/image\/\w+/.test(file.type)) {
                alert("文件必须为图片!");
                return false;
            }
            var reader = new FileReader();
            reader.readAsDataURL(file);
            reader.onload = function (e) {
                result.innerHTML += '<img data-src="' + file.name + '" src="' + this.result + '" alt="" style=" height:100px; width:100px;"/>';
            }
        }
    });


    $('#mainPicNum').Html5Upload({
        url: 'UploadImage.ashx?action=action',
         perLoading: function (data, curindex) {
             // console.log(data)
             //$(".MultiFile-remove").css("display", "none");
             //$(".MultiFile-title").css("display", "none");
         },
         perLoaded: function (curindex, data) {
             //alert(data);
             //alert("上传头像成功");
             //var img = '<img src="/Images/foo.png" style="background-image: url(\'' + data + '\');" />';
             // $('#hiddenImg').val(data);
             //  $(".js_pic").html(img);
         }
    });

  
    </script>
View Code

一般处理程序如下:

using System;
using System.Collections.Generic;
using System.Drawing;
using System.IO;
using System.Linq;
using System.Web;

namespace LLYY
{
    /// <summary>
    /// UploadImage 的摘要说明
    /// </summary>
    public class UploadImage : IHttpHandler
    {

        public void ProcessRequest(HttpContext context)
        {
            if (HttpContext.Current.Request.QueryString["action"] == "action")
            {
                uppic();
            }
            context.Response.ContentType = "text/plain";
        }

        protected void uppic()
        {
            string fileTim = DateTime.Now.ToString("yyyMddHHmmssffff");

            string pic = HttpContext.Current.Request.Form["pic"];
            pic = HttpContext.Current.Server.UrlDecode(pic);
            if (pic != null)
            {
                pic = pic.Split(',')[1];
                MemoryStream stream = new MemoryStream(Convert.FromBase64String(pic));
                Bitmap image = new Bitmap(stream);
                string fileurl = "/usercenter/uppic/";
                string serverPath = HttpContext.Current.Server.MapPath(fileurl);

                if (Directory.Exists(serverPath) == false)//如果不存在就创建file文件夹
                {
                    Directory.CreateDirectory(serverPath);
                }
                
                string picNum=Guid.NewGuid().ToString("N");
                string url = fileurl +picNum + ".png";
                image.Save(HttpContext.Current.Server.MapPath(url));
                HttpContext.Current.Response.Write(url);
            }

            HttpContext.Current.Response.End();
        }

        public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    }
}
View Code

直接复制粘贴即可

但是,我有一个疑问,希望大家能帮我解决。

我的疑问如下:

当网页第一次加载完成后,我们选择图片,执行如下操作:

第一步图示如下:

这时,图片已经上传到了指定路径。

紧接着,我们进行第二步,

第二步,点击 x ,把选择的图片去掉,然后再重新选择,图示如下:

结果后端程序不再执行了,也就是说程序仅仅只会在第一次执行。更改后,不执行,这样的异步上传肯定是不能满足工作需求的,但是,我个人能力有限,实在解决不了,请问各位大神,谁有好办法解决这个问题!

在此先说声谢谢!

如果谁能解决,请大度点,把您的优质代码贴在评论区!万分感谢!

@陈卧龙的博客

相关文章
|
6月前
|
编译器 数据处理 C#
C#中的异步流:使用IAsyncEnumerable<T>和await foreach实现异步数据迭代
【1月更文挑战第10天】本文介绍了C#中异步流的概念,并通过使用IAsyncEnumerable<T>接口和await foreach语句,详细阐述了如何异步地迭代数据流。异步流为处理大量数据或需要流式处理数据的场景提供了一种高效且非阻塞性的方法,使得开发者能够更优雅地处理并发和数据流问题。
C#的基本语法结构学习案例详解
C#的基本语法结构学习案例详解
61 0
|
3月前
|
数据采集 存储 C#
C# 爬虫技术:京东视频内容抓取的实战案例分析
C# 爬虫技术:京东视频内容抓取的实战案例分析
|
8天前
|
C# UED SEO
C# 异步方法async / await任务超时处理
通过使用 `Task.WhenAny`和 `Task.Delay`方法,您可以在C#中有效地实现异步任务的超时处理机制。这种方法允许您在指定时间内等待任务完成,并在任务超时时采取适当的措施,如抛出异常或执行备用操作。希望本文提供的详细解释和代码示例能帮助您在实际项目中更好地处理异步任务超时问题,提升应用程序的可靠性和用户体验。
27 3
|
3月前
|
C#
C# async await 异步执行方法
C# async await 异步执行方法
53 0
|
5月前
|
C#
蓝易云 - C#将异步改成同步方法
注意:虽然这样可以将异步方法转为同步,但在实际开发中,我们通常推荐使用异步方法,因为它可以提高应用程序的响应性和并发性。将异步方法转为同步可能会导致死锁或性能问题。
43 2
|
6月前
|
C#
C#的类和对象的概念学习案例刨析
【5月更文挑战第17天】C#是一种面向对象的语言,以类和对象为核心。类作为对象的模板,定义了属性(如Name, Age)和行为(如Greet)。对象是类的实例,可设置属性值。封装通过访问修饰符隐藏实现细节,如Customer类的私有name字段通过Name属性访问。继承允许新类(如Employee)从现有类(Person)继承并扩展。多态让不同对象(如Circle, Square)共享相同接口(Shape),实现抽象方法Area,提供灵活的代码设计。
65 1
|
6月前
|
安全 算法 测试技术
C#编程实战:项目案例分析
【4月更文挑战第20天】本文以电子商务系统为例,探讨C#在实际项目中的应用。通过面向对象编程实现组件抽象和封装,确保代码的可维护性和可扩展性;利用安全性特性保护用户数据;借助数据库操作处理商品信息;通过逻辑控制和算法处理订单;调试工具加速问题解决,展现C#的优势:面向对象、数据库交互、数据安全和开发效率。C#在实际编程中展现出广泛前景。
303 2
|
6月前
|
C#
C#同步异步详解
C#同步异步详解
54 0
|
6月前
|
存储 C#
C#中的序列化和反序列化案例
C#中的序列化和反序列化案例