表單上傳功能實現(xiàn) ajax文件異步上傳
項目中用戶上傳總是少不了的,下面就主要的列舉一下表單上傳和ajax上傳!注意: context.Request.Files不適合對大文件進行操作,下面列舉的主要對于小文件上傳的處理!
資源下載:
一、jQuery官方下載地址:https://jquery.com/download/
一.表單上傳:
html客戶端部分:
<form action="upload.ashx" method="post" enctype="multipart/form-data">
選擇文件:<input type="file" name="file1" /><br />
<input type="submit" value="上傳" />
</form>
一般處理程序服務器端:
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
HttpPostedFile file1 = context.Request.Files["file1"];
helper.uploadFile(file1, "~/upload/");//這里就是對相應方法進行調用
context.Response.Write("ok");//提示執(zhí)行成功
}
上傳代碼的封裝:
/// <summary>
/// 上傳圖片
/// </summary>
/// <param name="file">通過form表達提交的文件</param>
/// <param name="virpath">文件要保存的虛擬路徑</param>
public static void uploadImg(HttpPostedFile file,string virpath)
{
if (file.ContentLength > 1024 * 1024 * 4)
{
throw new Exception("文件不能大于4M");
}
string imgtype = Path.GetExtension(file.FileName);
if(imgtype!=".jpg"&&imgtype!=".jpeg") //圖片類型進行限制
{
throw new Exception("請上傳jpg或JPEG圖片");
}
using (Image img = Bitmap.FromStream(file.InputStream))
{
string savepath = HttpContext.Current.Server.MapPath(virpath+file.FileName);
img.Save(savepath);
}
}
/// <summary>
/// 上傳文件
/// </summary>
/// <param name="file">通過form表達提交的文件</param>
/// <param name="virpath">文件要保存的虛擬路徑</param>
public static void uploadFile(HttpPostedFile file, string virpath)
{
if (file.ContentLength > 1024 * 1024 * 6)
{
throw new Exception("文件不能大于6M");
}
string imgtype = Path.GetExtension(file.FileName);
//imgtype對上傳的文件進行限制
if (imgtype != ".zip" && imgtype != ".mp3")
{
throw new Exception("只允許上傳zip、rar....文件");
}
string dirFullPath= HttpContext.Current.Server.MapPath(virpath);
if (!Directory.Exists(dirFullPath))//如果文件夾不存在,則先創(chuàng)建文件夾
{
Directory.CreateDirectory(dirFullPath);
}
file.SaveAs(dirFullPath + file.FileName);
}
二.Ajax文件異步上傳:
注明:既然有了表單上傳為什么又要ajax上傳呢?因為表單上傳過程中,整個頁面就刷新了!ajax異步上傳就可以達到只刷新局部位置,下面就簡單看看ajax上傳吧!
html客戶端部分:
<head>
<script src="jquery-2.1.4.js"></script>
<script>
$(function () {
$("#upload").click(function () {
$("#imgWait").show();
var formData = new FormData();
formData.append("myfile", document.getElementById("file1").files[0]);
$.ajax({
url: "upload.ashx",
type: "POST",
data: formData,
/**
*必須false才會自動加上正確的Content-Type
*/
contentType: false,
/**
* 必須false才會避開jQuery對 formdata 的默認處理
* XMLHttpRequest會對 formdata 進行正確的處理
*/
processData: false,
success: function (data) {
if (data.status == "true") {
alert("上傳成功!");
}
if (data.status == "error") {
alert(data.msg);
}
$("#imgWait").hide();
},
error: function () {
alert("上傳失敗!");
$("#imgWait").hide();
}
});
});
});
</script>
</head>
<body>
選擇文件:<input type="file" id="file1" /><br />
<input type="button" id="upload" value="上傳" />
<img src="wait.gif" style="display:none" id="imgWait" />
</body>
一般處理程序服務器端:
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/html";
if (context.Request.Files.Count > 0)
{
HttpPostedFile file1 = context.Request.Files["myfile"];
helper.uploadFile(file1, "~/upload/"); //這里引用的是上面封裝的方法
WriteJson(context.Response, "true", "");
}
else
{
WriteJson(context.Response, "error", "請選擇要上傳的文件");
}
}
json代碼封裝:
public static void WriteJson(HttpResponse response,
string status1, string msg1, object data1 = null)
{
response.ContentType = "application/json";
var obj = new { status = status1, msg = msg1, data = data1 };
string json = new JavaScriptSerializer().Serialize(obj);
response.Write(json);
}
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
JQuery ajax返回JSON時的處理方式 (三種方式)
json數(shù)據(jù)是一種經(jīng)型的實時數(shù)據(jù)交互的數(shù)據(jù)存儲方法,使用到最多的應該是ajax與json配合使用了,下面由腳本之家小編給大家分享JQuery ajax返回JSON時的處理方式 (三種方式),需要的朋友可以參考下2015-09-09
JavaScript基于Ajax實現(xiàn)不刷新在網(wǎng)頁上動態(tài)顯示文件內容
這篇文章主要介紹了JavaScript基于Ajax實現(xiàn)不刷新在網(wǎng)頁上動態(tài)顯示文件內容,可實現(xiàn)實時顯示服務器上txt文件內容的功能,是Ajax基本應用,具有一定參考借鑒價值,需要的朋友可以參考下2015-03-03
AJAX實現(xiàn)數(shù)據(jù)的增刪改查操作詳解【java后臺】
這篇文章主要介紹了AJAX實現(xiàn)數(shù)據(jù)的增刪改查操作,結合實例形式詳細分析了ajax結合java后臺實現(xiàn)數(shù)據(jù)庫增刪改查相關操作技巧,需要的朋友可以參考下2020-06-06

