码迷,mamicode.com
首页 > 其他好文 > 详细

如何读取二进制图片-Gridview中显示二进制图片 --2--(转载)

时间:2014-10-14 18:13:59      阅读:169      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   io   os   使用   ar   for   

  上一次描述了如何读取一张图片。现在来讲讲更为实际的使用。在GridView中读取数据库中保存的图片信息。我讲采用vs2005 + sqlServer2000。访问有名的Northwind数据库中的Employee表。其中Employee表中的photo中保存了员工的信息(image类型)。我要做的是讲每一个员工的信息都显示出来包括他们的图片信息。
    注意:
        1.photo中的信息是二进制的,其中有效的图片信息是从第78位开始的。所以当你想要转换图片信息的时候应该从第78位开始。
        2. 我的例子中使用的是<img>显示图片信息的。当然你也可以使用imageWeb控件来显示。我尝试过,如果你使用的是Image控件的话你在调试模式下会报错,但在浏览模式下就是正常的。其原因我也不清楚。各位可以尝试一下。随便也告诉一下我原因。
    下面是代码。
     default.aspx
   

bubuko.com,布布扣<%@ Page Language="C#" AutoEventWireup="true"  CodeFile="Default.aspx.cs" Inherits="_Default" %>
bubuko.com,布布扣
bubuko.com,布布扣<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
bubuko.com,布布扣
bubuko.com,布布扣<html xmlns="http://www.w3.org/1999/xhtml" >
bubuko.com,布布扣<head runat="server">
bubuko.com,布布扣    <title>无标题页</title>
bubuko.com,布布扣</head>
bubuko.com,布布扣<body>
bubuko.com,布布扣    <form id="form1" runat="server">
bubuko.com,布布扣    <div>
bubuko.com,布布扣        <div style="width: 100px; position: static; height: 100px; margin:auto;">
bubuko.com,布布扣            <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataKeyNames="EmployeeID"
bubuko.com,布布扣                DataSourceID="SqlDataSource1" BackColor="White" BorderColor="#CCCCCC" BorderStyle="None" BorderWidth="1px" CellPadding="3">
bubuko.com,布布扣                <Columns>
bubuko.com,布布扣                    <asp:BoundField DataField="LastName" HeaderText="LastName" SortExpression="LastName" />
bubuko.com,布布扣                    <asp:BoundField DataField="FirstName" HeaderText="FirstName" SortExpression="FirstName" />
bubuko.com,布布扣                    <asp:TemplateField>
bubuko.com,布布扣                        <EditItemTemplate>
bubuko.com,布布扣                            <asp:TextBox ID="TextBox1" runat="server" Text=‘<%# Eval("EmployeeID") %>‘></asp:TextBox>
bubuko.com,布布扣                        </EditItemTemplate>
bubuko.com,布布扣                        <ItemTemplate>
bubuko.com,布布扣                            <img ID="Image1" src=‘<%# Eval("EmployeeID", "ImageHandler.ashx?id={0}") %>‘ />
bubuko.com,布布扣                        </ItemTemplate>
bubuko.com,布布扣                        <AlternatingItemTemplate>
bubuko.com,布布扣                            <img ID="Image1"  src=‘<%# Eval("EmployeeID", "ImageHandler.ashx?id={0}") %>‘/>
bubuko.com,布布扣                        </AlternatingItemTemplate>
bubuko.com,布布扣                    </asp:TemplateField>
bubuko.com,布布扣                </Columns>
bubuko.com,布布扣                <FooterStyle BackColor="White" ForeColor="#000066" />
bubuko.com,布布扣                <RowStyle ForeColor="#000066" />
bubuko.com,布布扣                <SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
bubuko.com,布布扣                <PagerStyle BackColor="White" ForeColor="#000066" HorizontalAlign="Left" />
bubuko.com,布布扣                <HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" />
bubuko.com,布布扣            </asp:GridView>
bubuko.com,布布扣        </div>
bubuko.com,布布扣    
bubuko.com,布布扣    </div>
bubuko.com,布布扣        <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:NorthwindConnectionString %>"
bubuko.com,布布扣            SelectCommand="SELECT [LastName], [FirstName], [EmployeeID] FROM [Employees]"></asp:SqlDataSource>
bubuko.com,布布扣    </form>
bubuko.com,布布扣</body>
bubuko.com,布布扣</html>
bubuko.com,布布扣

    default.aspx.cs 中不需要任何代码。注意以上的<img ID="Image2"  src=‘<%# Eval("EmployeeID", "ImageHandler.ashx?id={0}") %>‘/>  中的src指向的就是下面你编写的文件。
