ASP.NET怎么上传文件到数据库(2)
点击按钮处理代码
| 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(); } } } |
总结
以上我们提到的方法,适合所有类型的文件,对以上代码作适当修改,我们就可以建立一个完全基于数据库的文件管理系统。
Tag: 上传
文章整理:iocblog
版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。