sql >> Database >  >> NoSQL >> MongoDB

TypeError:pad moet een string of Buffer MEAN-stack zijn

Om een ​​bestand te uploaden moet je het in een FormData voorbeeld als volgt:

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());
        });
}

Bovendien faalt uw backend hoogstwaarschijnlijk in de volgende sectie:

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

Aangezien u nu een formulier uploadt met multipart/form-data coderen, moet u wat middleware gebruiken om het verzoek in uw backend te parseren, zoals vermeld in de expressjs-document

Je zou multer kunnen gebruiken of express-fileupload

Als je voor de tweede gaat, heb je het volgende nodig:

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')
        })
    });
});



  1. MongoDB geïnstalleerd via Homebrew werkt niet

  2. Problemen met het gebruik van MongoDB als backend voor het Django-project (Django 1.7)

  3. Mongoose-schema's maken met of zonder 'nieuw' trefwoord?

  4. Kan MongoDB /data/db-map niet maken op macOS Catalina