uploadify批量上传文件完整使用教程,供大家参考,具体内容如下
1.首先准备uploadify的js文件,网上一搜一大堆
2.上传页面UpFilePage.aspx
关键代码:
<html xmlns=\"http://www.w3.org/1999/xhtml\"> <head runat=\"server\"> <meta http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\"/> <title>上传文件</title> <link href=\"/jquery.uploadify/uploadify.css\" rel=\"stylesheet\" /> <script type=\"text/javascript\" src=\"/jquery.uploadify/jquery-1.8.3.min.js\"></script> <script src=\"/jquery.uploadify/swfobject.js\" charset=\"utf-8\"></script> <script src=\"/jquery.uploadify/jquery.uploadify.v2.1.0.js\"></script> <style type=\"text/css\"> #fileSave { padding-left:5px; padding-right:5px;} #fileSave .uploadifyQueueItem{ width:530px;} #fileQueue { padding-left:5px; padding-right:5px;} #fileQueue .uploadifyQueueItem { width:530px;} #uploadifyUploader { position:absolute; opacity:0;} .uploadify-button{ height: 30px; line-height: 30px; width: 109px; text-align:center; border:0px; margin-bottom:5px; background:#ff6600; color:#fff;} .cancel a { background:url(/jquery.uploadify/cancel.png) no-repeat center center; display:inline-block; width:16px; height:16px;} </style> </head> <body> <form runat=\"server\"> <div> <div > <div> <input type=\"file\" name=\"uploadify\" /> <div><span>添加文件</span></div> </div> <div></div> <div> <%=GetFile() %> </div> </div> </div> </form> <script type=\"text/javascript\"> var fileCount = 0; $(document).ready(function () { fileCount = $(\"#fileSave>div.uploadifyQueueItem\").length; $(\"input[name=\'radPhone\']:eq(0)\").attr(\"checked\", \"checked\"); $(\"#uploadify\").uploadify({ \'uploader\': \'/jquery.uploadify/uploadify.swf\',//uploadify.swf 文件的相对路径 \'script\': \'/jquery.uploadify/uploadHandler.ashx\',//处理文件的程序 //\'cancelImg\': \'/Scripts/jquery.uploadify/cancel.png\',//取消图片 //\'folder\': \'upfiles\',//上传文件存放的目录 \'queueID\': \'fileQueue\',//文件队列的ID //\'fileDesc\': \'*.flv;*.mp4;*.wmv;*.avi;*.3gp;*.mpg;*.ppt;*.pptx\',//上传格式限制 //\'fileExt\': \'*.flv;*.mp4;*.wmv;*.avi;*.3gp;*.mpg;*.ppt;*.pptx\',//上传格式限制 \"queueSizeLimit\": \"5\",//当允许多文件生成时,设置选择文件的个数 \'auto\': true,//设置为true当选择文件后就直接上传了 \'multi\': true,//设置为true时可以上传多个文件 \"fileDataName\": \"imgFile\",//设置一个名字,在服务器处理程序中根据该名字来取上传文件的数据 \"sizeLimit\": \"5242880\",//上传文件的大小限制,以字节为单位 \"simUploadLimit\": \"1\",// 允许同时上传的个数 默认值:1 \"onSelect\": function (e, queueId, fileObj) { fileCount = $(\"#fileSave>div.uploadifyQueueItem\").length; var less = 5 - fileCount; if (less <= 0) { layer.msg(\"最多只能上传5个附件\"); $(\"#a_upload\").attr(\"href\", \"javascript:\"); return false; } else { $(\"#a_upload\").attr(\"href\", \"javascript:$(\'#uploadify\').uploadifyUpload()\"); return true; } }, \"onComplete\": function () { $.ajax({ type: \"post\", url: \"/UploadAction/UploadHandler.ashx\", data: { operate: \"GetFile\" }, async: false, success: function (objdata) { $(\"#fileSave\").html(objdata); fileCount = $(\"#fileSave>div.uploadifyQueueItem\").length; var less = 5 - fileCount; if (less <= 0) { $(\"#a_upload\").attr(\"href\", \"javascript:\"); $(\"#fileQueue\").html(\"\"); return false; } else { $(\"#a_upload\").attr(\"href\", \"javascript:$(\'#uploadify\').uploadifyUpload()\"); return true; } } }); }, \"onCancel\": function () { fileCount = $(\"#fileSave>div.uploadifyQueueItem\").length; var less = 5 - fileCount; if (less <= 0) { $(\"#a_upload\").attr(\"href\", \"javascript:\"); return false; } else { $(\"#a_upload\").attr(\"href\", \"javascript:$(\'#uploadify\').uploadifyUpload()\"); return true; } }, }); }); function deleteFile(path) { $.ajax({ type: \"post\", url: \"/UploadAction/UploadHandler.ashx\", data: { operate: \"deleteFile\", file: path }, success: function (objdata) { $(\"#fileSave\").html(objdata); fileCount = $(\"#fileSave>div.uploadifyQueueItem\").length; var less = 5 - fileCount; if (less <= 0) { $(\"#a_upload\").attr(\"href\", \"javascript:\"); } else $(\"#a_upload\").attr(\"href\", \"javascript:$(\'#uploadify\').uploadifyUpload()\"); } }); } </script> </body> </html>
后台的GetFile()方法:
/// <summary> /// 获取cookie附件信息 /// </summary> /// <returns></returns> protected string GetFile() { #region 获取cookie附件信息 StringBuilder strHtml = new StringBuilder(); HttpCookie fileCookie = Request.Cookies[\"FileCookie\"]; if (fileCookie != null) { string[] fileArray = new string[1]; if (fileCookie.Value.Contains(\"|\")) fileArray = fileCookie.Value.Split(\'|\'); else fileArray[0] = fileCookie.Value; foreach (string objFile in fileArray) { if (!string.IsNullOrEmpty(objFile) && objFile.Contains(\",\")) { string[] file = objFile.Split(\',\'); strHtml.Append(@\"<div class=\'uploadifyQueueItem\'>\"); strHtml.Append(@\"<div class=\'cancel\'>\"); strHtml.Append(\"<a href=\'javascript:deleteFile(\\\"\" + file[1] + \"\\\")\'></a>\"); //strHtml.Append(@\"<img src=\'/Scripts/jquery.uploadify/cancel.png\' border=\'0\'>\"); strHtml.Append(@\"</div>\"); strHtml.Append(@\"<span class=\'fileName\'>\" + HttpUtility.UrlDecode(file[0]) + \"</span><span class=\'percentage\'> - 100%</span><div class=\'uploadifyProgress\'>\"); strHtml.Append(@\"<div class=\'uploadifyProgressBar\' style=\'width: 100%;\'>\"); strHtml.Append(@\"</div>\"); strHtml.Append(@\"</div>\"); strHtml.Append(@\"</div>\"); } } } return strHtml.ToString(); #endregion }
3.UploadAction文件夹下的一般处理程序:
public void ProcessRequest(HttpContext context) { context.Response.ContentType = \"text/plain\"; string operate = context.Request[\"operate\"]; if (operate == \"deleteFile\") { #region 删除文件附件信息 //获取文件路径 string filePath = context.Server.MapPath(context.Request[\"file\"]); //判断文件是否存在 if (File.Exists(filePath)) File.Delete(filePath);//删除文件 //获取附件cookie信息 HttpCookie fileCookie = context.Request.Cookies[\"FileCookie\"]; string[] fileArray = new string[1]; if (fileCookie != null) { filePath = filePath.Remove(0, filePath.IndexOf(\"upfiles\")).Replace(\"\\\\\", \"/\"); if (fileCookie.Value.Contains(\"|\")) fileArray = fileCookie.Value.Split(\'|\'); else fileArray[0] = fileCookie.Value; string strFile = \"\"; for (int i = 0; i < fileArray.Length; i++) { if (!fileArray[i].Contains(filePath)) strFile += fileArray[i] + \"|\"; } if (strFile.Contains(\"|\")) strFile = strFile.Remove(strFile.Length - 1); fileCookie.Value = strFile; fileCookie.Expires = DateTime.Now.AddDays(1); fileCookie.HttpOnly = true; context.Response.AppendCookie(fileCookie); StringBuilder strHtml = new StringBuilder(); if (fileCookie.Value.Contains(\"|\")) fileArray = fileCookie.Value.Split(\'|\'); else fileArray[0] = fileCookie.Value; foreach (string objFile in fileArray) { if (!string.IsNullOrEmpty(objFile) && objFile.Contains(\",\")) { string[] file = objFile.Split(\',\'); strHtml.Append(@\"<div class=\'uploadifyQueueItem\'>\"); strHtml.Append(@\"<div class=\'cancel\'>\"); strHtml.Append(\"<a href=\'javascript:deleteFile(\\\"\" + file[1] + \"\\\")\'></a>\"); //strHtml.Append(@\"<img src=\'/Scripts/jquery.uploadify-v2.1.0/cancel.png\' border=\'0\'>\"); strHtml.Append(@\"</div>\"); strHtml.Append(@\"<span class=\'fileName\'>\" + HttpUtility.UrlDecode(file[0]) + \"</span><span class=\'percentage\'> - 100%</span><div class=\'uploadifyProgress\'>\"); strHtml.Append(@\"<div class=\'uploadifyProgressBar\' style=\'width: 100%;\'>\"); strHtml.Append(@\"</div>\"); strHtml.Append(@\"</div>\"); strHtml.Append(@\"</div>\"); } } context.Response.Write(strHtml.ToString()); } #endregion } else if (operate == \"GetFile\") { #region 获取上传的附件并展示 StringBuilder strHtml = new StringBuilder(); HttpCookie fileCookie = context.Request.Cookies[\"FileCookie\"]; if (fileCookie != null) { string[] fileArray = new string[1]; if (fileCookie.Value.Contains(\"|\")) fileArray = fileCookie.Value.Split(\'|\'); else fileArray[0] = fileCookie.Value; foreach (string objFile in fileArray) { if (!string.IsNullOrEmpty(objFile) && objFile.Contains(\",\")) { string[] file = objFile.Split(\',\'); strHtml.Append(@\"<div class=\'uploadifyQueueItem\'>\"); strHtml.Append(@\"<div class=\'cancel\'>\"); strHtml.Append(\"<a href=\'javascript:deleteFile(\\\"\" + file[1] + \"\\\")\'>\"); //strHtml.Append(@\"<img src=\'/Scripts/jquery.uploadify-v2.1.0/cancel.png\' border=\'0\'></a>\"); strHtml.Append(@\"</div>\"); strHtml.Append(@\"<span class=\'fileName\'>\" + HttpUtility.UrlDecode(file[0]) + \"</span><span class=\'percentage\'> - 100%</span><div class=\'uploadifyProgress\'>\"); strHtml.Append(@\"<div class=\'uploadifyProgressBar\' style=\'width: 100%;\'>\"); strHtml.Append(@\"</div>\"); strHtml.Append(@\"</div>\"); strHtml.Append(@\"</div>\"); } } } context.Response.Write(strHtml.ToString()); #endregion } }
4.上传文件uploadHandler.ashx一般处理程序代码,文件上传路径可以根据剧情需要自由设定:
public void ProcessRequest(HttpContext context) { context.Response.ContentType = \"text/plain\"; HttpCookie fileCookie = context.Request.Cookies[\"FileCookie\"]; if (fileCookie != null) { string[] fileArray = new string[1]; if (fileCookie.Value.Contains(\"|\")) fileArray = fileCookie.Value.Split(\'|\'); if (fileArray.Length >= 5) return; } else { fileCookie = new HttpCookie(\"FileCookie\"); fileCookie.Value = \"\"; context.Response.Cookies.Add(fileCookie); } String aspxUrl = context.Request.Path.Substring(0, context.Request.Path.LastIndexOf(\"/\") + 1); //文件保存目录路径 String savePath = \"/upfiles/\"; //文件保存目录URL String saveUrl = \"/upfiles/\"; //if (context.Request.Cookies[\"Member\"] != null) //{ // savePath += context.Request.Cookies[\"Member\"][\"MemberId\"] + \"/\"; // saveUrl += context.Request.Cookies[\"Member\"][\"MemberId\"] + \"/\"; //} string Member = Guid.NewGuid().ToString().Trim().Replace(\"-\", \"\"); savePath += Member + \"/\"; saveUrl += Member + \"/\"; //定义允许上传的文件扩展名 /*Hashtable extTable = new Hashtable(); extTable.Add(\"image\", \"gif,jpg,jpeg,png,bmp\"); extTable.Add(\"flash\", \"swf,flv\"); extTable.Add(\"media\", \"swf,flv,mp3,wav,wma,wmv,mid,avi,mpg,asf,rm,rmvb,mp4\"); extTable.Add(\"file\", \"doc,docx,xls,xlsx,ppt,htm,html,txt,zip,rar,gz,bz2,swf,flv,mp3,wav,wma,wmv,mid,avi,mpg,asf,rm,rmvb,mp4,wps\");*/ //最大文件大小 int maxSize = 5242880; HttpPostedFile imgFile = context.Request.Files[\"imgFile\"]; /*if (imgFile == null) { showError(\"请选择文件。\"); }*/ String dirPath = context.Server.MapPath(savePath); if (!Directory.Exists(dirPath)) { Directory.CreateDirectory(dirPath); //showError(\"上传目录不存在。\"); } String dirName = context.Request.QueryString[\"dir\"]; if (String.IsNullOrEmpty(dirName)) { dirName = \"file\"; } /*if (!extTable.ContainsKey(dirName)) { showError(\"目录名不正确。\"); }*/ String fileName = imgFile.FileName; String fileExt = Path.GetExtension(fileName).ToLower(); /*if (String.IsNullOrEmpty(fileExt) || Array.IndexOf(((String)extTable[dirName]).Split(\',\'), fileExt.Substring(1).ToLower()) == -1) { showError(\"上传文件扩展名是不允许的扩展名。\\n只允许\" + ((String)extTable[dirName]) + \"格式。\"); } if (dirName.Contains(\"image\")) { if (imgFile.InputStream == null || imgFile.InputStream.Length > maxSize) { showError(\"上传文件超过5M大小限制。\"); } }*/ //创建文件夹 dirPath += dirName + \"/\"; saveUrl += dirName + \"/\"; if (!Directory.Exists(dirPath)) { Directory.CreateDirectory(dirPath); } String ymd = DateTime.Now.ToString(\"yyyyMMdd\", DateTimeFormatInfo.InvariantInfo); dirPath += ymd + \"/\"; saveUrl += ymd + \"/\"; if (!Directory.Exists(dirPath)) { Directory.CreateDirectory(dirPath); } String newFileName = DateTime.Now.ToString(\"yyyyMMddHHmmss_ffff\", DateTimeFormatInfo.InvariantInfo) + fileExt; String filePath = dirPath + newFileName; imgFile.SaveAs(filePath); String fileUrl = saveUrl + newFileName; /*Hashtable hash = new Hashtable(); hash[\"error\"] = 0; hash[\"url\"] = fileUrl; context.Response.AddHeader(\"Content-Type\", \"text/html; charset=UTF-8\"); context.Response.Write(JsonMapper.ToJson(hash)); context.Response.End();*/ if (fileCookie != null) { string strFile = fileCookie.Value; if (!string.IsNullOrEmpty(strFile)) strFile = strFile + \"|\" + HttpUtility.UrlEncode(fileName) + \",\" + fileUrl; else strFile = HttpUtility.UrlEncode(fileName) + \",\" + fileUrl; fileCookie.Value = strFile; fileCookie.Expires = DateTime.Now.AddDays(1); fileCookie.HttpOnly = true; context.Response.AppendCookie(fileCookie); } context.Response.Write(\"1\"); context.Response.End(); }
5.所有代码敲完OK,可以收获成果了:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持phpstudy。
本文地址:https://www.stayed.cn/item/22677
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我