多部分数据意外结束

时间:2018-10-31 15:54:17

标签: c# node.js asp.net-core openshift busboy

我有一个.net core 2.0 API服务,该服务获取两个文件(XML和Word)并将其传输到节点js服务器,该服务器将它们保存到MongoDB。

当我在本地主机上托管网络核心服务时,一切正常,但是当我将.net服务上载到open shift(Kubernete)时,我从busboy-body-parser包中的Node.js服务中获得了异常。在index.js文件中:

  

“错误:多部分数据的意外末尾为   ... node_modules \ dicer \ lib \ Dicer.js:62:28正在处理。_tickCallback   (internal / process / next_tick.js61:11)“

此代码在index.js file中捕获了异常:

busboy.on('error', function (err) {
                debug('Error parsing form');
                debug(err);
                error = err;
                next(err);
            });

这是我的c#代码,用于将文件发布到从bratched复制的Node.js服务中:

public byte[] UploadFiles(string address, IEnumerable<UploadFile> files, NameValueCollection values)
    {
        var request = WebRequest.Create(address);
        request.Method = "POST";
        var boundary = "---------------------------" + DateTime.Now.Ticks.ToString("x", NumberFormatInfo.InvariantInfo);
        request.ContentType = "multipart/form-data; boundary=" + boundary;
        boundary = "--" + boundary;

        using (var requestStream = request.GetRequestStream())
        {
            // Write the values
            foreach (string name in values.Keys)
            {
                var buffer = Encoding.ASCII.GetBytes(boundary + Environment.NewLine);
                requestStream.Write(buffer, 0, buffer.Length);
                buffer = Encoding.ASCII.GetBytes(string.Format("Content-Disposition: form-data; name=\"{0}\"{1}{1}", name, Environment.NewLine));
                requestStream.Write(buffer, 0, buffer.Length);
                buffer = Encoding.UTF8.GetBytes(values[name] + Environment.NewLine);
                requestStream.Write(buffer, 0, buffer.Length);
            }

            // Write the files
            foreach (var file in files)
            {
                var buffer = Encoding.ASCII.GetBytes(boundary + Environment.NewLine);
                requestStream.Write(buffer, 0, buffer.Length);
                buffer = Encoding.UTF8.GetBytes(string.Format("Content-Disposition: form-data; name=\"{0}\"; filename=\"{1}\"{2}", file.Name, file.Filename, Environment.NewLine));
                requestStream.Write(buffer, 0, buffer.Length);
                buffer = Encoding.ASCII.GetBytes(string.Format("Content-Type: {0}{1}{1}", file.ContentType, Environment.NewLine));
                requestStream.Write(buffer, 0, buffer.Length);
                file.Stream.CopyTo(requestStream);
                buffer = Encoding.ASCII.GetBytes(Environment.NewLine);
                requestStream.Write(buffer, 0, buffer.Length);
            }

            var boundaryBuffer = Encoding.ASCII.GetBytes(boundary + "--");
            requestStream.Write(boundaryBuffer, 0, boundaryBuffer.Length);
        }

        using (var response = request.GetResponse())
        using (var responseStream = response.GetResponseStream())
        using (var stream = new MemoryStream())
        {
            responseStream.CopyTo(stream);
            return stream.ToArray();
        }
    }

1 个答案:

答案 0 :(得分:-1)

尝试查看此链接:https://github.com/mscdex/dicer/issues/14

您需要在文件中添加错误列表,然后查看问题所在

我们可以通过将错误事件处理程序附加到文件对象来捕获错误。

file.on('错误',()=> {})