Javascript 我无法将文件上载到使用node js multer指定的目录

Javascript 我无法将文件上载到使用node js multer指定的目录,javascript,node.js,json,reactjs,mongodb,Javascript,Node.js,Json,Reactjs,Mongodb,我使用NodeJS创建了一个web服务。我创建了一个带有React界面的表单,并添加了用户信息和文件上传。我将此信息保存到mongodb。我想使用multer将文件保存到node js服务器,但没有将文件添加到我指定的目录中。我需要修理什么 路线 Server/index.js 反应侧 import React,{Component}来自'React'; 从“axios”导入axios; 类应用程序扩展了React.Component{ 建造师(道具){ 超级(道具); 此.state={ 用户

我使用NodeJS创建了一个web服务。我创建了一个带有React界面的表单,并添加了用户信息和文件上传。我将此信息保存到mongodb。我想使用multer将文件保存到node js服务器,但没有将文件添加到我指定的目录中。我需要修理什么

路线

Server/index.js

反应侧

import React,{Component}来自'React';
从“axios”导入axios;
类应用程序扩展了React.Component{
建造师(道具){
超级(道具);
此.state={
用户:[],
id:0,
名称:“”,
电子邮件:“”,
密码:“”,
img:'
}
}
componentDidMount(){
试一试{
axios.get()http://localhost:8080/api')
。然后((res)=>{
这是我的国家({
用户:res.data,
id:0,
名称:“”,
电子邮件:“”,
密码:“”,
img:'
})
})
}捕获(e){
控制台日志(e)
}
}
名称更改=事件=>{
这是我的国家({
名称:event.target.value
})
}
emailChange=事件=>{
这是我的国家({
电子邮件:event.target.value
})
}
passwordChange=event=>{
这是我的国家({
密码:event.target.value
})
}
fileSelectedHandler=event=>{
这是我的国家({
img:event.target.files[0]
})
}
提交(事件,id){
event.preventDefault();
const data=新表单数据();
data.append('name',this.state.name);
data.append('password',this.state.password);
data.append('email',this.state.email);
data.append('image',this.state.img);
如果(id==0){
轴心柱http://localhost:8080/api,则(()=>{
this.componentDidMount()
})
}否则{
轴心http://localhost:8080/api/“+id,数据)。然后(()=>{
this.componentDidMount()
})
}
}
删除用户(id){
试一试{
axios.delete('http://localhost:8080/api/“+id)
。然后((res)=>{
this.componentDidMount()
})
console.log('已成功删除')
}捕获(e){
控制台日志(e)
}
}
编辑用户(id){
试一试{
axios.get()http://localhost:8080/api/“+id)
。然后((res)=>{
console.log(res.data)
这是我的国家({
id:res.data.\u id,
名称:res.data.name,
电子邮件:res.data.email,
密码:res.data.password,
img:res.data.img.name
})
})
}捕获(e){
控制台日志(e)
}
}
render(){
返回(
this.submit(e,this.state.id)}>
人
this.nameChange(e)}type=“text”id=“自动完成输入”
className=“自动完成”必填项/>
名称
邮件
this.emailChange(e)}type=“email”id=“自动完成输入”
className=“自动完成”必填项/>
电子邮件
vpn_密钥
this.passwordChange(e)}type=“password”id=“自动完成输入”
className=“自动完成”必填项/>
密码
this.fileSelectedHandler(e)}/>

提交 发送 名称 电子邮件 密码 IMG 编辑 删除 {this.state.users.map(user=> {user.name} {user.email} {user.password} this.editUser(user.\u id)} className=“btn波浪效果波浪浅绿色”type=“提交”name=“操作”> 编辑 this.deleteUser(user.\u id)} className=“btn波浪效果波浪浅红色”type=“提交”name=“操作”> 删除 )} ); } } 导出默认应用程序;
我发现您的代码中有两个问题

在服务器端,上传的f
const express = require('express')
const User = require('../models/index')
const router = express.Router()
const multer = require('multer')

const storage = multer.diskStorage({
    destination: function(req, file, cb) {
        cb(null, './public/uploads');
    },
    filename: function (req, file, cb) {
        cb(null , file.originalname);
    }
});

const upload = multer({ storage: storage })

/* create new*/
router.post('/', upload.single('image'), (req,res)=>{

    user = new User({
        name:req.body.name,
        email:req.body.email,
        password:req.body.password,
        img: req.file
    });

    user.save(()=>{
        res.json(user)
    })
});

/* find all users */
router.get('/', (req, res) => {
    User.find({},(err,data) =>{
        res.json(data)
    })
});

/* find user by id */
router.get('/:id',(req, res) =>{
    User.findById(req.params.id, (err, data) =>{
        res.json(data)
    })
});

/* delete user by id */
router.delete('/:id',async (req, res) =>{
    await User.findByIdAndDelete(req.params.id)
    res.json({'message':'deleted'})
});

/* update */
router.put('/:id', async (req, res)=>{
    await User.findByIdAndUpdate(req.params.is, req.body)
    res.json({'message':'updated'})
});

module.exports = router;
const express = require('express');
const mongoose = require('mongoose');
const mongodb = require('mongodb');
const cors = require('cors');
mongoose.connect('mongodb://localhost:27017/admin?authSource=$[authSource] --username $[username]', {useNewUrlParser : true});
const app = express();

