0

我有一个检索员工数据的列表框,当我单击员工时,我会得到他的名字、姓氏和他的照片。

我做了所有事情,直到显示数据库中的图像。我在下面有这段代码。当我单击列表框中的员工姓名时,我也想加载并显示他的照片和他的名字。(SQL 列 EmployeePhoto 是“图像”类型,我成功地将员工图像作为二进制插入。

在堆栈中抓取了这个主题,但没有找到我能理解的有用解决方案。需要你的帮助,谢谢。

protected void ListBox1_SelectedIndexChanged(object sender, EventArgs e) //select listbox item
        {

          try
          {
            cnn.Open();
            SqlCommand cmd = new SqlCommand("SELECT EmployeeFirstName,EmployeeLastName,EmployeePhoto FROM Employees WHERE EmployeeID = @myvalue", cnn);
            cmd.Parameters.AddWithValue("@myvalue", (ListBox1.SelectedValue));
            SqlDataReader dr = cmd.ExecuteReader();
            if (dr.HasRows)
            {
                while (dr.Read())
                {
                    TextBox1.Text = dr.GetString(0);
                    TextBox2.Text = dr.GetString(1);

                    //want to display EmployeePhoto in ID:Image1 that was saved as binary

                }
            }
            cnn.Close();
        }
        catch (Exception ex)
        {
            Label1.Text = ex.Message;
        }
    }

在此处输入图像描述

4

3 回答 3

0

我会将图像保存到文件系统(使用File.WriteAllBytes())。然后在图像框中显示文件系统中的文件。

于 2013-10-02T17:30:54.063 回答
0

您需要图像处理程序 (ASHX) 才能向浏览器显示二进制数据。

ASP.NET 中的图像处理

例如,

using System;
using System.Web;

public class ImageHandler : IHttpHandler, IReadOnlySessionState
{     
    public void ProcessRequest(HttpContext context)
    {
        // Query image data from database based on query string value.
        context.Response.BinaryWrite(YourImageByte);
    }

    public bool IsReusable {
        get { return false; }
    }

}

// Usage
Image1.ImageUrl ="ImageHandler.ashx?id=5"
于 2013-10-02T17:32:31.570 回答
0

你应该使用ListViewcontrol 而不是 ListBox.

ListViewiItem 有一个ImageIndex属性,可让您指定要从中渲染的图像的索引(它也支持绑定)

于 2013-10-02T17:33:11.307 回答