一、前言

之前做图片上传一直用的第三方插件,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. windows的消息传递--消息盒子(超详细EM_UNDO等消息)

    使用delphi的消息机制可以方便操作后台,其中重要的就是sendmessage()函数.下面讲解一下这个函数 function SendMessage(hWnd: HWND; Msg: UINT;  ...

  2. poj 1564 Sum It Up | zoj 1711 | hdu 1548 (dfs + 剪枝 or 判重)

    Sum It Up Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Total Sub ...

  3. 移动端 前端框架 amaze ui

    移动端 前端框架 amaze ui http://amazeui.org/?_ver=2.x

  4. [置顶] 提高生产力:Web开发基础平台WebCommon的设计和实现

    Web开发中,存在着各种各样的重复性的工作.为了提高开发效率,不在当码农,我在思考和实践如何搭建一个Web开发的基础平台. Web开发基础平台的目标和功能 1.提供一套基础的开发环境,整合了常用的框架 ...

  5. 上一篇括号配对让人联想起catalan数,顺便转载一篇归纳的还不错的文章

    转载请注明来自souldak,微博:@evagle 怎么样才是合法的组合? 只要每一时刻保证左括号的数目>=右括号的数目即可. 直接递归就行,每次递归加一个括号,左括号只要还有就能加,右括号要保 ...

  6. 关于ARM开发板与PC主机的网络设置问题

    直观来讲,ARM开发板多数情况下会有条网线与主机相连,所以最重要的一步是保证PC主机与ARM开发板能互通. 互通的意思进一步来讲就是互相能ping通.也就是说在瘟都死的dos下(假设主机是瘟都死系统) ...

  7. [Unity3D]Unity3D游戏开发之《愤慨的小鸟》弹弓实现

    各位朋友,大家晚上好, 我是秦元培.欢迎大家关注我的博客,我的博客地址是blog.csdn.net/qinyuanpei.今天我们来做一个高端大气上档次的东西. 我相信大家都玩过一款叫做<愤慨的 ...

  8. [置顶] android关机闹钟设计思路

    1: 首先需要硬件支持,支持alarm中断触发开机,目前高通平台几乎都支持: 2:关机前需要在rtc-xxx.c中做到enable_irq_wake,和不disable alarm功能(默认开机后al ...

  9. Vue ES6

    Vue ES6 Jade Scss Webpack Gulp   一直以来非常庆幸曾经有翻过<代码大全2>:这使我崎岖编程之路少了很多不必要的坎坷.它在软件工艺的话题中有写到一篇:“首先是 ...

  10. TComponent,TControl,TWinControl,TGraphic的DefineProperties赏析与说明(不懂)

    先观赏一下最后的实现效果: object Form1: TForm1 Left = Top = Width = Height = Caption = 'Form1' Color = clBtnFace ...