欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ASP.NET保存PDF、Word和Excel文件到數(shù)據(jù)庫

 更新時間:2017年01月24日 17:16:40   作者:Yesi  
這篇文章主要為大家詳細介紹了ASP.NET保存PDF、Word和Excel文件到數(shù)據(jù)庫的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下

在項目中,有時候我們很需要把PDF、Word和Excel文檔等等上傳到數(shù)據(jù)庫,以便日后使用。今天這篇文章向大家講解如何將這些文件保存到數(shù)據(jù)庫的。

詳細步驟

第一步:打開數(shù)據(jù)庫,單擊新建查詢,創(chuàng)建一個名稱為Documents的表:

代碼如下:

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 
)

這個表包含了這些數(shù)據(jù):

SNo序列號

Name_File文件名

DisplayName 文件顯示的名稱

Extension文件的擴展名

ContentType文件種類

FileData文件二進制格式

FileSize文件大小

UploadDate文件導入時間

第二步:打開Visual Studio,新建一個空網(wǎng)站,命名為“FilesToBinary”

第三步:再添加一個新頁面,命名為“Conversion.aspx”

在這個頁面我們需要添加TextBox ,F(xiàn)ileUpload ,Button這三個控件。

設(shè)計界面如圖:

當然你也可以在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編寫代碼,將文件轉(zhuǎn)換為二進制流,點擊Button后文件便可存到數(shù)據(jù)庫中。

代碼如下:

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)
    { 
     //表里插入數(shù)據(jù)
     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("數(shù)據(jù)已添加"); 
     } 
 
    } 
    else 
    { Response.Write("文件大小無效"); return; } 
   } 
   else 
   {
    Response.Write("無效文件"); return; 
   } 
  } 
}

運行結(jié)果如圖:

這時瀏覽文件夾,就可以添加我們的文件了。點擊導入,成功添加。

如果選擇了不符合規(guī)則的文件后,則會顯示:

返回數(shù)據(jù)庫,這時PDF、Word 和Excel文件已經(jīng)成功添加到數(shù)據(jù)庫啦。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 設(shè)置默認Ajax操作cache and error

    設(shè)置默認Ajax操作cache and error

    設(shè)置默認Ajax操作cache and error,需要的朋友可以參考一下
    2013-02-02
  • jquery中如何獲得服務(wù)器控件實現(xiàn)思路

    jquery中如何獲得服務(wù)器控件實現(xiàn)思路

    jquery中如何獲得服務(wù)器控件,很多新手朋友對此比較陌生,接下來為您介紹解決方法,感興趣的朋友可以了解下哦
    2013-01-01
  • asp.net驗證碼的簡單制作

    asp.net驗證碼的簡單制作

    當用戶進行注冊、登陸的時候都會遇到輸入驗證碼的情況,那驗證碼到底是怎么制作的,下面就為大家講解如何使用ASP.NET制作簡單的驗證碼,感興趣的朋友可以參考一下
    2015-09-09
  • .NET Core中本地化機制的深入講解

    .NET Core中本地化機制的深入講解

    這篇文章主要給大家介紹了關(guān)于.NET Core中本地化機制的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-10-10
  • ASP.NET WebAPI導入CSV

    ASP.NET WebAPI導入CSV

    這篇文章介紹了ASP.NET WebAPI導入CSV的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-05-05
  • Asp.net MVC中獲取控制器的名稱的方法

    Asp.net MVC中獲取控制器的名稱的方法

    這篇文章主要介紹了Asp.net MVC中獲取控制器的名稱的方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-10-10
  • Asp.net頁面中調(diào)用soapheader進行驗證的操作步驟

    Asp.net頁面中調(diào)用soapheader進行驗證的操作步驟

    這篇文章主要介紹了Asp.net頁面中調(diào)用soapheader進行驗證的操作步驟,感興趣的小伙伴們可以參考一下
    2016-04-04
  • ASP.NET MVC實現(xiàn)橫向展示購物車

    ASP.NET MVC實現(xiàn)橫向展示購物車

    這篇文章介紹了ASP.NET MVC實現(xiàn)橫向展示購物車的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-09-09
  • asp.net注冊Javascript的方法

    asp.net注冊Javascript的方法

    今天在cnblogs上看到有關(guān)注冊Javascript,主要是用到了ClientScript的三個方法。
    2008-07-07
  • 淺析GridView中顯示時間日期格式的問題

    淺析GridView中顯示時間日期格式的問題

    下面小編就為大家?guī)硪黄獪\析GridView中顯示時間日期格式的問題。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-05-05

最新評論