如何保存PDF、Word和Excel文件到數據庫中

在項目中,有時候咱們很須要把PDF、Word和Excel文檔等等上傳到數據庫,以便往後使用。今天這篇文章向你們講解如何將這些文件保存到數據庫的。sql

詳細步驟數據庫

第一步:打開數據庫,單擊新建查詢,建立一個名稱爲Documents的表:ide

代碼以下:網站

create table Documents  
(  
SNo int identity,  
Name_File varchar(100),  
DisplayName varchar(50),  
Extension varchar(10),  
ContentType varchar(200),  
FileData varbinary(max),  
FileSize bigint,  
UploadDate datetime  
)

這個表包含了這些數據:spa

SNo序列號設計

Name_File文件名code

DisplayName 文件顯示的名稱server

Extension文件的擴展名blog

ContentType文件種類文檔

FileData文件二進制格式

FileSize文件大小

UploadDate文件導入時間

第二步:打開Visual Studio,新建一個空網站,命名爲「FilesToBinary」

第三步:再添加一個新頁面,命名爲「Conversion.aspx」

在這個頁面咱們須要添加TextBox ,FileUpload ,Button這三個控件。

設計界面如圖:

固然你也能夠在Conversion.apsx文件直接輸入下列代碼:

顯示文件
    <asp:TextBox ID="txtfilename" runat="server">  
    </asp:TextBox>   
<br />  
  
選擇文件  
<asp:FileUpload ID="FileUpload1" runat="server" />  
<br />  
  
<asp:Button ID="Button1" runat="server"  
Text="導入" OnClick="Button1_Click" /> 

第四步:控件添加後,雙擊Button,在Conversion.apxs.cs文件添加如下命名空間。

using System;
using System.Web;
using System.Data.SqlClient;
using System.Data;
using System.IO;

而後在Button1_Click編寫代碼,將文件轉換爲二進制流,點擊Button後文件即可存到數據庫中。

代碼以下:

protected void Button1_Click(object sender, EventArgs e)
    {
         if (!FileUpload1.HasFile)  
        {  
            Response.Write("未選擇文件"); return;  
        }  
        else  
        {            
            string filename = Path.GetFileName(FileUpload1.PostedFile.FileName);  
            string extension = Path.GetExtension(filename);  
            string contentType = FileUpload1.PostedFile.ContentType;  
            HttpPostedFile file = FileUpload1.PostedFile;  
            byte[] document = new byte[file.ContentLength];  
            file.InputStream.Read(document, 0, file.ContentLength);  
  
         //驗證保存的文件擴展名是否爲pdf,doc,docx,xls.
         if ((extension == ".pdf") || (extension == ".doc") || (extension == ".docx") || (extension == ".xls"))
            {  
    //驗證文件的大小
                if (file.ContentLength <= 31457280)
                {  
                    //表裏插入數據
                    using (SqlConnection conn = new SqlConnection("Data Source=AFOD3-609221015;Initial Catalog=Personal;Integrated Security=True"))  
                    {
                        conn.Open();  
                        string sql = @"insert into Documents(Name_File,DisplayName,Extension,ContentType,FileData,FileSize,UploadDate) values(@Name_File,@DisplayName,@Extension,@ContentType,@FileData,@FileSize,getdate())";
                        SqlCommand cmd = new SqlCommand(sql, conn);  
                       
                        cmd.Parameters.Add("@Name_File", SqlDbType.VarChar);  
                        cmd.Parameters["@Name_File"].Value = filename;  
                        cmd.Parameters.Add("@DisplayName", SqlDbType.VarChar);  
                        cmd.Parameters["@DisplayName"].Value = txtfilename.Text.Trim();  
                        cmd.Parameters.Add("@Extension", SqlDbType.VarChar);  
                        cmd.Parameters["@Extension"].Value = extension;  
  
                        cmd.Parameters.Add("@ContentType", SqlDbType.VarChar);  
                        cmd.Parameters["@ContentType"].Value = contentType;  
  
                        cmd.Parameters.Add("@FileData", SqlDbType.VarBinary);  
                        cmd.Parameters["@FileData"].Value = document;  
  
                        cmd.Parameters.Add("@FileSize", SqlDbType.BigInt);  
                        cmd.Parameters["@FileSize"].Value = document.Length;  
                        cmd.ExecuteNonQuery();  
                        cmd.Dispose();  
                        conn.Close();  
                        Response.Write("數據已添加");  
                    }  
  
                }  
                else  
                { Response.Write("文件大小無效"); return; }  
            }  
            else  
            {
                Response.Write("無效文件"); return;  
            }  
        }  
}
View Code

運行結果如圖:

這時瀏覽文件夾,就能夠添加咱們的文件了。點擊導入,成功添加。

若是選擇了不符合規則的文件後,則會顯示:

返回數據庫,這時PDF、Word 和Excel文件已經成功添加到數據庫啦。

但願對你有幫助,謝謝瀏覽!

相關文章
相關標籤/搜索