校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁(yè) > 知識(shí)庫(kù) > asp.net上傳文件到數(shù)據(jù)庫(kù)的解決方案

asp.net上傳文件到數(shù)據(jù)庫(kù)的解決方案

熱門標(biāo)簽:安陸市地圖標(biāo)注app 辦公用地圖標(biāo)注網(wǎng)點(diǎn)怎么操作 西寧電銷外呼系統(tǒng)公司 上海市三維地圖標(biāo)注 聊城智能電銷機(jī)器人電話 寧德防封版電銷卡 云南外呼系統(tǒng)代理 海東防封電銷卡 南昌自動(dòng)外呼系統(tǒng)線路

現(xiàn)在,我們來看存放文件的數(shù)據(jù)庫(kù)表結(jié)構(gòu),這里,我們給出建立表的標(biāo)準(zhǔn)SQL語句:

CREATE TABLE tblBooksUpload
(
 DocID int NOT NULL IDENTITY Primary Key ,
 DocTitle varchar (200) ,
 Doc image,
 DocType varchar (50) ,
 Entrydate datetime Default GetDate()
)

以上的語句中,我們看到數(shù)據(jù)表tblBooksUpload包含五個(gè)字段:

·字段DocID是表的關(guān)鍵字段,數(shù)據(jù)記錄編號(hào);

·字段DocTitle是用來簡(jiǎn)單說明上傳文件的,如果上傳文本文件,我們一般將其設(shè)置為文件標(biāo)題,圖像、程序等,就設(shè)置為圖像、程序的簡(jiǎn)單介紹;

·字段Doc是用來存放我們上傳的文件的字段,注意,這里將Doc字段的設(shè)置為Image類別;

·字段DocType用來保存我們上傳文件的類型,可能我們奇怪為什么要這個(gè)字段呢?其實(shí),這個(gè)字段是很重要的,在用戶從數(shù)據(jù)庫(kù)取得數(shù)據(jù)的時(shí)候,這個(gè)字段將用來指定數(shù)據(jù)字段Doc中數(shù)據(jù)的類別,然后,瀏覽器根據(jù)這個(gè)字段來決定呈現(xiàn)給用戶的數(shù)據(jù);

·字段DateTime是一個(gè)時(shí)間字段,我們可以看到該字段的值取自服務(wù)器的當(dāng)前日期。

下面是插入數(shù)據(jù)的存儲(chǔ)過程,我們來看具體代碼:

CREATE PROCEDURE uSP_BooksUploadFile
@Title varchar(200),
@Doc image,
@DocType varchar(4)

AS

INSERT tblBooksUpload(DocTitle,Doc,DocType)
VALUES (@Title,@Doc,@DocType)

GO

現(xiàn)在,我們先從文字上了解一下上傳文件到數(shù)據(jù)庫(kù)的具體步驟,再?gòu)拇a上來實(shí)現(xiàn):
首先,從客戶端取得上傳的文件,然后,我們將它放入數(shù)據(jù)流;
第二,服務(wù)器端讀取數(shù)據(jù)流,然后將其保存到緩存;
第三,將緩存數(shù)據(jù)保存到數(shù)據(jù)庫(kù);

現(xiàn)在,我們一步步來看怎樣在程序中實(shí)現(xiàn)這些功能。
第一步
當(dāng)然,首先我們要實(shí)現(xiàn)用戶在瀏覽器端自由選擇文件,然后上傳,這里用戶選擇文件,當(dāng)然是要求標(biāo)準(zhǔn)的Windows方式,所以,我們?cè)谶@里使用Form的File文件組件來給用戶選擇文件。注意,因?yàn)樯蟼魑募裕贔orm的屬性設(shè)置的時(shí)候,我們應(yīng)該設(shè)置為:multipart/form-data,這樣,才可以正確上傳文件。下面是上傳頁(yè)面的主要代碼:

<form id="frmUpload" method="post" enctype="multipart/form-data" runat="server">
<span>Title</span><br>
<asp:textbox id="txtTitle" runat="server" EnableViewState="False"></asp:textbox>
<asp:requiredfieldvalidator id="valrTitle" runat="server" ErrorMessage="* 
Required" ControlToValidate="txtTitle">* Required</asp:requiredfieldvalidator>

<br>
<br>

<span>Docutment to Upload</span><br>
<input id="txtFileContents" type="file" runat="server" NAME="txtFileContents">
<br>
<br>

<asp:button id="btnSubmit" Text="Submit" Runat="server"></asp:button>
</form>

第二步

我們可以將上傳的文件通過數(shù)據(jù)流保存到緩存,緩存的大小和文件的具體大小相同,我們可以使用以下的代碼來取得文件的具體大小:

int intDocLen = txtFileContents.PostedFile.ContentLength;

然后,我們可以設(shè)置緩存的具體大小了:  

byte[] Docbuffer = new byte[intDoclen];

