我正在尝试在Web API中读取图像流。
以下是我的代码。
var express = require('express');
var bodyParser = require('body-parser');
var app = express();
var Busboy = require('busboy');
app.use(bodyParser.json());
app.get('/', function(req, res) {
res.send('Hello World!');
});
app.post('/', function(req, res){
var busboy = new Busboy({
headers: request.headers
});
busboy.on('file', function(fieldname, file, filename, encoding, mimetype) {
console.log('File [' + fieldname + ']: filename: ' + filename + ', encoding: ' + encoding + ', mimetype: ' + mimetype);
file.on('data', function(data) {
console.log('File [' + fieldname + '] got ' + data.length + ' bytes');
});
file.on('end', function() {
console.log('File [' + fieldname + '] Finished');
});
});
});
app.listen(3000, function() {
console.log('Example app listening on port 3000!');
});
当我使用邮递员测试以上发布端点时,什么都没有发生。
似乎busboy.on从未被调用/触发过。
Busboy npm https://www.npmjs.com/package/busboy#readme
以下是我的要求。通过提琴手追踪。
POST http://localhost:3000/ HTTP/1.1
Host: localhost:3000
Connection: keep-alive
Content-Length: 879585
Postman-Token: 1defded8-01ff-eb6e-4afa-c49f63b477db
Cache-Control: no-cache
Origin: chrome-extension://fhbjgbiflinjbdggehcddcbncdddomop
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.99 Safari/537.36
Content-Type: multipart/form-data; boundary=----WebKitFormBoundarySrX3beIdojsVD2nB
Accept: */*
Accept-Encoding: gzip, deflate, br
Accept-Language: en-US,en;q=0.8,fr-CA;q=0.6,fr;q=0.4
------WebKitFormBoundarySrX3beIdojsVD2nB
Content-Disposition: form-data; name="File"; filename="Chrysanthemum.jpg"
Content-Type: image/jpeg
最佳答案
似乎您已经在使用busboy,但我仍然建议您尝试multer,诸如boundry&multipart之类的东西不会打扰您。
但是,如果您想自己打包busboy,则在multer中使用these code也会很有用。
还记得检查this out。也许您可以覆盖邮递员中的Content-Type,这不是必需的。