在Express Node.js中将图像文件转换为base64

Sau*_*abh 5 html javascript binary node.js express

我正在尝试将图像文件转换为bas64,因此我可以将base64字符串形式存储在mongoDB中。

这就是我试图做到的方式:

router.post('/file_upload',function(req,res){

  function base64_encode(file) {
    var bitmap = fs.readFileSync(file);
    return new Buffer(bitmap).toString('base64');
}

  var ImageFileToSave =  base64_encode(req.body.file);

  console.log(ImageFileToSave);


})
Run Code Online (Sandbox Code Playgroud)

在客户端:

<form action="/file_upload" method="POST" enctype="multipart/form-
 data">
<input type="file" name="file" />
<input type="submit" value="Upload File" />
</form>
Run Code Online (Sandbox Code Playgroud)

这是我得到的错误

TypeError:路径必须是字符串或Buffer

如何将图像文件(例如:image.jpg)转换为base64?

Fra*_*teo 6

您将需要使用Multer中间件来处理multipart/form-data

const express = require('express')
const multer  = require('multer')
const upload = multer({ dest: 'uploads/' })

const app = express()

app.post('/file_upload', upload.single('example'), (req, res, next) => {
  // req.file is the `example` file or whatever you have on the `name` attribute: <input type="file" name="example" />
  // I believe it is a `Buffer` object.
  const encoded = req.file.buffer.toString('base64')
  console.log(encoded)
})
Run Code Online (Sandbox Code Playgroud)

2018-10-24:请参阅下面的David评论。

2019-06-11:修正了基于评论的示例。确实是这样的req.file.bufferhttps : //github.com/expressjs/multer/blob/master/storage/memory.js#L8


Dav*_*nte 6

由于之前的答案对我不起作用,我正在分享另一个有效的答案。我使用multer库获取文件然后将其转换为base64

const multer  = require('multer')
const upload = multer({});

router.post('/uploadlogo', upload.single('logo'), (req, res, next) => {
    // encoded has the base64 of your file
    const encoded = req.file.buffer.toString('base64');
});
Run Code Online (Sandbox Code Playgroud)