Rendering bytes from sql server to an image control?

后端 未结 4 624
天涯浪人
天涯浪人 2020-12-22 04:20

Markup:


    
        
相关标签:
4条回答
  • 2020-12-22 04:54

    You have to create an http handler that returns the image

    public void ProcessRequest(HttpContext context)
    {
        byte[] yourImage = //get your image byte array
        context.Response.BinaryWrite(yourImage);
        context.Request.ContentType = "image/jpeg";
        context.Response.AddHeader("Content-Type", "image/jpeg");
        context.Response.AddHeader("Content-Length", (yourImage).LongLength.ToString());
        con.Close();
    
        context.Response.End();
        context.Response.Close();
    }
    

    You can can do that by creating a GenericHandler file type from the visual studio and add the previous code in then you can call you can write the url of the generic handler as the image source

    0 讨论(0)
  • 2020-12-22 05:00

    Download and Upload images from SQL Server via ASP.Net MVC.

    The code is MVC but the idea behind the implementation is not MVC specific and can be used in generic ASP. The gist of the issue is that you want to avoid reading the database BLOB into a byte array and then writing the byte array into the response, doing so will result in poor performance under load due to the many large size array allocations (an image can easily go into 2 MB+ and large images can go into tens and even hundreds of MB). This article shows how to do a stream based implementation where the bytes are sent back to the HTTP response as they are read from the database.

    0 讨论(0)
  • 2020-12-22 05:13

    See full article here.

    public class NWEmpPhotoHandler : IHttpHandler 
    { 
        public bool IsReusable { get { return true; } } 
    
        public void ProcessRequest(HttpContext ctx) 
        { 
            string id = ctx.Request.QueryString["id"]; 
    
            SqlConnection con = new SqlConnection(<<INSERT CONNECTION STRING HERE>>); 
            SqlCommand cmd = new SqlCommand("SELECT Photo FROM Employees WHERE EmployeeID = @EmpID", con); 
            cmd.CommandType = CommandType.Text; 
            cmd.Parameters.Add("@EmpID", id); 
    
            con.Open(); 
            byte[] pict = (byte[])cmd.ExecuteScalar(); 
            con.Close(); 
    
            ctx.Response.ContentType = "image/bmp"; 
            ctx.Response.OutputStream.Write(pict, 78, pict.Length - 78); 
        } 
    } 
    
    0 讨论(0)
  • 2020-12-22 05:14

    Cool question. I would write a class implementing IHttpHandler which responds to requests for the image file(s).

    See my answer in the following question for an example of how to get file streams in and out of a SQL varbinary(max) field.

    How to make a fileupload interface in ASP.NET

    Don't forget to use the correct MIME type when crafting the HTTP response.

    0 讨论(0)
提交回复
热议问题