C#上传附件,以及下载实现

通常情况下,我们会遇到各种上传附件的情况,以及上传后需要下载,文档格式各种各样,当然这个过程中也是报不同错误,还是一个原则,具体问题,具体分析:需求图:

上传代码实现:

 aspx代码:

 1 <asp:Panel ID="Panel5" runat="server">
 2                 <fieldset>
 3                     <legend>整体活动效果:</legend>
 4                     <nav class="navbar navbar-default" role="navigation">
 5                         <table cellspacing="0" class="table table-hover" border="0" style="border-collapse: collapse;">
 6                             <tbody>
 7                                 <tr>
 8                                     <td><strong>需求单名称</strong></td>
 9                                     <td colspan="2">
10                                         <strong>添加附件</strong>
11                                     </td>
12                                     <td>附件名称</td>
13                                 </tr>
14                                 <tr>
15                                     <td><asp:Literal ID="LtOrder" runat="server"></asp:Literal></td>
16                                     <td>
17                                       <asp:Button style="margin-right: -55px;" ID="btnImport" runat="server" Text="添加附件" class="btn btn-default" OnClick="btnImport_Click" /></td>
18                                     <td class="Up_file">
19                                         <asp:FileUpload ID="UpLoadTxt" runat="server" class="form-control" />
20                                     </td>
21                                     <td>
22                                         <asp:Literal ID="LAccessory" runat="server"></asp:Literal>
23                                     </td>
24                                 </tr>
25                             </tbody>
26                         </table>
27                     </nav>
28                 </fieldset>
29             </asp:Panel>

cs代码:

  1     #region///上传,文件名称添加数据库,文件保存相应路径
  2     /// <summary>
  3     /// 添加附件
  4     /// </summary>
  5     /// <param name="sender"></param>
  6     /// <param name="e"></param>
  7     protected void btnImport_Click(object sender, EventArgs e)
  8     {
  9         string res = "0";
 10         string fileName = UpLoadTxt.FileName;//获取要导入的文件名  
 11         if (fileName == null || fileName == "")
 12         {
 13             res = "2";
 14         }
 15         else
 16         {
 17             string savePath = Server.MapPath("~/UploadFiles/ChatLog/");
 18             FileOperatpr(fileName, savePath);
 19             string url = savePath + fileName;
 20             UpLoadTxt.SaveAs(url);
 21             SqlConnection conn = SqlHelperEx.ConnOpen("SPSDB");
 22             string ExtName = getFileExt(fileName).ToUpper();//获取上传文件名称
 23            // string ENDNmae = getFileEND(fileName).ToUpper(); //后缀名
 24             id = Request["id"];
 25             res = GetAccessory(conn, fileName, id);
 26             SqlHelperEx.ConnClose(conn);
 27         }
 28         if (res == "2")
 29         {
 30             Response.Write("<script>alert('没有要添加的文件,请选中文件后再操作!');window.location.href='SNSNeedingOrder_InfoListView.aspx?id=" + Request["id"] + "';</script>");
 31         }
 32         if (res == "0")
 33         {
 34             Response.Write("<script>alert('添加失败!');window.location.href='SNSNeedingOrder_InfoListView.aspx?id=" + Request["id"] + "';</script>");
 35         }
 36         if(res=="1") {
 37             Response.Write("<script>alert('添加成功!');window.location.href='SNSNeedingOrder_InfoListView.aspx?id=" + Request["id"] + "';</script>");
 38         }
 39         if (res == "3")
 40         {
 41             Response.Write("<script>alert('没有需求单,非法操作!');window.location.href='SNSNeedingOrder_InfoListView.aspx?id=" + Request["id"] + "';</script>");
 42         }
 43     }
 44     #region 辅助功能
 45     /// <summary>
 46     /// 获取上传文件的后缀名
 47     /// </summary>
 48     /// <param name="fileName"></param>
 49     /// <returns></returns>
 50     private string getFileEND(string fileName)
 51     {
 52         if (fileName.IndexOf(".") == -1)
 53             return "";
 54         string[] temp = fileName.Split('.');
 55         return temp[temp.Length - 1].ToLower();
 56     }
 57     /// <summary>
 58     /// //获取上传文件的名称
 59     /// </summary>
 60     /// <param name="fileName"></param>
 61     /// <returns></returns>
 62     private string getFileExt(string fileName)
 63     {
 64         if (fileName.IndexOf(".") == -1)
 65             return "";
 66         string file = "";
 67         string[] temp = fileName.Split(new[] { "." }, StringSplitOptions.RemoveEmptyEntries);
 68         file = temp[0].ToLower();
 69         return file.ToLower();
 70     }
 71 
 72 
 73     private void FileOperatpr(string fileName, string savePath)
 74     {
 75         if (!Directory.Exists(savePath))
 76         {
 77             Directory.CreateDirectory(savePath);
 78         }
 79         if (File.Exists(savePath + fileName))
 80         {
 81             File.Delete(savePath + fileName);
 82         }
 83     }
 84 
 85     #endregion
 86 
 87     /// <summary>
 88     /// 添加文件名
 89     /// </summary>
 90     /// <param name="conn"></param>
 91     /// <param name="filename"></param>
 92     /// <param name="id"></param>
 93     private string GetAccessory(SqlConnection conn, string filename, string id)
 94     {
 95         string res = "0";
 96         if (id == "0" || id == "" || id == null)
 97         {
 98             res = "3";
 99         }
100         else
101         {
102             if (filename == null || filename == "")
103             {
104                 res = "2";
105             }
106             else
107             {
108                 string strOrderID = id;
109                 string strFileName = filename;
110                 string strCreateUserId = Session["UserName"].ToString();
111                 StringBuilder strSql = new StringBuilder();
112                 // 生成SQL语句;
113                 strSql.AppendFormat("INSERT INTO BaseSNSAccessory(OrderID,FileName,CreateUserId) values(  {0}", Environment.NewLine);
114                 strSql.AppendFormat(" @OrderID,@FileName,@CreateUserId) {0}", Environment.NewLine);
115                 SqlParameter[] parameters = {
116                                             new SqlParameter("@OrderID", strOrderID),
117                                             new SqlParameter("@FileName", strFileName),
118                                             new SqlParameter("@CreateUserId", strCreateUserId),
119                                             };
120                 // 执行
121                 int result = SqlHelperEx.ExecuteNonQuery(strSql.ToString(), conn, parameters);
122                 // 返回
123                 SqlHelperEx.ConnClose(conn);
124                 if (result == 1)
125                 {
126                     res = "1";
127                 }
128                 else
129                 {
130                     res = "0";
131                 }
132             }
133         }
134         return res;
135     }
136     #endregion