這樣設(shè)置以后,我們可以將上傳文件的內(nèi)容保存到緩存中:  

Stream objStream;
objStream = txtFileContents.PostedFile.InputStream;
objStream.Read(Docbuffer,0,intDocLen);

在以上代碼中,讀取緩存的時(shí)候,從緩存的0位置開始,直到整個(gè)文件的長(zhǎng)度,其實(shí),這就是整個(gè)文件或者整個(gè)緩存的大小。

第三步

現(xiàn)在我們需要做的就是將緩存數(shù)據(jù)保存到數(shù)據(jù)庫(kù),我們已經(jīng)直到數(shù)據(jù)表結(jié)構(gòu),這樣,我們通過編寫簡(jiǎn)單的SQL語句就可以實(shí)現(xiàn)這個(gè)功能。在上面的內(nèi)容中,我們編寫了一個(gè)存儲(chǔ)過程,在程序中,我們只要建立SqlCommand對(duì)象并且將這個(gè)存儲(chǔ)過程傳遞給它,并設(shè)置“@Doc”參數(shù)取得緩存數(shù)據(jù)就可以了:

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;

點(diǎn)擊按鈕處理代碼

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

 //用于保存文件大小

 int intDocLen;

 //Stream用于讀取上傳數(shù)據(jù)

 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;
   }
   //上傳文件具體內(nèi)容
   intDocLen = txtFileContents.PostedFile.ContentLength;
   byte[] Docbuffer = new byte[intDocLen];
   objStream = txtFileContents.PostedFile.InputStream;

   //文件保存到緩存 
   //緩存將保存到數(shù)據(jù)庫(kù)

   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();
  }
 }
}

總結(jié)
以上我們提到的方法,適合所有類型的文件,對(duì)以上代碼作適當(dāng)修改,我們就可以建立一個(gè)完全基于數(shù)據(jù)庫(kù)的文件管理系統(tǒng)。

您可能感興趣的文章:
  • Asp.Net修改上傳文件大小限制方法
  • Asp.net MVC中使用JQuery插件ajaxFileUpload上傳文件
  • ASP.NET插件uploadify批量上傳文件完整使用教程
  • asp.net中MVC借助Iframe實(shí)現(xiàn)無刷新上傳文件實(shí)例
  • asp.net fileupload控件上傳文件與多文件上傳
  • Asp.Net的FileUpload類實(shí)現(xiàn)上傳文件實(shí)例
  • Asp.Net模擬表單提交數(shù)據(jù)和上傳文件的實(shí)現(xiàn)代碼
  • asp.net實(shí)現(xiàn)上傳文件顯示本地絕對(duì)路徑的實(shí)例代碼
  • 如何限制asp.net中上傳文件的大小的代碼
  • asp.net 模擬提交有文件上傳的表單(通過http模擬上傳文件)
  • 解決.net項(xiàng)目中上傳的圖片或者文件太大無法上傳問題

