软件编程
位置:首页>> 软件编程>> C#编程>> c# 实现文件上传下载功能的实例代码

c# 实现文件上传下载功能的实例代码

作者:少年。  发布时间:2021-12-10 15:00:30 

标签:c#,文件,上传,下载

NuGet 安装SqlSugar

1.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 + "\r\n" +
              Db.Utilities.SerializeObject(pars.ToDictionary(it => it.ParameterName, it => it.Value)));
     Console.WriteLine();
   };

}
 //注意:不能写成静态的,不能写成静态的
 public SqlSugarClient Db;//用来处理事务多表查询和复杂的操作
 public SimpleClient<uploading> uploadingdb { get { return new SimpleClient<uploading>(Db); } }//用来处理Student表的常用操作
}

2.建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; }
}

3.Manager文件下建UploadingManager


class UploadingManager : DbContext
 {
   public List<uploading> Query()
   {
     try
     {
       List<uploading> data = Db.Queryable<uploading>()
         .Select(f => new uploading
         {
           name = f.name,
           path = f.path
         })
         .ToList();
       return data;
     }
     catch (Exception e)
     {
       Console.WriteLine(e);
       throw;
     }
 }

public List&lt;string&gt; GetName(string name)
 {
   List&lt;string&gt; data = Db.Queryable&lt;uploading&gt;()
     .Where(w=&gt;w.name== name)
     .Select(f =&gt; f.path)
     .ToList();
   return data;

}
}

窗体加载Form1_Load

1.读取到数据库字段name并赋值


private void Form1_Load(object sender, EventArgs e)
   {
     List<uploading> data = uploading.Query();
     foreach (var data1 in data)
     {
       comboBox1.Items.Add(data1.name);
     }
     comboBox1.SelectedIndex = 0;
 }

2.comboBox事件触发条件查询到上传的path


private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
   {
     List<string> data = uploading.GetName(comboBox1.Text);
   for (int i = 0; i &lt; data.Count; i++)
   {
     textBox1.Text = data[0];
   }
 }

3.上传事件触发


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(&quot;上传成功&quot;);
       }
       // 否则直接Copy文件
       else
       {
         System.IO.File.Copy(file, aimPath + System.IO.Path.GetFileName(file), true);
         DisplaylistboxMsg(&quot;上传成功&quot;);
       }
     }
   }
   catch (Exception e)
   {
     DisplaylistboxMsg(&quot;上传失败&quot; + e.Message);
   }
 }

4.下载事件触发


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(&quot;下载成功&quot;);
     }
     // 否则直接Copy文件
     else
     {
       System.IO.File.Copy(file, aimPath + System.IO.Path.GetFileName(file), true);
       DisplaylistboxMsg(&quot;下载成功&quot;);
     }
   }
 }

来源:https://www.cnblogs.com/ouyangkai/p/12484260.html

0
投稿

猜你喜欢

手机版 软件编程 asp之家 www.aspxhome.com