/// <summary>上傳文件方法 /// 返回文件名 /// </summary> /// <param name="myFileUpload">上傳控件ID</param> /// <param name="allowExtensions">容許上傳的擴展文件名類型,如:string[] allowExtensions = { ".doc", ".xls", ".ppt", ".jpg", ".gif" };</param> /// <param name="maxLength">容許上傳的最大大小,以M爲單位</param> /// <param name="savePath">保存文件的目錄,注意是絕對路徑,如:Server.MapPath("~/upload/");</param> public string Upload(FileUpload myFileUpload, string[] allowExtensions, int maxLength, string savePath) { // 文件格式是否容許上傳 bool fileAllow = false; //檢查是否有文件案 if (myFileUpload.HasFile) { // 檢查文件大小, ContentLength獲取的是字節,轉成M的時候要除以2次1024 if (myFileUpload.PostedFile.ContentLength / 1024 / 1024 >= maxLength) { throw new Exception("只能上傳小於" + maxLength + "M的文件!"); } //取得上傳文件之擴展文件名,並轉換成小寫字母 string fileExtension = System.IO.Path.GetExtension(myFileUpload.FileName).ToLower(); string tmp = ""; // 存儲容許上傳的文件後綴名 //檢查擴展文件名是否符合限定類型 for (int i = 0; i < allowExtensions.Length; i++) { tmp += i == allowExtensions.Length - 1 ? allowExtensions[i] : allowExtensions[i] + ","; if (fileExtension == allowExtensions[i]) { fileAllow = true; } } if (fileAllow) { try { string datedir = DateTime.Now.ToString("yyyyMMdd"); if (!Directory.Exists(savePath + datedir)) { Directory.CreateDirectory(savePath + datedir); } // string saveName = Guid.NewGuid() + fileExtension; string saveName = Guid.NewGuid() + fileExtension; string path = savePath + datedir + "\\" + saveName; //存儲文件到文件夾 myFileUpload.SaveAs(path); return "FileUploadUrl" + "\\" + datedir + "\\" + saveName; } catch (Exception ex) { throw new Exception(ex.Message); } } else { return "文件格式不符"; // throw new Exception("文件格式不符,能夠上傳的文件格式爲:" + tmp); } } else { throw new Exception("請選擇要上傳的文件!"); } }