app.use(express.json());
app.use(cors());
app.use(express.urlencoded({extended:true}));

app.use('/api',require('./routes/index'));

const port = process.env.PORT || 8080;

app.listen(port);

module.exports =  new mongoose.model('User', newSchema);
import React, {Component} from 'react';
import axios from 'axios';

class App extends React.Component {

    constructor(props) {
        super(props);
        this.state = {
            users: [],
            id: 0,
            name: '',
            email: '',
            password: '',
            img: ''
        }
    }

    componentDidMount() {
        try {
            axios.get('http://localhost:8080/api')
                .then((res) => {
                    this.setState({
                        users: res.data,
                        id: 0,
                        name: '',
                        email: '',
                        password: '',
                        img: ''
                    })
                })
        } catch (e) {
            console.log(e)
        }
    }

    nameChange = event => {
        this.setState({
            name: event.target.value
        })
    }

    emailChange = event => {
        this.setState({
            email: event.target.value
        })
    }

    passwordChange = event => {
        this.setState({
            password: event.target.value
        })
    }

    fileSelectedHandler = event =>{
        this.setState({
            img : event.target.files[0]
        })
    }

    submit(event, id) {
        event.preventDefault();

        const data = new FormData();

        data.append('name', this.state.name);
        data.append('password', this.state.password);
        data.append('email', this.state.email);
        data.append('image', this.state.img);

        if (id === 0) {
            axios.post('http://localhost:8080/api', data).then(()=>{
                this.componentDidMount()
            })

        } else {
            axios.put('http://localhost:8080/api/'+id, data).then(()=>{
                this.componentDidMount()
            })
        }
    }

    deleteUser(id) {
        try {
            axios.delete('http://localhost:8080/api/' + id)
                .then((res) => {
                    this.componentDidMount()
                })
            console.log('Deleted successfully.')
        } catch (e) {
            console.log(e)
        }
    }

    editUser(id) {
        try {
            axios.get('http://localhost:8080/api/' + id)
                .then((res) => {
                    console.log(res.data)
                    this.setState({
                        id:res.data._id,
                        name: res.data.name,
                        email: res.data.email,
                        password: res.data.password,
                        img : res.data.img.name
                    })
                })
        } catch (e) {
            console.log(e)
        }
    }

    render() {
        return (
            <div className="row">
                <div className="col s6">
                    <form onSubmit={(e) => this.submit(e, this.state.id)}>
                        <div className="input-field col s12">
                            <i className="material-icons prefix">person</i>
                            <input value={this.state.name} onChange={(e) => this.nameChange(e)} type="text" id="autocomplete-input"
                                   className="autocomplete" required/>
                            <label htmlFor="autocomplete-input">Name</label>
                        </div>
                        <div className="input-field col s12">
                            <i className="material-icons prefix">mail</i>
                            <input value={this.state.email} onChange={(e) => this.emailChange(e)} type="email" id="autocomplete-input"
                                   className="autocomplete" required/>
                            <label htmlFor="autocomplete-input">Email</label>
                        </div>
                        <div className="input-field col s12">
                            <i className="material-icons prefix">vpn_key</i>
                            <input value={this.state.password} onChange={(e) => this.passwordChange(e)} type="password" id="autocomplete-input"
                                   className="autocomplete" required/>
                            <label htmlFor="autocomplete-input">Password</label>
                        </div>
                        <div className="input-field col s12">
                            <input type="file" name="file" onChange={(e) => this.fileSelectedHandler(e)}/>
                        </div>
                        <br/>
                        <button className="btn waves-effect waves-light right blue" type="submit" name="action">Submit
                            <i className="material-icons right">send</i>
                        </button>
                    </form>
                </div>
                <div className="col s6">
                    <table>
                        <thead>
                        <tr>
                            <th>Name</th>
                            <th>Email</th>
                            <th>Password</th>
                            <th>IMG</th>
                            <th>Edit</th>
                            <th>Delete</th>
                        </tr>
                        </thead>
                        <tbody>
                        {this.state.users.map(user =>
                            <tr key={user._id}>
                                <td>{user.name}</td>
                                <td>{user.email}</td>
                                <td>{user.password}</td>
                                <td>
                                    <img src="./public/uploads/user.img.name" width="80"/>
                                </td>
                                <td>
                                    <button onClick={(e) => this.editUser(user._id)}
                                            className="btn waves-effect waves-light green" type="submit" name="action">
                                        <i className="material-icons right">edit</i>
                                    </button>
                                </td>
                                <td>
                                    <button onClick={(e) => this.deleteUser(user._id)}
                                            className="btn waves-effect waves-light red" type="submit" name="action">
                                        <i className="material-icons right">delete</i>
                                    </button>
                                </td>
                            </tr>
                        )}
                        </tbody>
                    </table>
                </div>
            </div>
        );
    }
}

export default App;
router.post('/', upload.single('image'), (req,res)=>{
...
    const image = req.file; // req.file contains the image
    // req.body holds the other fields like name, email, ...
...
});
const data = new FormData();
data.append('image', this.state.img);
data.append('email', this.state.name);
// ... append the remaining fields
axios.post('http://localhost:8080/api', data)
.then(() => {
    this.componentDidMount()
});

// in the view also use the correct name
...
<input type="file" name="image" onChange={(e) => this.fileSelectedHandler(e)}/>
...