ImageHandler.ashx
  
bubuko.com,布布扣<%@ WebHandler Language="C#" Class="ImageHandler" %>
bubuko.com,布布扣
bubuko.com,布布扣using System;
bubuko.com,布布扣using System.Web;
bubuko.com,布布扣using System.Data;
bubuko.com,布布扣using System.Data.SqlClient;
bubuko.com,布布扣public class ImageHandler : IHttpHandler {
bubuko.com,布布扣    
bubuko.com,布布扣    public void ProcessRequest (HttpContext context) 
bubuko.com,布布扣    {
bubuko.com,布布扣        //获取雇员ID。
bubuko.com,布布扣        string id = context.Request.QueryString["id"];
bubuko.com,布布扣        //这里可以使用我在上一个例子中读图片的文件的例子来代替。
bubuko.com,布布扣        //altimageData的作用是数据库中不存在照片数据的时候可以
bubuko.com,布布扣        //显示这个默认的图片。我在这里就用它来代替了。没有实际作用。
bubuko.com,布布扣        byte[] altimageData = new byte[1];
bubuko.com,布布扣        byte[] imageData = altimageData;
bubuko.com,布布扣        using (SqlConnection conn = new SqlConnection(System.Configuration.ConfigurationManager.ConnectionStrings["NorthwindConnectionString"].ConnectionString))
bubuko.com,布布扣        {
bubuko.com,布布扣           
bubuko.com,布布扣            SqlCommand comm = new SqlCommand("SELECT Photo FROM Employees WHERE EmployeeID = @EmployeeID", conn);
bubuko.com,布布扣            SqlParameter parm = comm.Parameters.Add("@EmployeeID", SqlDbType.Int, 4);
bubuko.com,布布扣            parm.Value = int.Parse(id);
bubuko.com,布布扣            conn.Open(); 
bubuko.com,布布扣            using (SqlDataReader rdr = comm.ExecuteReader(CommandBehavior.SingleRow))
bubuko.com,布布扣            {
bubuko.com,布布扣                if (rdr.Read())
bubuko.com,布布扣                    //为了防止你读的数据是空的而做的。如果没有图片就使用替代图片来代替。
bubuko.com,布布扣                    imageData = (rdr[0] == System.DBNull.Value) ? altimageData : (byte[])rdr[0];
bubuko.com,布布扣            }
bubuko.com,布布扣         
bubuko.com,布布扣        }
bubuko.com,布布扣        //写入图片信息到输出流中。
bubuko.com,布布扣        context.Response.OutputStream.Write(imageData, 78, imageData.Length - 78);
bubuko.com,布布扣    }
bubuko.com,布布扣
bubuko.com,布布扣    public bool IsReusable
bubuko.com,布布扣    {
bubuko.com,布布扣        get {
bubuko.com,布布扣            return false;
bubuko.com,布布扣        }
bubuko.com,布布扣    }
bubuko.com,布布扣
bubuko.com,布布扣}

    源代码下载

 
分类: ASP.NET2.0

如何读取二进制图片-Gridview中显示二进制图片 --2--(转载)

标签:style   blog   http   color   io   os   使用   ar   for   

原文地址:http://www.cnblogs.com/lschenblog/p/4024685.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!