標(biāo)簽:崇左 衢州 青海 南寧 汕尾 贛州 洛陽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《asp.net上傳文件到數(shù)據(jù)庫(kù)的解決方案》,本文關(guān)鍵詞  asp.net,上傳,文件,到,數(shù)據(jù)庫(kù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《asp.net上傳文件到數(shù)據(jù)庫(kù)的解決方案》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于asp.net上傳文件到數(shù)據(jù)庫(kù)的解決方案的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    日韩欧美aaaaaa| 久久九九99视频| 国产成人av在线影院| 日韩伦理av电影| 精品美女在线观看| 欧洲一区在线电影| 国产精品亚洲成人| 日本不卡视频一二三区| |精品福利一区二区三区| 日韩亚洲欧美中文三级| 色呦呦国产精品| 国产一区二区调教| 青青国产91久久久久久| 一区二区三区免费| 久久久久久久久久久99999| 欧美日韩二区三区| 99久久99久久精品国产片果冻 | 欧美精品三级在线观看| 波多野结衣精品在线| 久久激情综合网| 亚洲成av人在线观看| 亚洲视频一二区| 亚洲欧美自拍偷拍| 久久久精品影视| 精品第一国产综合精品aⅴ| 欧美精品丝袜中出| 欧美视频在线一区二区三区| av一区二区三区四区| 丰满白嫩尤物一区二区| 经典一区二区三区| 麻豆国产欧美一区二区三区| 爽好多水快深点欧美视频| 亚洲在线视频网站| 一区二区三区中文字幕精品精品| √…a在线天堂一区| 国产精品女人毛片| 欧美国产日韩一二三区| 国产清纯白嫩初高生在线观看91| 日韩女优制服丝袜电影| 日韩欧美成人激情| 精品乱码亚洲一区二区不卡| 欧美va亚洲va香蕉在线| 日韩美女视频在线| 日韩精品影音先锋| 久久综合色综合88| 久久久久久久久久久久久女国产乱 | 久久99久久久久| 麻豆专区一区二区三区四区五区| 婷婷开心激情综合| 日本少妇一区二区| 免费在线成人网| 久久国产精品色| 国产精品亚洲第一| av在线综合网| 日本道色综合久久| 欧美日韩电影一区| 日韩免费一区二区三区在线播放| 2017欧美狠狠色| 国产精品视频观看| 日韩欧美在线影院| 欧美性videosxxxxx| 国产福利一区二区三区视频在线 | 亚洲第一福利视频在线| 国产精品久久久久久妇女6080| 成人av动漫在线| 91免费看`日韩一区二区| www激情久久| 亚洲精品水蜜桃| 免播放器亚洲一区| 亚洲精选在线视频| 国产嫩草影院久久久久| 在线观看成人小视频| 成人久久视频在线观看| 精品一区二区在线免费观看| 亚洲欧美日韩国产成人精品影院| 国产丝袜欧美中文另类| 亚洲在线成人精品| 蜜桃久久精品一区二区| 成人午夜免费电影| 欧美午夜一区二区三区| 正在播放亚洲一区| 亚洲一二三四区不卡| 亚洲成av人在线观看| 精品一区二区在线视频| av网站一区二区三区| 91在线视频网址| 成人av先锋影音| 99re这里都是精品| 日韩欧美在线不卡| 亚洲国产成人一区二区三区| 亚洲视频精选在线| 亚洲成人av一区| 久久国产生活片100| 久久99热这里只有精品| 国产精品自在欧美一区| 国产成人精品aa毛片| 91小视频在线免费看| 色偷偷成人一区二区三区91| 在线综合视频播放| 日韩免费观看2025年上映的电影 | 一区二区三区在线免费播放| 午夜视频在线观看一区二区三区 | 91网站黄www| 日韩限制级电影在线观看| 中文字幕一区二区三区不卡| 韩国一区二区三区| 日韩亚洲欧美成人一区| 欧美肥妇毛茸茸| 日韩视频中午一区| 久久亚洲春色中文字幕久久久| 久久午夜羞羞影院免费观看| 国产精品中文字幕欧美| 亚洲乱码一区二区三区在线观看| 亚洲国产综合在线| 成人免费的视频| 精品久久久久一区| 天堂一区二区在线免费观看| 91在线视频在线| 中文字幕的久久| 国产自产视频一区二区三区| 欧美精品亚洲一区二区在线播放| 亚洲乱码国产乱码精品精小说| 国产精品123| 26uuu久久天堂性欧美| 五月综合激情婷婷六月色窝| 色婷婷久久综合| 亚洲日本在线看| jlzzjlzz亚洲女人18| 久久无码av三级| 久久福利视频一区二区| 日韩午夜在线观看| 日本不卡在线视频| 欧美日韩国产电影| 午夜伦理一区二区| 欧美日韩一区在线| 亚洲二区在线观看| 欧洲另类一二三四区| 亚洲美女淫视频| 91国产免费看| 亚洲小说春色综合另类电影| 91成人在线免费观看| 一区二区三区美女视频| 欧美性一区二区| 亚洲影视资源网| 正在播放亚洲一区| 久久国产综合精品| 久久综合狠狠综合久久激情| 国产一二精品视频| 国产欧美一二三区| 色综合视频一区二区三区高清| 亚洲视频一区二区免费在线观看| 91视频91自| 亚洲二区在线观看| 精品日韩欧美一区二区| 国产成人精品网址| 亚洲女厕所小便bbb| 欧美日韩三级在线| 美女高潮久久久| 国产亚洲短视频| 色老综合老女人久久久| 亚洲r级在线视频| 欧美mv和日韩mv的网站| 国产成人午夜片在线观看高清观看| 中文字幕国产一区二区| 91成人在线观看喷潮| 美女国产一区二区三区| 久久精品免费在线观看| 91亚洲精品久久久蜜桃| 亚洲伊人伊色伊影伊综合网| 精品人在线二区三区| thepron国产精品| 天堂va蜜桃一区二区三区漫画版| 欧美电视剧免费全集观看| 成人视屏免费看| 午夜激情综合网| 国产亚洲欧美中文| 欧洲一区二区三区免费视频| 精品午夜久久福利影院| 中文字幕亚洲精品在线观看| 91精品国产色综合久久| 国产91精品免费| 五月天精品一区二区三区| 欧美激情一区二区| 欧美午夜电影在线播放| 国产91丝袜在线观看| 五月天中文字幕一区二区| 国产精品日日摸夜夜摸av| 欧美美女bb生活片| 99在线视频精品| 捆绑紧缚一区二区三区视频| 有码一区二区三区| 国产三级精品三级| 7777女厕盗摄久久久| 91免费看`日韩一区二区| 国产自产v一区二区三区c| 亚洲电影视频在线| 国产精品不卡视频| 久久麻豆一区二区| 欧美一级夜夜爽| 欧美午夜精品久久久久久孕妇|