Asp.net把圖片存入數(shù)據(jù)庫(kù)和讀取圖片的方法
存儲(chǔ)圖片類(lèi)型數(shù)據(jù)有以下幾種方式:
1.將圖片轉(zhuǎn)換為二進(jìn)制數(shù)組(byte[])
byte[] fileData = this.FileUpload1.FileBytes;
2. 根據(jù)路徑將文件轉(zhuǎn)換為2進(jìn)制數(shù)組
代碼
public byte[] returnbyte(string strpath)
{
// 以二進(jìn)制方式讀文件
FileStream fsMyfile = new FileStream(strpath, FileMode.OpenOrCreate, FileAccess.ReadWrite);
// 創(chuàng)建一個(gè)二進(jìn)制數(shù)據(jù)流讀入器,和打開(kāi)的文件關(guān)聯(lián)
BinaryReader brMyfile = new BinaryReader(fsMyfile);
// 把文件指針重新定位到文件的開(kāi)始
brMyfile.BaseStream.Seek(0, SeekOrigin.Begin);
byte[] bytes = brMyfile.ReadBytes(Convert.ToInt32(fsMyfile.Length.ToString()));
// 關(guān)閉以上new的各個(gè)對(duì)象
brMyfile.Close();
return bytes;
}
3img 類(lèi)型得到二進(jìn)制數(shù)組
public static byte[] Getbyte(Image img)
{
MemoryStream stream = new MemoryStream();
img.Save(stream, ImageFormat.Jpeg);
byte[] mydata = new byte[stream.Length];
mydata = stream.ToArray();
stream.Close();
return mydata;
}
讀取image類(lèi)型的數(shù)據(jù)并顯示在網(wǎng)頁(yè)上的方式如下:
1。直接返回image 類(lèi)型
private System.Drawing.Image getImageDataFromOracle()
{
string sql = "select IMGDATA from t_img where imgID=100";
string strconn = System.Configuration.ConfigurationManager.ConnectionStrings["ConnectionStringForOracle"].ToString();
OracleConnection oraConn = new OracleConnection(strconn);
OracleCommand oraComm = new OracleCommand(sql, oraConn);
oraConn.Open();
byte[] fileData = (byte[])oraComm.ExecuteScalar();
oraConn.Close();
System.IO.MemoryStream ms = new System.IO.MemoryStream(fileData);
System.Drawing.Image img = System.Drawing.Image.FromStream(ms);
return img;
}
2.利用頁(yè)面輸入來(lái)顯示圖片
頁(yè)面ImageShow.aspx (Page_Load方法)
protected void Page_Load(object sender, EventArgs e)
{
byte[] b_logoImg = (byte[])dt_channelImg.Rows[0]["LogoImage"]; //得到byte[] 數(shù)組,這里只是舉個(gè)例子
if (b_logoImg.Length > 0)
{
System.Drawing.Image logoImg;
MemoryStream ms = new MemoryStream(b_logoImg);
Response.Clear();
Response.ContentType = "image/gif";
Response.OutputStream.Write(b_logoImg, 0, b_logoImg.Length);
Response.End();
}
}
圖片路徑寫(xiě)成為:<img src = "ImageShow.aspx" />
相關(guān)文章
Asp.net之?dāng)?shù)據(jù)過(guò)濾淺析
在B/S開(kāi)發(fā)中,安全性能應(yīng)該是需要注意的,很多年前有位高人說(shuō)過(guò),凡是來(lái)自客戶(hù)端的數(shù)據(jù),都是不可信的,今天開(kāi)發(fā)時(shí),把數(shù)據(jù)過(guò)濾的方法重寫(xiě)了一下,所以忍不住想拿出來(lái)討論下,歡迎大家指點(diǎn)2011-11-11
淺談Asp.net Mvc之Action如何傳多個(gè)參數(shù)的方法
本篇文章主要介紹了Asp.net Mvc之Action如何傳多個(gè)參數(shù)的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-08-08
asp.net 修改/刪除站內(nèi)目錄操作后Session丟失問(wèn)題
在Web項(xiàng)目中使用 Directory.Move(olddir,newdir)修改目錄名稱(chēng)或使用Directory.Delete(true)刪除目錄后, 發(fā)現(xiàn)Session都失效。2010-01-01
ASP.NET實(shí)現(xiàn)進(jìn)度條效果
這篇文章主要為大家詳細(xì)介紹了ASP.NET實(shí)現(xiàn)簡(jiǎn)單的進(jìn)度條效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06
關(guān)于.NET/C#/WCF/WPF 打造IP網(wǎng)絡(luò)智能視頻監(jiān)控系統(tǒng)的介紹
本篇文章小編將為大家介紹,關(guān)于.NET/C#/WCF/WPF 打造IP網(wǎng)絡(luò)智能視頻監(jiān)控系統(tǒng)的介紹。需要的朋友參考下2013-04-04
C# 接口的隱式與顯示實(shí)現(xiàn)及適應(yīng)場(chǎng)景
以前在用到接口時(shí),從來(lái)沒(méi)注意到接口分為隱式實(shí)現(xiàn)與顯示實(shí)現(xiàn)。昨天在瀏覽博客時(shí)看到相關(guān)內(nèi)容,現(xiàn)在根據(jù)自己的理解記錄一下,方便日后碰到的時(shí)候溫習(xí)溫習(xí),需要的朋友可以了解下2012-12-12
分享一個(gè)取自HoverTree項(xiàng)目的.NET分頁(yè)類(lèi)
分頁(yè)顯示是一種非常常見(jiàn)的瀏覽和顯示大量數(shù)據(jù)的方法,屬于web編程中最常處理的事件之一。對(duì)于web編程的老手來(lái)說(shuō),編寫(xiě)這種代碼實(shí)在是和呼吸一樣自然,但是對(duì)于初學(xué)者來(lái)說(shuō),常常對(duì)這個(gè)問(wèn)題摸不著頭緒,今天我們給大家分享一個(gè)取自HoverTree項(xiàng)目的.NET分頁(yè)類(lèi)。2015-04-04
ASP.NET技巧:同時(shí)對(duì)多個(gè)文件進(jìn)行大量寫(xiě)操作對(duì)性能優(yōu)化
ASP.NET技巧:同時(shí)對(duì)多個(gè)文件進(jìn)行大量寫(xiě)操作對(duì)性能優(yōu)化...2006-09-09

