sql >> Databasteknik >  >> NoSQL >> MongoDB

TypeError:sökvägen måste vara en sträng eller buffert MEAN-stack

För att ladda upp en fil måste du slå in den i en FormData instans enligt följande:

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

Dessutom misslyckas din backend med största sannolikhet i följande avsnitt:

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

Med tanke på att du nu laddar upp ett formulär med multipart/form-data kodning, måste du använda en del mellanprogram för att analysera begäran i din backend som anges i expressjs doc

Du kan använda multer eller express-fileupload

Om du går med den andra behöver du följande:

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. Beräkna avstånd i Java med MongoDB

  2. mongodb tillämpa sortering på sökresultat

  3. Map-Reduce för att kombinera data (MongoDb)

  4. Hur man kodar MongoDB foreach Query i PHP