javascript - nw.js 的多部分/表单数据请求

标签 javascript ajax nw.js

我需要从 nw.js 将 POST 数据发送到服务器。数据包含简单的名称-值对和一个文件,即请求类型为multipart/form-data。所有数据均应按一个请求发送。

我使用 XMLHttpRequest 和 FormData 发送数据。代码:

function toArrayBuffer(buffer) {        // convert Node's Buffer to ArrayBuffer
    var ab = new ArrayBuffer(buffer.length);
    var view = new Uint8Array(ab);
    for (var i = 0; i < buffer.length; ++i) {
        view[i] = buffer[i];
    }
    return ab;
}

var fData = new global.window.FormData();
fData.append( 'email', email );
fData.append( 'foo', 'bar' );     // some plain data;
var fs = require('fs');
var buff;

fs.readFile( data.path, function ( err, data ) {    // data.path contents full path to the file
    if( err ) {
        console.log( 'file reading error' );
        //  handling a errors
    }else{
        console.log('reading complete');
        buff = data;                        // buffer contains data, checked
        send( );
    };
});

function send() {
    var blob = new global.window.Blob( [toArrayBuffer(buff)], { type:'image/jpeg' } );  // here is a problem, I think
    fData.append( 'file', blob );
    // I've tried some cases:
    // var blob = new Blob( toArrayBuffer(buff), { type:'image/jpeg' } );  //without array braces it throws a error: The 1st argument provided is either null, or an invalid Array object.
    // var blob = new Blob( buff, { type:'image/jpeg' } );  //  directly, same error

    var xhr = new global.window.XMLHttpRequest();
    xhr.open( "POST", url );
    xhr.timeout = 30000;
    xhr.onload = xhr.onerror = function() {
        // handling result or errors...
    };
    xhr.send( fData );
}

XMLHttpRequest 发送除文件之外的所有数据。这是请求负载:

------WebKitFormBoundaryc0ClIBTxPlqPmilD
Content-Disposition: form-data; name="email"

email
------WebKitFormBoundaryc0ClIBTxPlqPmilD
Content-Disposition: form-data; name="message_id"

4b38ad18-0501-9c0d-9cf6-e0a2fcca1898
------WebKitFormBoundaryc0ClIBTxPlqPmilD
Content-Disposition: form-data; name="foo"

bar
------WebKitFormBoundaryc0ClIBTxPlqPmilD
Content-Disposition: form-data; name="file"; filename="blob"
Content-Type: image/jpeg


------WebKitFormBoundaryc0ClIBTxPlqPmilD--

文件部分为空。

我还尝试过将 Buffer 直接传递给 FormData。 在这种情况下,文件发送,但服务器无法将文件识别为文件 - 而是将文件放入字符串中(常见的 PHP 服务器)。

谢谢

最佳答案

我用 form-data 解决了这个问题图书馆:

var FormData = require('form-data');
var form = new FormData();
var fs = require('fs');
form.append( 'email', email );
form.append( 'foo', 'bar' );
form.append('logo', fs.createReadStream(fileOnDisk)); // attach file
form.submit(url, function(err, res) { ... }

关于javascript - nw.js 的多部分/表单数据请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37832649/

相关文章:

java - 如何从 NW.js 实现的前端向 Java 实现的后端发送 RESTful 请求?

javascript - 迁移后 Sequelize 模型不同步

javascript - Loopback:我们如何修改内置模型函数的返回数据

页面内的Javascript重定向方法

javascript - MVC 更新部分 View onchange 下拉列表

json - 通过 AJAX 将 JSON 对象从 Django View 返回给客户端

javascript - 如何将 ISO 8601 转换为美国时区

javascript - jquery 将先前的输入设置为 0

javascript - 是否可以在特定目录中使用 javascript 保存 .swf、.mp3、.txt 等文件而没有 "save as"提示?

javascript - angularjs 与 nw.js 不工作。 ng-src 属性