1

我正在尝试使用 linq 从数据库返回二进制文件以在浏览器中显示。下面使用 ado.net 的方法有效,但我正在尝试 ypgrade 到 linq,但 linq 版本返回了错误。

    Public Sub ProcessRequest(ByVal context As System.Web.HttpContext) 
    Dim imageId As String = context.Request.QueryString("id")
    Dim ret As DataTable = Nothing
    ret = DPGetImageData.GetImageById(Convert.ToInt64(imageId))

        For Each dt As DataRow In ret.Rows
            For Each c As DataColumn In ret.Columns
                If Not (dt(c) Is Nothing) Then
                    context.Response.Clear()
                    context.Response.BufferOutput = False
                    context.Response.OutputStream.Write(CType(dt.Table.Rows(0).Item("imageData"), Byte()), 0, CInt(dt.Table.Rows(0).Item("imageSize")))
                    context.Response.End()
                End If

            Next
        Next


End Sub

工作 Linq 版本:

Public Sub ProcessRequest(ByVal context As HttpContext) Implements IHttpHandler.ProcessRequest
    If Not String.IsNullOrEmpty(Current.Request.QueryString("Id")) Then
        Dim imageId = HttpContext.Current.Request.QueryString("Id")
        Dim result = repository.FindById(Convert.ToInt64(imageId)).imageData.ToArray
        HttpContext.Current.Response.BinaryWrite(result)
        context.Response.End()

    End If
End Sub
4

2 回答 2

2

您应该可以只调用 Response.BinaryWrite(result.ToArray())。注意括号,ToArray 是一个方法调用。

于 2009-04-01T05:02:51.227 回答
0

您应该不需要强制转换为 Binary.ToArray,已经返回一个字节数组。

另一种方法是直接使用字节数组。您可以在设计器中对其进行修改。

更新:

我不完全确定,但可能是您的 DataContext 已经被处理了。我认为 Binary 类型使用延迟加载。

如果您添加堆栈跟踪,我们可以查看是否是这种情况。

于 2009-04-01T04:43:25.987 回答