使用 ashx 读取图像在 asp.net 中不起作用

read image using ashx doesn't work in asp.net

我正在尝试使用 ashx 从数据库加载图像。

当我使用此代码时,图像已成功加载

 <% <asp:Image ID="Image1" runat="server" ImageUrl='<%# Eval("Id", "~/Handler/CategoryHandler.ashx?catId={0}") %>' />

但是当我使用这段代码时

   <%
            foreach (ProductCategories VARIABLE in categoriesList)
            {
                 Response.Write("<div class='wrapper-box'>" +
                                    "<a href='product/product.aspx'>" +
                                        "<img src='~/Handler/ProductHandler.ashx?Id="+VARIABLE.Id+"'/>" +
                                        "<p>"+VARIABLE.CategoryName+"</p>" +
                                    "</a>" +
                                "</div>");
            }

             %>

图像无法加载。为什么代码不起作用?

ashx文件是这样的:

 public void ProcessRequest(HttpContext context)
    {
        // Set up the response settings
        context.Response.ContentType = "image/jpeg";
        context.Response.Cache.SetCacheability(HttpCacheability.Public);
        context.Response.BufferOutput = false;
        // Setup the Size Parameter
        ImageSize size;
        switch (context.Request.QueryString["Size"])
        {
            case "S":
                size = ImageSize.Small;
                break;
            case "L":
                size = ImageSize.Large;
                break;
            default:
                size = ImageSize.Small;
                break;
        }
        // Setup the PhotoID Parameter
        Stream stream;
        if (context.Request.QueryString["Id"] != null && context.Request.QueryString["Id"] != "")
        {
            Int32 id = Convert.ToInt32(context.Request.QueryString["Id"]);
            stream = Products.GetImageStream(id, size);
            //context.Response.AddHeader("content-disposition", String.Format("attachement;filename=\"{0}\"", );
            // Get the photo from the database, if nothing is returned, get the default "placeholder" photo
            if (stream == null) return;
            // Write image stream to the response stream
            const int buffersize = 1024 * 16;
            byte[] buffer = new byte[buffersize];
            int count = stream.Read(buffer, 0, buffersize);
            while (count > 0)
            {
                context.Response.OutputStream.Write(buffer, 0, count);
                count = stream.Read(buffer, 0, buffersize);
            }
        }
    }

问题是Response.Write没有将~字符扩展到基数URL,所以URL中生成的图像的URL页面的19=]类似这样:

<img src='~/Handler/ProductHandler.ashx?Id=123' />

为了解决这个问题,你必须在 Response.Write 中使用它之前扩展 URL:

<%
    foreach (ProductCategories VARIABLE in categoriesList)
    {
        var imgUrl = ResolveUrl("~/Handler/ProductHandler.ashx?Id=" + VARIABLE.Id.ToString());
        Response.Write("<div class='wrapper-box'>" +
            "<a href='product/product.aspx'>" +
                "<img src='" + imgUrl + "'/>" +
                "<p>"+VARIABLE.CategoryName+"</p>" +
            "</a>" +
        "</div>");
}
%>