=波波日志 > JavaScript/Ajax > ajax无刷新上传文件,使用iframe模仿=
ajax无刷新上传文件,使用iframe模仿
其实ajax是无法上传文件的,所以得用隐藏的iframe来模仿
ajax未出现之前,一直都是隐藏的iframe来实现无刷新操作
如果谁看过图灵程序设计丛书的Ajax高级编程,就知道了。
示例下载点击这里
下面列出代码,asp的上传代码太麻烦,就使用。net了。。。
upload.ashx
test.htm
ajax未出现之前,一直都是隐藏的iframe来实现无刷新操作
如果谁看过图灵程序设计丛书的Ajax高级编程,就知道了。
示例下载点击这里
下面列出代码,asp的上传代码太麻烦,就使用。net了。。。
upload.ashx
+展开
-C#
//<%@?WebHandler?Language="C#"?Class="upload"?%>
using System;
using System.Web;
public class upload : IHttpHandler {
private string Js(string v) {//此函数进行js的转义替换的,防止字符串中输入了'后造成回调输出的js中字符串不闭合
if (v == null) return "";
return v.Replace("'", @"\'");
}
//下面就是一个简单的示例,保存上传的文件,如果要验证上传的后缀名,得自己写,还有写数据库什么的
public void ProcessRequest (HttpContext context) {
HttpRequest Request = context.Request;
HttpResponse Response = context.Response;
HttpServerUtility Server = context.Server;
//指定输出头和编码
Response.ContentType = "text/html";
Response.Charset = "utf-8";
HttpPostedFile f = Request.Files["upfile"];//获取上传的文件
string des = Request.Form["des"]//获取描述
,newFileName=Guid.NewGuid().ToString();//使用guid生成新文件名
if (f.FileName == "")//未上传文件
Response.Write(" ");//输出js,使用parent对象得到父页的引用
else { //保存文件
newFileName += System.IO.Path.GetExtension(f.FileName);//注意加上扩展名
try {
f.SaveAs(Server.MapPath("~/uploads/" + newFileName));//如果要保存到其他地方,注意修改这里
//调用父过程更新内容,注意要对des变量进行js转义替换,防止字符串不闭合提示错误
Response.Write(" ");
}
catch {
Response.Write(" ");//如果保存失败,输出js提示保存失败
}
}
}
public bool IsReusable {
get {
return false;
}
}
}
using System;
using System.Web;
public class upload : IHttpHandler {
private string Js(string v) {//此函数进行js的转义替换的,防止字符串中输入了'后造成回调输出的js中字符串不闭合
if (v == null) return "";
return v.Replace("'", @"\'");
}
//下面就是一个简单的示例,保存上传的文件,如果要验证上传的后缀名,得自己写,还有写数据库什么的
public void ProcessRequest (HttpContext context) {
HttpRequest Request = context.Request;
HttpResponse Response = context.Response;
HttpServerUtility Server = context.Server;
//指定输出头和编码
Response.ContentType = "text/html";
Response.Charset = "utf-8";
HttpPostedFile f = Request.Files["upfile"];//获取上传的文件
string des = Request.Form["des"]//获取描述
,newFileName=Guid.NewGuid().ToString();//使用guid生成新文件名
if (f.FileName == "")//未上传文件
Response.Write(" ");//输出js,使用parent对象得到父页的引用
else { //保存文件
newFileName += System.IO.Path.GetExtension(f.FileName);//注意加上扩展名
try {
f.SaveAs(Server.MapPath("~/uploads/" + newFileName));//如果要保存到其他地方,注意修改这里
//调用父过程更新内容,注意要对des变量进行js转义替换,防止字符串不闭合提示错误
Response.Write(" ");
}
catch {
Response.Write(" ");//如果保存失败,输出js提示保存失败
}
}
}
public bool IsReusable {
get {
return false;
}
}
}
test.htm
+展开
-HTML
!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/1999/xhtml">
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8" />
<title>使用隐藏的Iframe实现ajax无刷新上传title>
head>
<body>
<script type="text/javascript">
function UpdateMsg(des,filename){//此函数用来提供给提交到的页面如upload.ashx输出js的回调,更新当前页面的信息
if(filename==''){alert('未上传文件!');return false;}
document.getElementById('ajaxMsg').innerHTML='你在表单中输入的“文件描述”为:'+des+'
'
+'上传的图片为:'+filename+'';
}
function check(f){
if(f.des.value==''){
alert('请输入文件描述!');f.des.focus();return false;
}
if(f.upfile.value==''){
alert('请选择文件!');f.upfile.focus();return false;
}
}
script>
<iframe name="ajaxifr" style="display:none;">iframe>
<form method="post" enctype="multipart/form-data" action="upload.ashx" target="ajaxifr" onsubmit="return check(this)">
文件描述:<input type="text" name="des" /><br >
选择文件:<input type="file" name="upfile" /><br >
<input type="submit" value="提交" />
form>
<div id="ajaxMsg">div>
body>
html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8" />
<title>使用隐藏的Iframe实现ajax无刷新上传title>
head>
<body>
<script type="text/javascript">
function UpdateMsg(des,filename){//此函数用来提供给提交到的页面如upload.ashx输出js的回调,更新当前页面的信息
if(filename==''){alert('未上传文件!');return false;}
document.getElementById('ajaxMsg').innerHTML='你在表单中输入的“文件描述”为:'+des+'
'
+'上传的图片为:'+filename+'';
}
function check(f){
if(f.des.value==''){
alert('请输入文件描述!');f.des.focus();return false;
}
if(f.upfile.value==''){
alert('请选择文件!');f.upfile.focus();return false;
}
}
script>
<iframe name="ajaxifr" style="display:none;">iframe>
<form method="post" enctype="multipart/form-data" action="upload.ashx" target="ajaxifr" onsubmit="return check(this)">
文件描述:<input type="text" name="des" /><br >
选择文件:<input type="file" name="upfile" /><br >
<input type="submit" value="提交" />
form>
<div id="ajaxMsg">div>
body>
html>
类别:JavaScript/Ajax 作者:波波 日期:2009-07-07 【评论:2】
日期:2011-4-8 20:49:27 IP:118.186.*.*
不是很实用的 小技术。管理员回复(2011-4-11 9:07:44)
O(∩_∩)O~,只是一个示例~~大部分无刷新都是隐藏iframe。
- abc
日期:2012-1-2 10:17:50 IP:58.34.*.*
说的很有道理<div style=display:none></div>管理员回复(2012-1-2 15:59:22)
呵呵
发表留言
百度赞助
同类热门博文
- ·AJAX跨域问题解决办..
- ·ajax问题总结
- ·jQuery dataType指定..
- ·ajax+asp.net+mssql..
- ·ajax对象abort方法
- ·JavaScript代码,变..
- ·fckeditor编辑器在F..
- ·JavaScript解析XML的..
博格Tag
- flash/flex/fcs/AIR(752)
- Asp.Net/C#/WCF(595)
- 操作系统及应用软件(376)
- JavaScript/Ajax(330)
- SQL及数据库(134)
- 黑客技术(115)
- Asp/VBScript(111)
- HTML/WML/CSS兼容/XML(102)
- PHP/apache/Perl(96)
- 网站排名及优化(92)
- 其他(75)
- 个人日志(66)
- lucene.net/分词技术(33)
- 计算机网络(26)
- 机械重工(26)
- C#设计模式(24)
- Google Maps开发(17)
- 日语学习(15)
- Canvas/VML/SVG(13)
- linux(11)
- 游戏开发(8)
- 正则表达式(5)
- Jsp/Java(4)
最新博文
- ·javascript实现html..
- ·Javascript风格要素..
- ·Javascript风格要素
- ·动态加载JavaScript
- ·JavaScript陷阱
- ·ajax技巧
- ·IE对CSS样式表的限制..
- ·什么是Javascript匿..
随机博文
