我正在使用MEAN.io,并尝试上传base64编码的图像。
客户端,AngularJS:
// Image we're going to send it out
var base64Image = files[i];
var file = {
image: base64Image,
type: type,
filetype: extension,
characterId: character._id
};
var newFile = new MediaSendBase64(file);
newFile.$save(function(image) {
if ( !image ) {
console.log('ERROR IMAGE');
}
else {
console.log('SUCCESS.');
console.log(image);
}
});
服务器端,NodeJS,控制器:
app.use(bodyParser.json({limit: '50mb'}));
app.use(bodyParser.urlencoded({limit: '50mb', extended: true}));
exports.uploadBase64 = function(req, res, next) {
var uploadPath = path.normalize(process.cwd() + '/packages/characters/public/assets/uploads/'),
data = new Buffer(''),
imgURL = undefined, // public URL to show the pic
type = undefined;
// In case the '/uploads' directoy doesn't exist
if( !fs.existsSync(uploadPath) ) {
fs.mkdirSync(uploadPath, 0755);
}
// Decoding the base64 image
var data = new Buffer(req.body.image, 'base64');
// Creating the name for the file --> characterId + type + timestamp + extension
var filename = req.body.characterId + '-' + req.body.type + '-' + new Date().getTime().toString() + '.' + req.body.filetype;
// Writing the image to filesystem
fs.writeFile(uploadPath + filename, data, function (err) {
if ( err ) {
console.log(err);
return res.status(500).json({
error: 'Cannot upload the image. Sorry.'
});
}
console.log('SAVED ON HD');
console.log('FINISHING');
// Sending success response
res.json({
imgURL: imgURL,
type: type
});
});
};
事情是存储在/ uploads中的文件不起作用。我无法看到图像。发送base64映像并将文件写入硬盘,但无法打开它。
出了什么问题?有什么建议吗?
谢谢!
答案 0 :(得分:3)
您可能正在尝试使用元数据保存文件。因此使得来自base64的解码数据无效。
这就是我的意思:
....
数据:image / png; base64只是meta而不是使用base64编码所以:
你需要从sting中剥离然后解码然后保存到磁盘。
我使用这个方便的功能:
function decodeBase64Image(dataString) {
var matches = dataString.match(/^data:([A-Za-z-+\/]+);base64,(.+)$/),
response = {};
if (matches.length !== 3) {
return new Error('Invalid input string');
}
response.type = matches[1];
response.data = new Buffer(matches[2], 'base64');
return response;
}
从我如何使用它开始:
var decodedImg = decodeBase64Image(imgB64Data);
var imageBuffer = decodedImg.data;
var type = decodedImg.type;
var extension = mime.extension(type);
var fileName = "image." + extension;
try{
fs.writeFileSync(".tmp/uploads/" + fileName, imageBuffer, 'utf8');
}
catch(err){
console.error(err)
}
mime是伟大的节点 - mime lib。 npm install mime。
答案 1 :(得分:0)
如果您使用快递文件上传,则可以这样做
routerApi.patch('/upload_gambar', (req, res) => {
var file_data= req.files.upload_file_name.data;
var base64Image = file_data.toString('base64');
}
如果您使用multer文件上传,则可以这样做
routerApi.patch('/upload_gambar', upload.single('upload_file_name'),(req, res) => {
var file_data= req.file.buffer
var base64Image = file_data.toString('base64');
}
答案 2 :(得分:0)
Node js base64 在与我一起读写这里代码后进行图像转换并上传到磁盘。
var imgBase64 = '';
var base64Data = imgBase64.replace(/^data:image\/png;base64,/, "");
fs.writeFile(uploadPath+"/out.png", base64Data, 'base64', function(err) {
console.log(err);
});
fs.readFileSync(base64Data, {encoding: 'base64'});