下载实现:

 1 /// <summary>
 2     /// 获取附件
 3     /// </summary>
 4     /// <param name="conn"></param>
 5     /// <param name="id"></param>
 6     public void GetAccessory(SqlConnection conn, string id)
 7     {
 8         string strsql = "SELECT *,(SELECT OrderName FROM  Order_Info WHERE IsValid=1 AND id=bs.OrderID AND IsValid=1) AS OrderName FROM BaseSNSAccessory AS bs WHERE bs.IsValid=1 and bs.OrderID="+id+"  ORDER BY bs.id  DESC";
 9         DataTable dt = SqlHelperEx.GetDataTable(strsql, conn);
10         if (dt.Rows.Count == 0)
11         {
12             Ltlog.Text = "无数据";
13             return;
14         }
15         string fileName = "";
16         string str = "";
17         for (int i = 0; i < dt.Rows.Count; i++)
18         {
19             fileName = dt.Rows[i]["FileName"].ToString();
20             str += "<tr height=\"36\" bgcolor=\"#FFFFFF\">";
21             str += "<td>" + dt.Rows[i]["OrderName"].ToString() + "</td>";
22             str += "<td>  <a href='/EcBossWeb/UploadFiles/ChatLog/" + fileName + "' >点击下载:" + fileName + "</a></td>";
23             str += " </tr>";
24         }
25         LtOrdersory.Text = str.ToString();
26 
27         //string filePath = "";
28 
29         //FileStream fs = new FileStream(filePath, FileMode.Open); // 设置文件流,filePath为文件路径
30         //byte[] bytes = new byte[(int)fs.Length];
31         //fs.Read(bytes, 0, bytes.Length); // 读取
32         //fs.Close();
33         //Response.ClearContent(); // 清楚缓冲区所有内容
34         //Response.ClearHeaders(); // 清楚缓冲区所有头
35         //Response.ContentType = "application/octet-stream"; // 设置输出流的Http MIME类型
36         ////通知浏览器下载文件而不是打开
37         //Response.AddHeader("Content-Disposition", "attachment; filename=" + HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8)); //fileName为需要下载的文件名
38         //Response.BinaryWrite(bytes); // 写入输入流
39         //Response.Flush(); // 向客户端发送数据流
40         //Response.End();
41     }

 

转载于:https://www.cnblogs.com/hulxm/articles/4935580.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
检测指定目录是否存在, 检测指定文件是否存在, 如果存在则返回true, 获取指定目录中所有文件列表,获取指定目录中所有子目录列表, 取指定目录及子目录中所有文件列表, 指定目录的绝对路径,检测指定目录是否为空, 检测指定目录中是否存在指定的文件, 若要搜索子目录请使用重载方法., 检测指定目录中是否存在指定的文件, 创建目录, 删除目录, 创建文件, 移动文件(剪贴--粘贴), 复制文件, 根据时间得到目录名 / 格式:yyyyMMdd 或者 HHmmssff, 根据时间得到文件名HHmmssff, 根据时间获取指定路径的 后缀名的 的所有文件, 复制文件夹,检查文件, 如果文件不存在则创建, 删除指定文件夹对应其他文件夹里的文件, 从文件的绝对路径中获取文件名( 包含扩展名 ), 复制文件参考方法,页面中引用, 创建一个目录, 创建一个文件, 并将字节流写入文件, 获取文本文件的行数, 获取一个文件的长度, 单位为Byte, 获取文件大小并以B,KB,GB,TB, 获取指定目录中的子目录列表, 向文本文件写入内容, 向文本文件的尾部追加内容, 将现有文件的内容复制到新文件中, 将文件移动到指定目录, 从文件的绝对路径中获取文件名( 不包含扩展名 ), 从文件的绝对路径中获取扩展名 以上每一行为一个方法, 例子如下: #region 清空指定目录 /// /// 清空指定目录下所有文件及子目录,但该目录依然保存. /// /// 指定目录的绝对路径 public static void ClearDirectory(string directoryPath) { directoryPath = HttpContext.Current.Server.MapPath(directoryPath); if (IsExistDirectory(directoryPath)) { //删除目录中所有的文件 string[] fileNames = GetFileNames(directoryPath); for (int i = 0; i < fileNames.Length; i++) { DeleteFile(fileNames[i]); } //删除目录中所有的子目录 string[] directoryNames = GetDirectories(directoryPath); for (int i = 0; i < directoryNames.Length; i++) { DeleteDirectory(directoryNames[i]); } } } #endregion #region 清空文件内容 /// /// 清空文件内容 /// /// 文件的绝对路径 public static void ClearFile(string filePath) { //删除文件 File.Delete(filePath); //重新创建该文件 CreateFile(filePath); } #endregion #region 删除指定目录 /// /// 删除指定目录及其所有子目录 /// /// 指定

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值