通过XHR从客户端向Node JS服务器发送blob数据

时间:2013-11-11 14:22:05

标签: javascript node.js xmlhttprequest

我想将一个blob数据从JA客户端发送到NodeJS服务器。

现在我有了这个客户端代码:     [...]     recorder.exportWAV(function(blob){         audioObj = blob;     });

var formData = new FormData();
formData.append("operation", "addMessage");
formData.append("msg", audioObj);

var xhr = new XMLHttpRequest();
xhr.open("POST", "http://localhost:8080/sendRecord", true);
xhr.onreadystatechange = function(){
    if(xhr.readyState==4 && xhr.status==200){
        // get response from server
    }
}
xhr.send(formData);

我使用一些JS库来记录集成麦克风的音频,最后我有一个audiobb是一个blob对象。

这个si node.js服务器,我想调整接收数据。

var http = require('http'),
    url = require('url');

var app = http.createServer(function(request, response){

    var path = url.parse(request.url).pathname;
    // check the url path
    if (path == "/sendRecord") {

        // check the request method
        if(request.method != "POST"){
            // return error
        }

        // _______________________________
        //| here I want catching XHR data |
        // –––––––––––––––––––––––––––––––
    }
}).listen(8080);

console.log("Server running on: http://localhost:8080/");

我认为应该是一些服务器端XHR API来响应客户端XHR请求,但我不知道在哪里以及在哪里找到它们。 谁能帮助我?还有白色链接或文档......;)

谢谢!

1 个答案:

答案 0 :(得分:3)

我回答自己......如果有人在将来发现有用的话;)

使用Formidable(https://github.com/felixge/node-formidable)我已经完成了这个:

var http = require('http'),
  url = require('url'),
  formidable = require('formidable')
  util = require('util');

var server = http.createServer().listen(8080);

server.on('request', function(request, response) {
  var form = new formidable.IncomingForm(),
    fields = [],
    files = [];

  form.on('error', function(err){
    response.writeHead(200, {'content-type': 'text/plain'});
    response.end('error:\n\n' + util.inspect(err));
  });

  form.on('field', function(field, value){
    console.log(field, value);
    fields.push([field, value]);
  });

  form.on('file', function(field, file){
    console.log(field, file);
    files.push([field, file]);
  });

  form.on('end', function(){
    console.log('-> upload done');
    response.writeHead(200, {'content-type': 'text/plain'});
    response.write('Received fields:\n\n ' + util.inspect(fields));
    response.write('\n\n');
    response.end('received files:\n\n ' + util.inspect(files));
  });

  form.encoding = 'utf-8';
  form.uploadDir = './tmp';
  form.keepExtensions = true;
  form.parse(request);
});

感谢robertklep的建议!