一、前言

之前做图片上传一直用的第三方插件,Uploadify  这个应该是用的比較多的,相同也用过别的,在方便了自己的同一时候也非常赞叹人家的功能。

思来想去,仅仅会用别的人东西,始终自己学到的少,还是自己做个尝试一下吧。

二、效果

先来看看效果。 这是做微信接口开发的时候做的,比較简陋。仅仅是要实现功能而已。

(1):这是上传前的。

(2):这是未选择图片。

(3):这是选择好图片后的。

(4):这是上传后的效果。返回图片路径 ,然后显示在页面上,由于用的是ajax方式,所以不会看到页面刷新。

三、实现方式

(1):aspx页面代码

    <input id="file_temporaryImage" type="file" name="file_temporaryImage" />  <div id="div_temporaryImage"></div><br />
<input id="btn_temporary" type="button" value="上传暂时素材" onclick="javascript:TemporaryMedia();" />

(2):所用到的js方法

/***
2015年4月29日10:26:17
小马
微信上传素材管理
**/ /********************上传暂时素材 Start*****************************/
function TemporaryMedia() {
//var image0 = $("input[name='file_temporaryImage']").val();
//推断上传控件中是否选择了图片
var image = $("#file_temporaryImage").val();
if ($.trim(image) == "") {
alert("请选择图片。");
return;
}
//提交请求处理的url
var actionUrl = "ImageUpload.ashx";
//開始ajax操作
$("#form1").ajaxSubmit({ type: "POST",//提交类型
dataType: "json",//返回结果格式
url: actionUrl,//请求地址
data: { "action": "TemporaryImage" },//请求数据
success: function (data) {//请求成功后的函数 if (data.status == "warning") {//返回警告
alert(data.msg);
} else if (data.status == "success") {//返回成功
$("#div_temporaryImage").append("<img style='width:300px;height:300px;' src='" + data.msg + "' /><span>暂时素材mediaId:" + data.uploadmsg.media_id + "</span>");
} },
error: function (data) { alert(data.msg); },//请求失败的函数
async: true }); }
/********************上传暂时素材 End*****************************/

(3):所用到 的一般处理程序代码。

