TypeError: Невозможно прочитать свойство 'path' из undefined при использовании cloudinary - PullRequest
0 голосов
/ 04 июня 2019

Я пытаюсь загрузить файл с реакции на экспресс-сервер. Однако я получаю эту ошибку

TypeError: Невозможно прочитать свойство 'path' из неопределенного

Я использую реагирование для передачи / загрузки файла на сервер.

Я ссылался на аналогичный вопрос, но он не специфичен для реакции js на передачу файла

Как исправить 'TypeError: Невозможно прочитать свойство' path 'of undefined' в Nodejs (Multer)

«Реакция» показывает выбранное изображение, поэтому «Реакция» корректно загружает изображение.

маршруты / images.js

import express from 'express';
import passport from 'passport';
import multer from 'multer';
import Image from '../models/Image'
import cloudinary from 'cloudinary';
import multipart from 'connect-multiparty';
import var_dump from 'var_dump';
import dd from 'dump-die';

const multipartMiddleware = multipart();

const cloud = cloudinary.v2
const router = express.Router();

const storage = multer.memoryStorage();
const upload = multer({ storage, dest:'uploads/'}); 

const params = {
    width: 250, 
    height:250, 
}

cloudinary.config({
    cloud_name: process.env.cloudinaryName,
    api_key: process.env.cloudinaryKey,
    api_secret: process.env.cloudinarySecret,
})



router.post('/upload',  multipartMiddleware,  upload.single('image'),  (req, res) => {
    cloud.uploader.upload(req.file.path,  (err, result) => {
        // dd(req.files);
        if(err){
            return res.status(500).send(err);
        }
       console.log(result);
        debugger;
        // const img = new Image({
        //     img_url:result,
        //     image_title:null
        // });

        // console.log(img);

        // img.save().then( img => {
        //     return res.status(200).json(img);
        // });

    });
});

export default router;

реагировать

import React, { Component } from "react";
import Button from '@material-ui/core/Button';
import Grid from '@material-ui/core/Grid';
import Typography from '@material-ui/core/Typography';
import ImageUploader from 'react-images-upload';
import Axios from '../Axios';
import Image from './Image';
class Dashboard extends Component{
    constructor(){
        super()
        this.state = {
            image_url: 'http://www.conservewildlifenj.org/images/artmax_1001.jpg', 
            selectedFile: null
        }
    }
    // handleChange = file => {
    //     const img = file[0]
    //     this.setState({
    //         selectedFile: img
    //     })
    //     debugger;
    // }
    handleUpload = ( file) =>   {

        const data = new FormData()
        const image = file[0]
        const image_url = image.name
        console.log(image.name);
        console.log(this.state.selectedFile);
        data.append('file',this.state.selectedFile)
        data.append('name',image_url)
        // data.append('description', 'some value user types')
        Axios.post('/images/upload', data).then((response) => {
            console.log(response);
            debugger;
            this.setState({
                image_url: response.data.fileUrl
            })
        });
    }
    render(){
        return(
            <div>
            <Grid container justify="center" spacing={16}>
                <Grid item sm={8} md={6} style={{ margin: '40px 0px', padding: '0px 30px'}}>
                    <Typography align="center" variant="h6">
                        Welcome to the Dashboard
                    </Typography>
                    <ImageUploader
                        withIcon={true}
                        withPreview={true}
                        buttonText='Upload an image'
                        imgExtension={['.jpg', '.gif', '.png', '.gif']}
                        onChange={this.handleUpload}
                        maxFileSize={5242880}
                    />
                     <Image image_url={this.state.image_url}/>
                </Grid>
                {/* Images  */}
              </Grid>
            </div>
        )
    }
}
export default Dashboard;

1 Ответ

0 голосов
/ 04 июня 2019

Проверьте данные, которые вы отправляете в / upload.Видно, что req.file не определен.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...