私はQueryString
をとり、ファイルをクライアントにストリームするASP.Net Webページを作成しました。ファイルはSQL Serverデータベースに格納されます。開発中にウェブサイトをローカルで実行しているときは、すべてがうまく動作します。私はサーバーからプロダクションでそれを実行すると、FirefoxではなくChromeでファイルを取得できます。クロムで私は得るError 100 (net::ERR_CONNECTION_CLOSED): Unknown error.
壊れたストリームファイル、Firefox動作
これは、Content-Length
に関連する可能性がありますが、私はなぜこれが開発ではなく、生産では動作するのか理解できません。その理由から私はここで何か他のことが起こっているに違いないと思います。
提案/ヒントありがとうございます。ここで
は私のコードです:
Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
Dim Data_ID As String = Request.QueryString("Data_ID")
Using dt As New Enterprise_Error_Log.Field_FileDataTable
Using ta As New Field_FileTableAdapter
ta.Fill(dt, Data_ID)
If dt.Rows.Count > 0 Then
Dim myRow As Enterprise_Error_Log.Field_FileRow = dt.Rows(0)
Dim myFileName As String = myRow("Field_File_Name")
'Dim myFileData() As Byte = myRow("Field_File")
Dim myFileLength As String = myRow("Field_File_Length")
Response.BufferOutput = False
Response.AddHeader("Content-Disposition", "inline;filename=""" & myFileName & """")
Response.AddHeader("Content-Length", myFileLength)
StreamFile(Data_ID)
Response.Close()
End If
End Using
End Using
End Sub
Private Sub StreamFile(ByVal Data_ID As String)
Dim bolGotContentType As Boolean = False
Using conn = New SqlConnection(Enterprise_Error_LogConnectionString.ConnectionString)
Using cmd = conn.CreateCommand()
conn.Open()
cmd.CommandText = "SELECT Field_File FROM Ext_Error_Log WHERE (Data_ID = @Data_ID)"
cmd.Parameters.AddWithValue("@Data_ID", Data_ID)
Using reader = cmd.ExecuteReader(Data.CommandBehavior.SequentialAccess)
While reader.Read()
Dim buffer As Byte() = New Byte(8040) {}
' Read chunks of 1KB
Dim bytesRead As Long = 0
Dim dataIndex As Long = 0
Do
'read next chunk
bytesRead = reader.GetBytes(0, dataIndex, buffer, 0, buffer.Length)
If bytesRead > 0 Then
'advance index
dataIndex += bytesRead
'if this is the first chunk, get the mime type from it.
If Not bolGotContentType Then
Response.ContentType = "application/octet-stream" 'getMimeFromFile(buffer)
bolGotContentType = True
End If
Response.BinaryWrite(buffer)
Response.Flush()
End If
Loop Until bytesRead = 0
End While
End Using
End Using
End Using
End Sub
私のヘッダーは次のとおりであります(FirefoxのLiveHTTPヘッダーが頭に浮かぶ)私は、HTTPのトレースツールで実際の応答を検査をお勧めします
Cache-Control: private
Date: Mon, 24 Jan 2011 20:37:33 GMT
Content-Length: 3153269
Content-Type: application/octet-stream
Content-Disposition: attachment;filename="C:\Users\CBARTH\AppData\Local\Temp\tmp4BC8.mdmp.gz";size=3153169
Server: Microsoft-IIS/6.0
X-AspNet-Version: 2.0.50727
X-Powered-By: ASP.NET
Content-Encoding: gzip
Content-Dispositionのコードが壊れています。 (ファイル名に空白が含まれる場合など)、エスケープ(ISO-8859-1以外の場合)の場合は、値を引用符で囲む必要があります。 –
ヘッダー検査でも値が引用されている場合でも値は引用符で囲まれます。おそらく私はあなたが何を指しているのか分からない。 – cjbarth