asp.net使用jquery.form实现图片异步上传

首先我们需要做准备工作:

jquery下载:http://files.cnblogs.com/tianguook/jquery1.8.rar

jquery.form.js下载:http://files.cnblogs.com/tianguook/jquery.form.js

页面JqueryFormTest.aspx:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="JqueryFormTest.aspx.cs" Inherits="JqueryFormTest" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1/xhtml">
<head runat="server">
    <title></title>
    <script src="JS/jquery-1.8.0.js" type="text/javascript"></script>
    <script src="JS/jquery.form.js" type="text/javascript"></script>
    <script type="text/javascript">
        $(function () {
            $("#btn").click(function () {
                $("#fm1").ajaxSubmit({
                    url: "img.ashx",
                    type: "post",
                    success: function (data) {
                        alert(data);
                        //IE显示图片会默认加上<PRE></PRE>,着必须要把去除掉才能在低版本ie显示  
                        data = data.replace("<PRE>", "").replace("</PRE>", "");
                        $("#divimg").append("<img src='" + data + "' width='200px' height='200px'/>");
                        //清空file控件里面的值  
                        var file = $("#btnfile");
                        file.after(file.clone().val(""));
                        file.remove();
                    }
                });
            });
        })  
    </script>
</head>
<body>
    <form id="fm1" method="post">
    <!--method="post"不能省略,在ie里面必不可少-->
    <input type="file" id="btnfile" name="btnfile" value="提交" />
    <br />
    <input type="button" id="btn" value="上传" />
    </form>
    <div id="divimg">
        
    </div>
</body>
</html>

img.ashx:

<%@ WebHandler Language="C#" Class="img" %>

using System;
using System.Web;

public class img : IHttpHandler {   
    public void ProcessRequest (HttpContext context) {
        context.Response.ContentType = "text/plain";
        //获取上传的文件的对象  
        HttpPostedFile img = context.Request.Files["btnfile"];

        //获取上传文件的名称  
        string s = img.FileName;
        //截取获得上传文件的名称(ie上传会把绝对路径也连带上,这里只得到文件的名称)  
        string str = s.Substring(s.LastIndexOf("\\") + 1);  
        string path = "~/upload/"+ str;
        //保存文件  
        img.SaveAs(context.Server.MapPath(path));
        //HttpRuntime.AppDomainAppVirtualPath主要是获取应用程序虚拟路径名称,因为响应给页面时不会自动添加而导致无法显示图片
        context.Response.Write(HttpRuntime.AppDomainAppVirtualPath + path.Substring(1));//path.Substring(1)用来去除第一个~字符
    }
 
    public bool IsReusable {
        get {
            return false;
        }
    }

}

 

更多相关文章
  • 我没有时间去唠叨自己的事,可是你们是我喜欢的人,ay很愿意写给你们分享:去年的万人阅读的总结链接:<没学历的IT人生没那么悲催,献给程序员们> 提前声明:本文不良反应:请自备垃圾桶,准备装节操.因为节操掉了一地. 茗洋原创诗词:山重水复哦哈妖,牧童遥指纳尼村.商女不知么么哒,隔江犹唱亚麻 ...
  •  近日,一直在阅读一些新观点新思维的书,吸取若干好玩有趣的现实视点,让自已在大众创业万众创新的浪潮里呛几口凉水,冷静冷静,看清情势,理清思路,从现在看未来,在未来看现在,这是创业者需要拥有的眼光. 以下观点不是我个人的,只是本人在阅读时偶遇的一些观点,并有所感悟,能理解到作者的意思,或者被观点/句子 ...
  • 易网科技讯 3月6日消息,华友世纪(NASDAQ:HRAY)今天公布截至2008年12月31日的2008年第四季度及全年财报显示,其第四季度总营收为1443万美元,环比增长6.65%,同比下滑9.22%.运营亏损528.6万美元,净亏损918万美元. 华友世纪本季度总营收1443万美元,环比增长6. ...
  • 2008年2月27日,国内知名的信息网络安全厂商金山联手全球最大的中文搜索引擎百度共同推出一款基于WEB的零客户端(网页方式)的安全解决方案--"百度安全中心",打造中国互联网最大免费杀毒平台,为广大网民提供免费的专业网络安全服务. 据了解,历经金山与百度半年的研发和测试后推出的 ...
  • 点击查看:MWC2014专题报道
  • 不管你有多好的商业点子也只能算是纸上谈兵,你需要的是将这些好的想法变为现实的资金,因此成功获得风投公司的亲睐对企业的发展至关重要.那么,究竟要怎样才能让自己的企业被风投公司选中呢?下面就是消费者信用与理财服务网站Gredit Karma 创始人Kenneth Lin为你支的招,Gredit Karm ...
一周排行
  • 在很多应用中,很多事情都是按照一定的次序来进行的,比如说起床穿衣时,不可能先穿鞋再穿袜子,但是穿袜子和穿裤子可以不分先后次序.这种按照一定顺序进行的活动,可以使用顶点表示活动,顶点之间的有向边表示活动间的先后关系,这 ...
  • 就象许多的PHP开发者一样,在刚开始建立动态网站的时候,我都是使用相对简单的数据结构.PHP在连接数据库方面的确实是十分方便(译者注:有些人认为 PHP在连接不同数据库时没有一个统一的接口,不太方便,其实这可以通过一 ...
  • 本文来源:趣火星HTC用一辆环美卡车让乡亲们体验了一把 Vive头盔.大家一起来看看如今最令人印象深刻的 VR头盔吧.Oculus Rift, Project Morpheus,Gear VR,甚至是 StarVR都 ...
  • 据新华社6月26日电  美国<华尔街日报>透露,传媒大亨默多克的新闻集团可能一分为二,旗下出版版块将与电影.电视.娱乐版块分道扬镳,各立门户. 报道说,最终决定尚未作出,而默多克本人热衷于"分家 ...
  • 线程:线程可以理解为"轻量级"的进程,它与创建它的进程共享代码段和数据段,同时拥有自己独立的栈. pthread_create 原型:int pthread_create(pthread_t *t ...
  •     Trailing return types是C++11关于函数声明的语言特性之一,旨在解决模版编程遇到的语法相关的问题,先看一个简单例子,感受一下什么是trailing return types: C++03 ...
  • 小米Note有几个版本?如果不是追求顶级配置的用户,可根据自己对于手机颜色和外观的喜好选择在标准版.女神版和天然竹版中任意进行选择,如果你是张杰的粉丝可以选择张杰版,如果你对手机的硬件有较高的需求建议入手顶配版.电信 ...
  • 易网科技讯 3月20日消息,英国<金融时报>今日向华为技术有限公司("华为")颁发了"业务新锐奖"(FT Boldness in Business award),以 ...
  • 本文为大家介绍下DEDE如何在图集列表中调出图集的所有图片,具体示例如下,大家可以参考下 在include/common.func.php 中添加以下函数代码 代码如下: // 在图集列表中调出图集的所有图片 fun ...
  • http://blog.sina.com.cn/s/blog_67571559010119bn.html