gpt4 book ai didi

javascript - 通过 Express、Axios 在 MySQL PUT 和 DELETE 上出现错误 500

转载 作者:行者123 更新时间:2023-11-29 18:04:39 25 4
gpt4 key购买 nike

我刚刚继承了一个项目,该项目是使用我不太熟悉的工具随意构建的。它使用 Express、Bookshelf 和 A​​xios 来访问 MySQL 数据库。 GET 和 PUT 的 Express 路由似乎工作得很好,但 POST 和 DELETE 都会导致错误 500。

以下是我正在使用的路由(我删除了更多可以正常工作的 GET 和 POST 路由):

import express from 'express';
import Points from '../models/points';

let router = express.Router();

// GET all points associated with a specific user AND a specific session
// This works fine.
router.get('/user/:user/session/:session', (req, res) => {
Points.query({
select: ['id', 'number', 'quadrant', 'level', 'title', 'category'],
where: {sessionId: req.params.session, userId: req.params.user}
}).fetchAll().then(point => {
res.json({point});
})
});

// POST a single point to the database.
// This works fine.
router.post('/', (req, res) => {
const {sessionId, userId, number, quadrant, level, title, category} = req.body;

Points.forge({
sessionId, userId, number, quadrant, level, title, category
}).save()
.then(user => res.json({success: true}))
.catch(err => res.status(500).json({error: err}));
});

// PUT (update) an existing point
// Doesn't work right now (500)
router.put('/edit/:identifier', (req, res) => {
Points.update({
set: {title: req.params.title},
where: {id: req.params.identifier}
}), function (err, point) {
if (err) {
return res.send(err);
}
res.json({message: 'Updated'});
};
});

// DELETE a point by id
// Doesn't work right now (500)
router.delete('/delete/:identifier', (req, res) => {
Points.remove({
id: req.params.identifier
}), function (err, point) {
if (err) {
return res.send(err);
} else {
res.json({message: 'Deleted'});
}
};
});

export default router;

以下是与上述路由相对应的 Redux 操作:

import axios from 'axios';


export function getPointsByUserAndSession(data) {
return dispatch => {
return axios.get('/api/points/user/'+data.user+'/session/'+data.session)
}
}

export function addPoint(data) {
return dispatch => {
return axios.post('/api/points', data)
}
}

export function editPointById(data) {
return dispatch => {
return axios.put('/api/points/edit/' + data.id)
}
}

export function deletePointById(identifier) {
return dispatch => {
return axios.delete('/api/points/delete/' + identifier)
}
}

最佳答案

使用以下代码启用 CORS:

 router.use((req, res, next) => {
res.header('Access-Control-Allow-Origin', '*');
res.header('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept, x-access-token');
res.header('Access-Control-Allow-Methods', 'GET, POST,OPTIONS, DELETE, PATCH, PUT');
next();
});

关于javascript - 通过 Express、Axios 在 MySQL PUT 和 DELETE 上出现错误 500,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47994009/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com