我向Angular.js发送了一个$http.post
请求给Node.js,以获得ArrayBuffer
如下:
$http.post('/api/scholarships/load/uploaded-files', Global.user, {responseType:'arraybuffer'}).success(function(ab){
console.log(ab); // Return ArrayBuffer {}
});
然后,在Node.js中,我检索上传的文件数据并将Buffer
对象转换为ArrayBuffer
对象:
exports.loadUploadedFiles = function(req, res) {
db.UserFile.findAll().success(function(files) {
var buffer = files[0].dataValues.data; // Get buffer
var arrayBuffer = new ArrayBuffer(buffer.length); // Start transforming Buffer to ArrayBuffer
var views = new Uint8Array(arrayBuffer);
for(var i = 0; i < buffer.length; ++i) {
views[i] = buffer[i];
}
res.type('arraybuffer');
res.send(arrayBuffer); // Send the ArrayBuffer object back to Angular.js
}).error(function(err) {
console.log(err);
res.sendStatus(500);
});
};
当我尝试打印上述$http.post
的回复时,我总是ArrayBuffer{}
。我做错了什么?任何帮助将不胜感激。
答案 0 :(得分:1)
无需在服务器端创建ArrayBuffer。实际上只返回node.js中的Buffer应该没问题。 ArrayBuffer是客户端/浏览器端的一个概念,用于将来自服务器的数据解释为ArrayBuffer。你得到“ArrayBuffer {}”的原因可能是因为node.js是res.send()上的ArrayBuffer toString()因为它不理解该对象。所以试试这个
exports.loadUploadedFiles = function(req, res) {
db.UserFile.findAll().success(function(files) {
var buffer = files[0].dataValues.data; // Get buffer
res.send(buffer);
}).error(function(err) {
console.log(err);
res.sendStatus(500);
});
};