Out Of Memory (7) when upload file in VB6 using MSXML

271 Views Asked by At

i have a function to upload multipart/form-data with Visual Basic 6 using MSXML2.ServerXMLHTTP60, no problem with 100MB file size, but when i upload 200MB it's show "Run Time Error '7'" Out Of Memory.

this is my code:

Public Function PostFile(sUrl As String, sJSON As String, sFileName As String) As String
    Const STR_BOUNDARY  As String = "864d391d-4097-44e0-92e1-71aff17094c1"
    Dim sPostData       As String
    Dim bytData

    With CreateObject("ADODB.Stream")
        .Type = 1
        .Mode = 3
        .Open
        .LoadFromFile sFileName
        bytData = .Read
    End With

    With CreateObject("ADODB.Stream")
        .Mode = 3
        .Charset = "Windows-1252"
        .Open
        .Type = 2
        .WriteText "--" & STR_BOUNDARY & vbCrLf
        .WriteText "Content-Disposition: form-data; name=""json""" & vbCrLf
        .WriteText "Content-Type: application/json" & vbCrLf & vbCrLf
        .WriteText sJSON & vbCrLf
        .WriteText "--" & STR_BOUNDARY & vbCrLf
        .WriteText "Content-Disposition: form-data; name=""uploadfile""; filename=""" & Mid$(sFileName, InStrRev(sFileName, "\") + 1) & """" & vbCrLf
        .WriteText "Content-Type: application/octet-stream" & vbCrLf & vbCrLf
        .Position = 0
        .Type = 1
        .Position = .Size
        .Write bytData
        .Position = 0
        .Type = 2
        .Position = .Size
        .WriteText vbCrLf & "--" & STR_BOUNDARY & "--"
        .Position = 0
        .Type = 1
        sPostData = StrConv(.Read, vbUnicode)
    End With

    With New MSXML2.ServerXMLHTTP60
        .Open "POST", sUrl, True
        .setRequestHeader "Content-Type", "multipart/form-data; boundary=" & STR_BOUNDARY
        .send ToByteArray(sPostData)
        .waitForResponse 300 'second
        If .Status = 200 Then PostFile = .responseText Else .abort
    End With
End Function

Private Function ToByteArray(sText As String) As Byte()
    ToByteArray = StrConv(sText, vbFromUnicode)
End Function

Before i update the script above i using "open file method" to read binary file like below:

Public Function PostFile(sUrl As String, sJSON As String, sFileName As String) As String
    Const STR_BOUNDARY  As String = "864d391d-4097-44e0-92e1-71aff17094c1"
    Dim nFile           As Integer
    Dim baBuffer()      As Byte
    Dim sPostData       As String

    nFile = FreeFile
    Open sFileName For Binary Access Read As nFile
    If LOF(nFile) > 0 Then
        ReDim baBuffer(0 To LOF(nFile) - 1) As Byte
        Get nFile, , baBuffer
        sPostData = StrConv(baBuffer, vbUnicode)
    End If
    Close nFile

    '--- prepare body
    sPostData = "--" & STR_BOUNDARY & vbCrLf & _
        "Content-Disposition: form-data; name=""json""" & vbCrLf & _
        "Content-Type: application/json" & vbCrLf & vbCrLf & _
        sJSON & vbCrLf & _
        "--" & STR_BOUNDARY & vbCrLf & _
        "Content-Disposition: form-data; name=""uploadfile""; filename=""" & Mid$(sFileName, InStrRev(sFileName, "\") + 1) & """" & vbCrLf & _
        "Content-Type: application/octet-stream" & vbCrLf & vbCrLf & _
        sPostData & vbCrLf & _
        "--" & STR_BOUNDARY & "--"
    '--- post

    With New MSXML2.ServerXMLHTTP60
        .Open "POST", sUrl, True
        .setRequestHeader "Content-Type", "multipart/form-data; boundary=" & STR_BOUNDARY
        .send ToByteArray(sPostData)
        .waitForResponse 300 'second
        If .Status = 200 Then PostFile = .responseText Else .abort
    End With
End Function

Private Function ToByteArray(sText As String) As Byte()
    ToByteArray = StrConv(sText, vbFromUnicode)
End Function

But, that show error "Run Time Error '14'" Out of string space

how to handle this error?

0

There are 0 best solutions below