Я работаю над простым приложением для тегов и поиска изображений.
Я загружаю свои изображения в БД, применяя теги, но у меня не получается, когда я возвращаю их назад - изображения не отображаются.
Я нашел это здесь на SO, но я не могу заставить его работать.
Я думаю, что, возможно, я неправильно понимаю обработчиков.
Короче говоря, в коде позади я создаю ASP: изображение, устанавливаю его imageurl в обработчик с идентификатором фотографии, а затем добавляю этот элемент управления в ASP: Placeholder.
Когда страница отображается, я получаю в IE тот маленький красный х без изображения, а в FF - ничего.
Одна вещь, которая заставляет меня думать, что я что-то упускаю, это то, что точка останова в моем коде обработчика никогда не достигается. Так что это даже выполняется. Правильно?
Кто-нибудь знает, что я здесь не так делаю? Спасибо.
Вот мой обработчик
Imports aapeClsLib
Imports System.Web
Imports System.Web.Services
Public Class photos
Implements System.Web.IHttpHandler
Sub ProcessRequest(ByVal context As HttpContext) Implements IHttpHandler.ProcessRequest
Dim img As Byte() = getImage(context.Request.QueryString("ID"))
context.Response.Clear()
context.Response.ContentType = "image/jpeg"
context.Response.BinaryWrite(img)
context.Response.End()
End Sub
ReadOnly Property IsReusable() As Boolean Implements IHttpHandler.IsReusable
Get
Return False
End Get
End Property
Private Function getImage(ByVal id As String) As Byte()
Dim img As Byte()
Dim strSql As String = "select ph_photo from photos where ph_id = " & id
Dim dt As DataTable = sqLiteData.getDataTable(strSql)
img = CType(dt.Rows(0)(0), Byte())
Return img
End Function
End Class
и где я втыкаю это в мой заполнитель
Private Sub insertPhotos(ByVal dt As DataTable)
For Each row As DataRow In dt.Rows
Dim img As New Image
img.ImageUrl = "photos.ashx?ID=" & row(0)
PlaceHolder1.Controls.Add(img)
Next
End Sub