asp.net javascript 文件無刷新上傳實例代碼
更新時間:2009年06月13日 19:47:05 作者:
最近在寫C# .net代碼的時候,遇到一個上傳刷新的問題。
第二種方法:用js動態(tài)創(chuàng)建form和iframe上傳文件,實現(xiàn)無刷新。優(yōu)點是代碼量小,無需客戶端安裝控件,缺點就是上傳有限制大小,下面看代碼:
需要文件有:1個前臺頁面upload.html、 1個js函數(shù) function upFile、 1個處理文件accept.aspx(accept.aspx.cs)
upload.html
復(fù)制代碼 代碼如下:
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>無標(biāo)題頁</title>
<script src="upload.js" src="upload.js" language="jscript" type="text/jscript"></script>
</head>
<body>
<form id="form1" runat="server">
<div style="width:100%">
<iframe name='hidden_frame' id="hidden_frame" style='width:150px; height:50px; display:none;'> </iframe>
<input type="file" id="hidFilePath" />
<input id="upBtn" type="button" class="clearBtn" style="display:none;" value="上傳圖片" onclick="upFile('hidFilePath');" />
</div>
</form>
</body>
</html>
function upFile
復(fù)制代碼 代碼如下:
function upFile(ob)
{
var file = document.getElementById(ob) ;
var newName = "FileName"; //設(shè)置文件保存的名字
var form=document.createElement('form');
document.body.appendChild(form);
form.encoding="multipart/form-data";
form.method = "post";
form.action= "accept.aspx?nm=" + newName;
form.target= "hidden_frame";
var pos=file.nextSibling; //記住file在舊表單中的的位置
form.appendChild(file);
form.submit();
pos.parentNode.insertBefore(file,pos);
document.body.removeChild(form);
}
accept.aspx
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="up.aspx.cs" Inherits="Member_up" %>
accept.aspx.cs
復(fù)制代碼 代碼如下:
using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
public partial class Member_up : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
string mz = HttpContext.Current.Request.QueryString["nm"].ToString();
string uperr = "";
HttpFileCollection files = HttpContext.Current.Request.Files;
if (files.Count>0)
{ uperr = upSingleFile(files[0], mz); }
else { uperr = "ok"; }
HttpContext.Current.Session["upInfo"] = uperr;
Response.Write(uperr);
}
//上傳文件
private string upSingleFile(HttpPostedFile file, String theFileName)
{
string infos = "";
bool fileOK = false;
string fileName, fileExtension ;
fileName = System.IO.Path.GetFileName(file.FileName);
if (fileName != "")
{
if (file.ContentLength >= 1024 * 1024 * 2)
{
infos = "上傳文件太大,目前僅支持2M以內(nèi)的圖片上傳!";
}
else
{
fileExtension = System.IO.Path.GetExtension(fileName).ToLower();
String[] allowedExtensions = { ".jpg", ".jpeg", ".gif", ".bmp", ".png", ".icon" };
for (int i = 0; i < allowedExtensions.Length; i++)
{
if (fileExtension == allowedExtensions[i])
{
fileOK = true;
break;
}
}
if (!fileOK)
{
infos = "不支持上傳此類型文件!目前支持的圖片格式有:jpg|jpeg|gif|bmp|png|icon";
}
else
{
file.SaveAs(System.Web.HttpContext.Current.Request.MapPath("~/books/BookPic/") + theFileName);
infos = "ok" + theFileName;
}
}
}
else
{
infos = "沒有讀取到文件!";
}
return infos;
}
}
以上為我寫程序過程中遇到過的問題和探索到的解決方法,寫下來一是自己在溫習(xí)鞏固一遍,二來是為了與大家分享,請大家指正需改進之處,以期達到共同進步!
您可能感興趣的文章:
- nodejs利用ajax實現(xiàn)網(wǎng)頁無刷新上傳圖片實例代碼
- PHP+JavaScript實現(xiàn)無刷新上傳圖片
- SpringMVC結(jié)合ajaxfileupload.js實現(xiàn)文件無刷新上傳
- jsp+ajax實現(xiàn)無刷新上傳文件的方法
- js實現(xiàn)頭像圖片切割縮放及無刷新上傳圖片的方法
- js動態(tài)創(chuàng)建上傳表單通過iframe模擬Ajax實現(xiàn)無刷新
- asp.net+js 實現(xiàn)無刷新上傳解析csv文件的代碼
- javascript仿163網(wǎng)盤無刷新文件上傳系統(tǒng)
- JavaScript實現(xiàn)無刷新上傳預(yù)覽圖片功能
相關(guān)文章
解決Win10無法安裝.Net Framework 3.5提示錯誤代碼0x800F081F
這篇文章主要介紹了Win10無法安裝.Net Framework 3.5提示錯誤代碼0x800F081F的完美解決方法,需要的朋友可以參考下2017-12-12
asp.net下獲取遠程網(wǎng)頁的內(nèi)容之二(downmoon原創(chuàng))
asp.net下獲取遠程網(wǎng)頁的內(nèi)容之二(downmoon原創(chuàng))...2007-04-04
asp.net下讓Gridview鼠標(biāo)滑過光棒變色效果
Gridview光棒效果 鼠標(biāo)滑過2010-07-07
IdnentiyServer使用客戶端憑據(jù)訪問API的實例代碼
這篇文章主要介紹了IdnentiyServer-使用客戶端憑據(jù)訪問API的相關(guān)知識,非常不錯,具有一定的參考借鑒價值 ,需要的朋友可以參考下2018-10-10
asp.net中倒計時自動跳轉(zhuǎn)頁面的實現(xiàn)方法(使用javascript)
本篇文章介紹了,asp.net中倒計時自動跳轉(zhuǎn)頁面的實現(xiàn)方法(使用javascript)。需要的朋友參考下2013-05-05

