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 ...
一周排行
  • 台式机共享笔记本的无线网络(只需要一根网线)   一.笔记本的设置方法: 1.先将笔记本的无线连接共享给有线网卡 将鼠标放到桌面的网上邻居上,按鼠标右键,选属性,再将鼠标放到无线连接上,又是按鼠标右键,选属性,在弹出 ...
  • 有如下差别: 1.假设页面A通过include指令包含了页面B,那么B页面所发生的变化直到A页面发生变化时才会被注意到.这和JSP引擎的机制是有关的.使用include指令时,页面A在每次编译的时候才将页面B中的内容 ...
  • MPMediaQuery *myPlaylistsQuery = [MPMediaQuery songsQuery];      NSArray *playlists = [myPlaylistsQuery coll ...
  • 据TNW援引印度媒体报道,Yahoo将收购印度的云文档服务初创企业Bookpad,这是这家昔日的互联网巨头首次收购一家印度初创企业.Yahoo尚未确认此消息,但Bookpad所在的卡纳塔克邦政府官员已就此发表声明.交 ...
  • C技巧:VC中编译.运行程序的知识点(1) 1.Run-Time Library Run-Time Library是编译器提供的标准库,提供一些基本的库函数和系统调用. 我们一般使用的Run-Time Library ...
  • 在前几篇笔记中,我们有了解了部分对象创建型模式,包括Builder(建造者).Abstract Factory(抽象工厂)和Factory Method(工厂方法),今天我们要接触到的是另一种对象创建型模式,既简单又 ...
  • Win7系统自带资源监视器功能之探究   资源监视器其实我们几乎每天都会看见他,他就在我们的身边,我们每次打开任务管理器查看CPU还有内存使用情况的时候其实都会和他擦肩而过,只要我们一低头,肯定就会注意到他.  ww ...
  • #!/usr/bin/perl # carved-out by: crit3rion, just making th3 world a b3tt3r plac3! # Xerox_Remote_DoS.2008080 ...
  • 如何声明一个存储过程CREATE PROCEDURE 存储过程名(IN 输入变量名 输入变量类型,OUT 输出变量名 输出变量类型)紧跟其后的是存储过程属性列表            常用的有:LANGUAGE SQ ...
  • 摘要:大家在日常工作中,我想99%都会用到sqlplus工具来登陆你的数据库,对数据库进行管理.调优.配置.运维.那么如果有n多台数据库的时候,我们在连接后全部是统一的SQL>提示符,就有可能发生目前不知道连接 ...