教你如何實現c#檔案上傳下載功能
uGet 安裝SqlSugar
Model檔案下新建 DbContext 類
public class DbContext { public DbContext() { Db = new SqlSugarClient(new ConnectionConfig() { ConnectionString = "server=localhost;uid=root;pwd=woshishui;database=test", DbType = DbType.MySql, InitKeyType = InitKeyType.Attribute,//從特性讀取主鍵和自增列資訊 IsAutoCloseConnection = true,//開啟自動釋放模式和EF原理一樣我就不多解釋了 }); //調式程式碼 用來列印SQL Db.Aop.OnLogExecuting = (sql, pars) => { Console.WriteLine(sql + "rn" + Db.Utilities.SerializeObject(pars.ToDictionary(it => it.ParameterName, it => it.Value))); Console.WriteLine(); }; } //注意:不能寫成靜態的,不能寫成靜態的 public SqlSugarClient Db;//用來處理事務多表查詢和複雜的操作 public SimpleClientuploadingdb { get { return new SimpleClient(Db); } }//用來處理Student表的常用操作 }
uploading實體類
[SugarTable("uploading")] public class uploading { //指定主鍵和自增列,當然資料庫中也要設定主鍵和自增列才會有效 [SugarColumn(IsPrimaryKey = true, IsIdentity = true)] public int id { get; set; } public string name { get; set; } public string path { get; set; } }
UploadingManager
class UploadingManager : DbContext { public ListQuery() { try { Listdata = Db.Queryable() .Select(f => new uploading { name = f.name, path = f.path }) .ToList(); return data; } catch (Exception e) { Console.WriteLine(e); throw; } } public ListGetName(string name) { Listdata = Db.Queryable() .Where(w=>w.name== name) .Select(f => f.path) .ToList(); return data; } }
窗體載入
讀取到資料庫欄位name並賦值
private void Form1_Load(object sender, EventArgs e) { Listdata = uploading.Query(); foreach (var data1 in data) { comboBox1.Items.Add(data1.name); } comboBox1.SelectedIndex = 0; }
comboBox事件觸發條件查詢到上傳的path
private void comboBox1_SelectedIndexChanged(object sender, EventArgs e) { Listdata = uploading.GetName(comboBox1.Text); for (int i = 0; i < data.Count; i++) { textBox1.Text = data[0]; } }
上傳事件觸發
private void Button1_Click(object sender, EventArgs e) { string path = textBox1.Text; CopyDirs(textBox3.Text, path); }
.
private void CopyDirs(string srcPath, string aimPath) { try { // 檢查目標目錄是否以目錄分割字元結束如果不是則新增 if (aimPath[aimPath.Length - 1] != System.IO.Path.DirectorySeparatorChar) { aimPath += System.IO.Path.DirectorySeparatorChar; } // 判斷目標目錄是否存在如果不存在則新建 if (!System.IO.Directory.Exists(aimPath)) { System.IO.Directory.CreateDirectory(aimPath); } // 得到源目錄的檔案列表,該裡面是包含檔案以及目錄路徑的一個陣列 // 如果你指向copy目標檔案下面的檔案而不包含目錄請使用下面的方法 // string[] fileList = Directory.GetFiles(srcPath); string[] fileList = System.IO.Directory.GetFileSystemEntries(srcPath); // 遍歷所有的檔案和目錄 foreach (string file in fileList) { // 先當作目錄處理如果存在這個目錄就遞迴Copy該目錄下面的檔案 if (System.IO.Directory.Exists(file)) { CopyDir(file, aimPath + System.IO.Path.GetFileName(file)); DisplaylistboxMsg("上傳成功"); } // 否則直接Copy檔案 else { System.IO.File.Copy(file, aimPath + System.IO.Path.GetFileName(file), true); DisplaylistboxMsg("上傳成功"); } } } catch (Exception e) { DisplaylistboxMsg("上傳失敗" + e.Message); } }
下載事件觸發
private void Button2_Click(object sender, EventArgs e) { CopyDir(@"\\10.55.2.3\mech_production_line_sharing\Test\" + textBox2.Text, textBox4.Text); } private void CopyDir(string srcPath, string aimPath) { // 檢查目標目錄是否以目錄分割字元結束如果不是則新增 if (aimPath[aimPath.Length - 1] != System.IO.Path.DirectorySeparatorChar) { aimPath += System.IO.Path.DirectorySeparatorChar; } // 判斷目標目錄是否存在如果不存在則新建 if (!System.IO.Directory.Exists(aimPath)) { System.IO.Directory.CreateDirectory(aimPath); } // 得到源目錄的檔案列表,該裡面是包含檔案以及目錄路徑的一個陣列 // 如果你指向copy目標檔案下面的檔案而不包含目錄請使用下面的方法 // string[] fileList = Directory.GetFiles(srcPath); string[] fileList = System.IO.Directory.GetFileSystemEntries(srcPath); // 遍歷所有的檔案和目錄 foreach (string file in fileList) { // 先當作目錄處理如果存在這個目錄就遞迴Copy該目錄下面的檔案 if (System.IO.Directory.Exists(file)) { CopyDir(file, aimPath + System.IO.Path.GetFileName(file)); DisplaylistboxMsg("下載成功"); } // 否則直接Copy檔案 else { System.IO.File.Copy(file, aimPath + System.IO.Path.GetFileName(file), true); DisplaylistboxMsg("下載成功"); } } }
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69901823/viewspace-2840937/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Feign實現檔案上傳下載
- SpringMVC實現檔案上傳&下載(2)SpringMVC
- 前端實現檔案下載和拖拽上傳前端
- Flutter 實現檔案下載功能Flutter
- Java實現檔案下載功能Java
- React中使用fetch實現檔案上傳下載React
- vue實現Excel檔案的上傳與下載VueExcel
- JavaWeb之實現檔案上傳與下載工具JavaWeb
- JavaWeb之實現檔案上傳與下載元件JavaWeb元件
- JavaWeb之實現檔案上傳與下載示例JavaWeb
- 基於SpringWeb MultipartFile檔案上傳、下載功能SpringWeb
- 檔案上傳下載
- .net web core 如何編碼實現檔案上傳功能Web
- 使用Vue+go實現前後端檔案的上傳下載,csv檔案上傳下載可直接照搬VueGo後端
- JavaWeb之實現檔案上傳與下載外掛JavaWeb
- JavaWeb之實現檔案上傳與下載原始碼JavaWeb原始碼
- JavaWeb之實現檔案上傳與下載例項JavaWeb
- 自定義檔案上傳功能實現方法
- 【node】檔案上傳功能簡易實現
- SpringBoot實現檔案上傳功能詳解Spring Boot
- 使用Spring Boot實現檔案上傳功能Spring Boot
- JAVA檔案上傳下載Java
- springboot 檔案上傳下載Spring Boot
- 檔案上傳與下載
- Spring 對檔案上傳下載的支援(Spring boot實現)Spring Boot
- JavaWeb之實現檔案上傳與下載控制元件JavaWeb控制元件
- Java檔案上傳如何實現呢?Java
- springCloud 微服務通過minio實現檔案上傳和檔案下載介面SpringGCCloud微服務
- C#如何使用HttpClient對大檔案進行斷點上傳和下載C#HTTPclient斷點
- 檔案的上傳與下載
- 使用SecureCRT上傳下載檔案Securecrt
- minio檔案上傳與下載
- SpringMVC檔案上傳下載(單檔案、多檔案)SpringMVC
- 【轉】大檔案上傳原理及C#實現方案C#
- Linux如何實現斷點續傳檔案功能?Linux斷點
- Netty接收HTTP檔案上傳及檔案下載NettyHTTP
- spring cloud feign 檔案上傳和檔案下載SpringCloud
- 實現簡單的csv檔案上傳和bootstrap表格的下載boot