Отправка html2pdf сгенерированного PDF обратно на сервер - PullRequest
0 голосов
/ 03 сентября 2018

Я должен отправить PDF, сгенерированный на стороне клиента, используя html2pdf на сервер. Мне удалось преобразовать сгенерированный PDF в base64 и хочу отправить его обратно, используя axios. Вот мой код на стороне клиента:

  function myFunction(){
           var element = document.getElementById('element-to-print');
           html2pdf().from(element).outputPdf().then(function(pdf) {
    //Convert to base 64
            const newpdf=btoa(pdf);
            console.log(newpdf)
            var formData = new FormData();
            formData.append("uploadedFile", newpdf);
            axios.post('/upload',formData).then(res => { console.log(res) }).catch(error => {
            console.log(error.response)
        })
    });

Вот мой код на стороне сервера:

app.post('/upload', fileUpload(), function(req, res) {  
  const sampleFile = req.files.uploadedFile;
  // do something with file
  res.send('File uploaded');
})

Я думаю, что проблема на стороне клиента, поскольку я получаю версию base64 моего преобразованного pdf на своей консоли, но после этого я получаю ошибку:

POST http://localhost:3000/upload 500 (внутренняя ошибка сервера)

Как мне решить эту проблему? Спасибо.

1 Ответ

0 голосов
/ 03 сентября 2018

Для FormData в express вы должны использовать промежуточное программное обеспечение, такое как Multer

и ваш код будет выглядеть так:

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

var app = express()

app.post('/upload', upload.single('uploadedFile'), function (req, res, next) {
  // req.file is the `avatar` file
  // req.body will hold the text fields, if there were any
})
...