三层架构中ajax,基于mvc三层架构和ajax技术实现最简单的文件上传
前臺頁面提交文件
文件操作上傳文件
//上傳文件
function upFile() {
var file = document.getElementById("UpFile").files[0];
if (!file) {
alert("請選擇文件!");
return;
}
var size = file.size / 1024 / 1024;
if (size > 50) {
alert("圖片文件不能大于50M");
return;
}
$("#upFileForm").ajaxSubmit({
url: "/File/UploadFile",
type: "post",
dataType: "json",
success: function (data) {
if (data == "" || data == "0") {
alert("上傳失敗");
}
if (data == "2") {
alert("不支持上傳該文件");
} else {
alert(JSON.stringify(data));
}
},
error: function (aa) {
alert(aa);
}
});
}
后臺接收和上傳
[HttpPost]
public JsonResult UploadFile()
{
HttpRequest request = System.Web.HttpContext.Current.Request;
HttpFileCollection FileCollect = request.Files;
string path = "";//文件的完整路徑
//文件保存目錄路徑
string imgPathName = DateTime.Now.ToString("yyyyMMdd");//以日期為文件存放的上層文件夾名
string savePath = "/upload/file/" + imgPathName + "/";//文件存放的完整路徑
//如果文件路徑不存在則創建文件夾
if (!Directory.Exists(Server.MapPath(savePath)))
{
Directory.CreateDirectory(Server.MapPath(savePath));
}
//定義允許上傳的文件擴展名
Hashtable extTable = new Hashtable();
extTable.Add("file", "doc,docx,xls,xlsx,ppt,htm,html,txt,zip,rar,gz,bz2");
if (FileCollect.Count > 0)//如果集合的數量大于0,多文件上傳情況
{
foreach (string str in FileCollect)
{
HttpPostedFile imgFile = FileCollect[str];//用key獲取單個文件對象HttpPostedFile
string fileName = imgFile.FileName;//獲取文件名
string fileExt = Path.GetExtension(fileName).ToLower();//獲取文件后綴名
//判斷文件類型是否正確
if (Array.IndexOf(((string)extTable["file"]).Split(','), fileExt.Substring(1).ToLower()) == -1)
{
//文件類型不正確
return Json("2");
}
string imgName = DateTime.Now.ToString("yyyyMMddhhmmss");//文件別名
string imgPath = savePath + imgName + "-" + imgFile.FileName;//構造文件保存路徑
string AbsolutePath = Server.MapPath(imgPath);
imgFile.SaveAs(AbsolutePath);//將上傳的東西保存
path = imgPath;//獲得文件完整路徑并返回到前臺頁面
}
return Json(path);
}
else
{
//上傳失敗
return Json("0");
}
}
標簽:
版權申明:本站文章部分自網絡,如有侵權,請聯系:west999com@outlook.com
特別注意:本站所有轉載文章言論不代表本站觀點,本站所提供的攝影照片,插畫,設計作品,如需使用,請與原作者聯系,版權歸原作者所有
總結
以上是生活随笔為你收集整理的三层架构中ajax,基于mvc三层架构和ajax技术实现最简单的文件上传的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: oh my life是哪首歌啊?
- 下一篇: 华为云服务器默认密码怎么修改,云服务器怎