MongoDB
 sql >> Datenbank >  >> NoSQL >> MongoDB

TypeError:path muss ein String oder Buffer MEAN Stack sein

Um eine Datei hochzuladen, müssen Sie sie in FormData einschließen Instanz wie folgt:

interface Profile {
   photo: File;
}

updatePhoto(profile: Profile, id: string) {
    const body = new FormData();
    body.append('photo',profile.photo);
    return this.http.post(`http://localhost:3000/profile/photo/${id}`, body,)
        .map((response: Response) => response.json())
        .catch((error: Response) => {
            return Observable.throw(error.json());
        });
}

Außerdem schlägt Ihr Backend höchstwahrscheinlich im folgenden Abschnitt fehl:

user.img.data = fs.readFileSync(req.body.photo);

In Anbetracht dessen, dass Sie jetzt ein Formular mit multipart/form-data hochladen Codierung müssen Sie Middleware verwenden, um die Anfrage in Ihrem Backend zu parsen, wie in expressjs-Dokument

Sie könnten multer verwenden oder express-fileupload

Wenn Sie sich für die zweite entscheiden, benötigen Sie Folgendes:

const fileUpload = require('express-fileupload');

router.use(fileUpload());// use express-fileupload as default parser for multipart/form-data encoding

router.post('/photo/:id', (req, res) => {
User.find({ _id: req.params.id })
    .exec((err, user) => {
        if (err) {
            return res.status(500).json({
                title: 'An error occured',
                error: err
            });
        }
        user.img.data = req.files.photo.data;
        user.img.contentType = 'image/png';
        user.save((err, obj) => {
            if (err) {
                throw err
            }
            console.log('success')
        })
    });
});