using System;
using System.IO;
using System.Text;
using System.Web;
using WeiXin_Web.Common;
using WX_Tools;
using WX_Tools.Entites; namespace WeiXin_Web
{
/// <summary>
/// ImageUpload 的摘要说明
/// </summary>
public class ImageUpload : IHttpHandler
{ private HttpContext _httpContext; public void ProcessRequest(HttpContext context)
{ _httpContext = context; // context.Response.ContentType = "text/plain";
//context.Response.Write("Hello World");
//获取请求
string requestAction=context.Request.Form["action"]; switch (requestAction)
{
//暂时图片素材
case "TemporaryImage":
TemporaryMeidaUpload();
break;
} } //回复消息状态
private enum status
{
error,
success,
warning
} /// <summary>
/// 上传暂时素材
/// </summary>
private void TemporaryMeidaUpload()
{
//返回格式:{"status":"error,success,warning","msg":""} // string result = "{\"status\":\"{0}\",\"msg\":\"{1}\"}"; try
{
//依据前台html的name获取文件
HttpPostedFile upfile = _httpContext.Request.Files["file_temporaryImage"]; if (upfile == null)
{ ResponseWriteEnd(status.warning.ToString(), "没有选择文件"); } //文件原名称
string oldMediaName = upfile.FileName; //文件后辍名称
string oldMediaExtension = Path.GetExtension(oldMediaName); //推断文件格式是否符合要求
if (!oldMediaExtension.ToLower().Equals(".jpg"))
{ ResponseWriteEnd(status.warning.ToString(), "请上传jpg格式的文件。");
return;
} //推断文件大小是否符合要求
if (upfile.ContentLength >= (1024*1024*1))
{
ResponseWriteEnd(status.warning.ToString(), "请上传1M以内的文件!");
return;
} string imgName = DateTime.Now.ToString("yyyy-MM-dd-HH-ss") + DateTime.Now.Ticks;
bool flag = false; try
{
upfile.SaveAs(_httpContext.Server.MapPath("/Upload/" + imgName + ".jpg"));
flag = true;
}
catch (Exception e)
{ //写入日志 } if (flag)
{
//返回json ResponseWriteEnd(status.success.ToString(), "/Upload/" + imgName + ".jpg"); }
else
{
File.Delete(_httpContext.Server.MapPath("/Upload/" + imgName + ".jpg")); ResponseWriteEnd(status.warning.ToString(), "图片保存出错,已经被删除。");
}
}
catch (Exception EX_NAME)
{ ResponseWriteEnd(status.error.ToString(),EX_NAME.ToString());
}
} /// <summary>
/// 输出方法
/// </summary>
/// <param name="status"></param>
/// <param name="msg"></param>
private void ResponseWriteEnd(string status,string msg,string uploadMsg="")
{
StringBuilder stringBuilder=new StringBuilder();
stringBuilder.Append("{");
stringBuilder.Append("\"status\":");
stringBuilder.AppendFormat("\"{0}\",", status);
stringBuilder.Append("\"msg\":");
stringBuilder.AppendFormat("\"{0}\",", msg);
stringBuilder.Append("\"uploadmsg\":");
stringBuilder.AppendFormat("{0}", uploadMsg);
stringBuilder.Append("}"); _httpContext.Response.Write(stringBuilder.ToString());
// _httpContext.Response.End();此方法会引起 中止线程错误 。
_httpContext.ApplicationInstance.CompleteRequest();
} public bool IsReusable
{
get
{
return false;
}
}
}
}

(4):要记得引入jquery.form.js这个文件。

四、源代码下载

因为这是我做微信接口开发中的代码的一部分。所以这里给出完整的微信接口开发的代码的地址,我托管在了github上,大家能够下载。也能够一起来编写这个项目。

https://github.com/anyangmaxin/WeiXin

五、欢迎增加.net技术交流群

欢迎增加.net技术交流群

使用Ajax以及Jquery.form异步上传图片的更多相关文章

  1. Jquery实现异步上传图片

    利用jQuery的ajax函数就可以实现异步上传图片了.一开始我是想在处理程序中,直接用context.Request.Files来获取页面中的input file,但是不知道为什么一次获取不了.网上 ...

  2. ajax+php (jquery.form插件)实现异步文件上传

    <!DOCTYPE html> <html lang="CN"> <head> <title>upload model</ti ...

  3. 使用jquery.form异步提交注意jquery.validate需要手动添加验证

    使用jquery.form.js异步提时,即使jquery.validate验证失败也会提交的所以加个$("form").valid()来判断是否通过验证: $("#fo ...

  4. Jquery.form异步上传文件常见问题解决

    Jquery.form常用方法我就不多说,主要说一下在使用过程中碰到的问题 1.提示 “xxxx” is not define 或者"xxx" is not a function ...

  5. http://www.vaikan.com/docs/jquery.form.plugin/jquery.form.plugin.html#getting-started

    http://www.vaikan.com/docs/jquery.form.plugin/jquery.form.plugin.html#getting-started Jquery.Form 异步 ...

  6. jQuery Form 表单提交插件----Form 简介,官方文档,官方下载地址

     一.jQuery Form简介 jQuery Form插件是一个优秀的Ajax表单插件,可以非常容易地.无侵入地升级HTML表单以支持Ajax.jQuery Form有两个核心方法 -- ajaxF ...

  7. jQuery学习笔记(jquery.form插件)

    官网: http://malsup.com/jquery/form/ jQuery Form插件是一个优秀的Ajax表单插件,可以非常容易地.无侵入地升级HTML表单以支持Ajax.jQuery Fo ...

  8. jQuery插件 -- Form表单插件jquery.form.js<转>

    jQuery Form插件是一个优秀的Ajax表单插件,可以非常容易地.无侵入地升级HTML表单以支持Ajax.jQuery Form有两个核心方法 -- ajaxForm() 和 ajaxSubmi ...

  9. jQuery Form

    https://github.com/jquery-form/form#type 概念 jQuery表单插件允许您轻松,无差错地升级HTML表单以使用AJAX. 主要方法ajaxForm和ajaxSu ...

随机推荐

  1. 基于visual Studio2013解决C语言竞赛题之1027 YN

          题目 解决代码及点评 /* 计算Yn的值,直到|Yn - Yn-1|<10-6为止,并打印出此时共作了多少次COS计算. 提示:Yn+1=COS(Yn),故本 ...

  2. Buenos Aires和Rio de Janeiro怎么发音?

    Buenos Aires和Rio de Janeiro怎么发音?_百度知道     Buenos Aires和Rio de Janeiro怎么发音?    2009-09-25 08:58 zd029 ...

  3. 手动加入PE文件数字签名信息及格式具体解释图之下(历史代码,贴出学习)

    #include <windows.h> HANDLE hWriteFileHandle = NULL ; HANDLE hReadFileHandle = NULL ; HANDLE h ...

  4. [转]java开发环境搭建

    分成两个部分: 1.下载安装jdk,并配置环境变量 链接:http://www.runoob.com/java/java-environment-setup.html 2.安装Eclipse 链接:h ...

  5. 微软Ajax--UpdatePanel控件

    今天用做日历显示本月的考勤记录,用到了UpdatePanel控件,才发现对这个控件并不太了解,所以找了点儿资料,整理了一下给大家发上来! 一.UpdatePanel的结构 <asp:Script ...

  6. AOP编程,spring实现及JDK,CGLIB实现

    什么是AOP? AOP(Aspect-OrientedProgramming,面向方面编程)和OOP(Object-Oriented Programing,面向对象编程)思想不同,两者并非对立关系,前 ...

  7. Ubuntu环境下SSH的安装及使用

    Ubuntu环境下SSH的安装及使用 SSH是指Secure Shell,是一种安全的传输协议,Ubuntu客户端可以通过SSH访问远程服务器 .SSH的简介和工作机制可参看上篇文章SSH简介及工作机 ...

  8. JAVA 实现发牌的 改进

    java是一门面向对象的语言,我们在解决这个问题的时候先找对象.我认为面想对象 “就是把复杂的问题变简单,简单的问题程序化” .如果我们  创建一盒牌--->洗牌--->选地主牌---&g ...

  9. Cloudera Hadoop 5& Hadoop高阶管理及调优课程(CDH5,Hadoop2.0,HA,安全,管理,调优)

    1.课程环境 本课程涉及的技术产品及相关版本: 技术 版本 Linux CentOS 6.5 Java 1.7 Hadoop2.0 2.6.0 Hadoop1.0 1.2.1 Zookeeper 3. ...

  10. FZOJ2111:Min Number

    Problem Description Now you are given one non-negative integer n in 10-base notation, it will only c ...