手机
当前位置:查字典教程网 >编程开发 >asp.net教程 >c# 读取Northwind数据库image字段
c# 读取Northwind数据库image字段
摘要:这里值得一提的是,web控件image不像winForm控件那样可以通过读取二进制流赋值给image属性来显示图像。可以通过变通的方法来实现...

这里值得一提的是,web控件image不像winForm控件那样可以通过读取二进制流赋值给image属性来显示图像。可以通过变通的方法来实现,流行的做法是新建一个页面专门用来显示图像,这里代码直接用孟子E章前辈的(作了小修改,主要是剔除78个byte字节流来正常显示northwind数据库的图片):

ReadImage.aspx.cs

复制代码 代码如下:

using System;

using System.Collections;

using System.Configuration;

using System.Data;

using System.Linq;

using System.Web;

using System.Web.Security;

using System.Web.UI;

using System.Web.UI.HtmlControls;

using System.Web.UI.WebControls;

using System.Web.UI.WebControls.WebParts;

using System.Xml.Linq;

using System.Data.SqlClient;

namespace WebApplication2

{

public partial class ReadImage : System.Web.UI.Page

{

protected void Page_Load(object sender, EventArgs e)

{

string strImageID = Request.QueryString["id"];

SqlConnection myConnection = new SqlConnection("Data Source=.;Initial Catalog=northwind;User Id=sa;Password=123456;");

SqlCommand myCommand = new SqlCommand("Select Picture from Categories Where CategoryID="

+ strImageID, myConnection);

try

{

myConnection.Open();

SqlDataReader myDataReader;

myDataReader = myCommand.ExecuteReader(CommandBehavior.CloseConnection);

if (myDataReader.Read())

{

Response.Clear();

Response.ContentType = "image/jpeg";

byte[] b = (byte[])myDataReader["Picture"];

//下面的方法就是用来让图片可以正常显示

byte[] temp=new byte [b.Length -78];

Array.Copy(b, 78, temp, 0, b.Length - 78);

Response.BinaryWrite(temp);

}

myConnection.Close();

}

catch (SqlException SQLexc)

{

Response.Write(SQLexc.ToString ());

}

Response.End();

}

}

}

在源页面如Default.aspx.cs可以通过下面方法调用

复制代码 代码如下:

protected void Page_Load(object sender, EventArgs e)

{

if(!IsPostBack )

Image1.ImageUrl = FormatURL("1");

}

protected string FormatURL(string strArgument)

{

return "ReadImage.aspx?id=" + strArgument;

}

如果不想新建一个页面来承载图像,也可以使用下面的方法:(注意:下面的类是自定义的,大家看得懂这个方法就可以了)

复制代码 代码如下:

using System;

using System.Collections;

using System.Configuration;

using System.Data;

using System.Linq;

using System.Web;

using System.Web.Security;

using System.Web.UI;

using System.Web.UI.HtmlControls;

using System.Web.UI.WebControls;

using System.Web.UI.WebControls.WebParts;

using System.Xml.Linq;

using System.Data.SqlClient;

namespace WebApplication2

{

public partial class ReadImage : System.Web.UI.Page

{

protected void Page_Load(object sender, EventArgs e)

{

string strImageID = Request.QueryString["id"];

SqlConnection myConnection = new SqlConnection("Data Source=.;Initial Catalog=northwind;User Id=sa;Password=123456;");

SqlCommand myCommand = new SqlCommand("Select Picture from Categories Where CategoryID="

+ strImageID, myConnection);

try

{

myConnection.Open();

SqlDataReader myDataReader;

myDataReader = myCommand.ExecuteReader(CommandBehavior.CloseConnection);

if (myDataReader.Read())

{

Response.Clear();

Response.ContentType = "image/jpeg";

byte[] b = (byte[])myDataReader["Picture"];

byte[] temp=new byte [b.Length -78];

Array.Copy(b, 78, temp, 0, b.Length - 78);

Response.BinaryWrite(temp);

}

myConnection.Close();

}

catch (SqlException SQLexc)

{

Response.Write(SQLexc.ToString ());

}

Response.End();

}

}

}

【c# 读取Northwind数据库image字段】相关文章:

ASP.Net Post方式获取数据流的一种简单写法

注册表中存储数据库链接字符串的方法

ASP.NET2.0数据库入门之SqlDataSource

.net 通过URL推送POST数据具体实现

ASP.NET封装的SQL数据库访问类

C# 文件保存到数据库中或者从数据库中读取文件

c#将Excel数据导入到数据库的实现代码

asp.net ListView 数据绑定

asp.net连接数据库读取数据示例分享

asp.net Xml绑定到数据控件的具体实现

精品推荐
分类导航