ASP.NET怎么上传文件到数据库(2)

分类: asp.net   出处:iocblog整理  更新时间:2009-06-08   添加到收藏  

  点击按钮处理代码


private void btnSubmit_Click(object sender, System.EventArgs e)
{
 string strDocExt;
 //strDocType用于保存上传文件的类型
 string strDocType;

 //用于保存文件大小

 int intDocLen;

 //Stream用于读取上传数据

 Stream objStream;
 SqlConnection BooksConn;
 SqlCommand cmdUploadDoc;

 if(IsValid)
 {
  if(txtFileContents.PostedFile != null)
  {
   //文件类型
   strDocExt = CString.Right(txtFileContents.PostedFile.FileName,4).ToLower();
   switch(strDocExt)
   {
    case ".doc":
     strDocType = "doc";
     break;
    case ".ppt":
     strDocType = "ppt";
     break;
    case ".htm":
     strDocType = "htm";
     break;
    case ".html":
     strDocType = "htm";
     break;
    case ".jpg":
     strDocType = "jpg";
     break;
    case ".gif":
     strDocType = "gif";
     break;
    default:
     strDocType = "txt";
     break;
   }
   //上传文件具体内容
   intDocLen = txtFileContents.PostedFile.ContentLength;
   byte[] Docbuffer = new byte[intDocLen];
   objStream = txtFileContents.PostedFile.InputStream;

   //文件保存到缓存
   //缓存将保存到数据库

   objStream.Read(Docbuffer ,0,intDocLen);
   BooksConn = new SqlConnection("Server=Server;UID=sa;Database=Books");
   cmdUploadDoc = new SqlCommand("uSP_BooksUploadFile",BooksConn);
   cmdUploadDoc.CommandType = CommandType.StoredProcedure;
   cmdUploadDoc.Parameters.Add("@Title ",SqlDbType.VarChar,200);
   cmdUploadDoc.Parameters.Add("@Doc",SqlDbType.Image);
   cmdUploadDoc.Parameters.Add("@DocType",SqlDbType.VarChar,4);
   cmdUploadDoc.Parameters[0].Value = txtTitle.Text;
   cmdUploadDoc.Parameters[1].Value = Docbuffer ;
   cmdUploadDoc.Parameters[2].Value = strDocType;
   BooksConn.Open();
   cmdUploadDoc.ExecuteNonQuery();
   BooksConn.Close();
  }
 }
}

  总结

  以上我们提到的方法,适合所有类型的文件,对以上代码作适当修改,我们就可以建立一个完全基于数据库的文件管理系统。

上一页 [1] [2]


Tag: 上传



文章整理:iocblog
版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。