四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

ASP.Net 圖片存入數(shù)據(jù)庫(kù)的實(shí)現(xiàn)代碼

在這篇文章中,我們將討論怎樣把圖片存入到Sql2000當(dāng)中。
在這篇文章中我們可以學(xué)到以下幾個(gè)方面的知識(shí):
1. 插入圖片的必要條件
2. 使用流對(duì)象
3. 查找準(zhǔn)備上傳的圖片的大小和類型
4.怎么使用InputStream方法?
插入圖片的必要條件
在我們開(kāi)始上傳之前,有兩件重要的事我們需要做:
#Form 標(biāo)記的 enctype 屬性應(yīng)該設(shè)置成 enctype="multipart/form-data"
# 需要一個(gè)<input type=file>表單來(lái)使用戶選擇他們要上傳的文件,同時(shí)我們需要導(dǎo)入 System.IO名稱空間來(lái)處理流對(duì)象
把以上三點(diǎn)應(yīng)用ASPx頁(yè)面。同時(shí)我們需要對(duì)SqlServer做以下的準(zhǔn)備。
# 需要至少含有一個(gè)圖片類型的字段的表
# 如果我們還有另外一個(gè)變字符類型的字段來(lái)存儲(chǔ)圖片類型,那樣會(huì)更好一些。
現(xiàn)在,我們準(zhǔn)備了一個(gè)Sql表(包含了一個(gè)image數(shù)據(jù)類型的字段),還有<input type=file>標(biāo)記。當(dāng)然我們還得準(zhǔn)備Submit按鈕,以便用戶在選擇了圖片以后提交。在這個(gè)按鈕的Onclick事件里,我們需要讀取選取圖片的內(nèi)容,然后把它存入到表里。那我們先來(lái)看看這個(gè)Onclick事件。
提交按鈕的Onclick事件的代碼:
以下為引用的內(nèi)容:
復(fù)制代碼 代碼如下:
Dim intImageSize As Int64
Dim strImageType As String
Dim ImageStream As Stream
' Gets the Size of the Image
intImageSize = PersonImage.PostedFile.ContentLength
' Gets the Image Type
strImageType = PersonImage.PostedFile.ContentType
' Reads the Image
ImageStream = PersonImage.PostedFile.InputStream
Dim ImageContent(intImageSize) As Byte
Dim intStatus As Integer
intStatus = ImageStream.Read(ImageContent, 0, intImageSize)
' Create Instance of Connection and Command Object
Dim myConnection As New SqlConnection(ConfigurationSettings.AppSettings("ConnectionString"))
Dim myCommand As New SqlCommand("sp_person_isp", myConnection)
' Mark the Command as a SPROC
myCommand.CommandType = CommandType.StoredProcedure
' Add Parameters to SPROC
Dim prmPersonImage As New SqlParameter("@PersonImage", SqlDbType.Image)
prmPersonImage.Value = ImageContent
myCommand.Parameters.Add(prmPersonImage)
Dim prmPersonImageType As New SqlParameter("@PersonImageType", SqlDbType.VarChar, 255)
prmPersonImageType.Value = strImageType
myCommand.Parameters.Add(prmPersonImageType)
Try
myConnection.Open()
myCommand.ExecuteNonQuery()
myConnection.Close()
Response.Write("New person successfully added!")
Catch SQLexc As SqlException
Response.Write("Insert Failed. Error Details are: " & SQLexc.ToString())
End Try

這是怎么工作的呢?
PersonImage是HTMLInputFile控件的對(duì)象。首先需要獲得圖片的大小,可以使用下面的代碼實(shí)現(xiàn):
intImageSize = PersonImage.PostedFile.ContentLength
然后返回圖片的類型使用ContenType屬性。最后,也是最重要的事就是取得Image Stream,這可以用以下代碼實(shí)現(xiàn):
ImageStream = PersonImage.PostedFile.InputStream
我們需要一個(gè)字節(jié)型數(shù)組來(lái)存儲(chǔ)image 內(nèi)容。讀取整個(gè)圖片可以使用Stream對(duì)象的Read方法來(lái)實(shí)現(xiàn)。Read(in byte[] buffer,int offset,int count)方法有三個(gè)參數(shù)。【關(guān)于Read方法的詳細(xì)可以參看.NET FrameWorkSDK】他們是:
buffer
字節(jié)數(shù)組。此方法返回時(shí),該緩沖區(qū)包含指定的字符數(shù)組,該數(shù)組的 offset 和 (offset + count) 之間的值由從當(dāng)前源中讀取的字節(jié)替換。
offset
buffer 中的從零開(kāi)始的字節(jié)偏移量,從此處開(kāi)始存儲(chǔ)從當(dāng)前流中讀取的數(shù)據(jù)。
count
要從當(dāng)前流中最多讀取的字節(jié)數(shù)。
這個(gè)Read方法用以下代碼實(shí)現(xiàn):
intStatus = ImageStream.Read(ImageContent, 0, intImageSize)
現(xiàn)在,我們已經(jīng)讀取了整個(gè)圖片的內(nèi)容,下一步,我們要把這些內(nèi)容存入到sql 表。我們將使用存儲(chǔ)過(guò)程來(lái)完成插入圖片類型和圖片內(nèi)容到sql 表。如果你瀏覽了上面的代碼,你將會(huì)發(fā)現(xiàn)我們使用了sqldbtype.image的數(shù)據(jù)類型(datatype)。Ok了,完成了這些,我們也就成功的把圖片存入到SqlServer中了。下面是我們編寫(xiě)的ASPx頁(yè)面。
圖片存入數(shù)據(jù)庫(kù)結(jié)論
我們已經(jīng)討論了如何把圖片存入到Sql Server,那么我們?nèi)绾螐腟qlServer中讀取圖片呢?可以參看我的另一篇文章:在ASP.NET中從SqlServer中檢索圖片。

AspNet技術(shù)ASP.Net 圖片存入數(shù)據(jù)庫(kù)的實(shí)現(xiàn)代碼,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 杨子姗赵又廷演的电影叫什么| cctv17节目表今天| 建国大业演员表| 蜂鸟电视剧演员表| 口述公交车上| 他其实没那么爱你电影| 歌手蔡国庆个人简历| 赵琦| av在线看| 出轨的女人电影| 土壤动植物的乐园教学反思| 性视频网站在线| 供货合同| 邓紫飞| 时间空间和人第二部| 神经内科出科小结| 老男人gay同性gay做受| 红色诗配画| 陈宛蔚| 掐脖子的视频| 美女上厕所| 安息2| 圆谷一夫| 飞扬的青春 电视剧| 戴安·梅尔致命诱饵电影上映时间| 张晓婷| 凌晨晚餐| 密使2之江都谍影 2013 于震| 生产时直拍宫口| 格伦鲍威尔| hereweare| christie stevens| 《哥哥的女人》电影| 尸忆在线观看完整恐怖免费| 刘何娜| ymxk| 浙江卫视今天全部节目表| 刘何娜| 凯西·贝茨| 禁忌爱游戏| 寡妇的大乳bd高清|