delete请求,express获取req.body失败

使用 Express 框架处理 DELETE 请求时,通常情况下是不会有请求体的。DELETE 请求通常用于删除资源,而不是发送数据。因此, Express 默认情况下不会解析 DELETE 请求的请求体。

如果需要在 DELETE 请求中发送数据,一种常见的做法是将数据作为 URL 参数或请求头的一部分发送,而不是在请求体中。可以在 URL 参数中包含数据,或者使用自定义的请求头来传递信息。

1、在前端代码中使用 Axios 发送 DELETE 请求,并在 URL 参数中包含数据

javascript 复制代码
axios.delete('/api/resource', {
  params: { key: 'value' }
})
  .then(response => {
    // 处理响应
  })
  .catch(error => {
    // 处理错误
  });

然后,在 Express 后端中,可以通过 req.query 访问 URL 参数:

javascript 复制代码
app.delete('/api/resource', (req, res) => {
  const data = req.query;
  // 处理数据
  res.send('DELETE 请求处理成功');
});

2、使用路径参数传递数据

javascript 复制代码
axios.delete('/api/resource/data值', {
})

然后,在 Express 后端中,可以通过 req.params 获取路径参数:

javascript 复制代码
app.delete('/api/resource/:id', (req, res) => {
  const data = req.params;
  res.send('DELETE 请求处理成功');
});
javascript 复制代码
例如要传递的数据为id:"323"
请求:axios.delete('/api/resource/323', {
})
接收:app.delete('/api/resource/:id', (req, res) => {
  const id= req.params.id;
});
相关推荐
学嵌入式的小杨同学1 小时前
从零打造 Linux 终端 MP3 播放器!用 C 语言实现音乐自由
linux·c语言·开发语言·前端·vscode·ci/cd·vim
weixin_425543731 小时前
TRAE CN3.3.25 构建的Electron简易DEMO应用
前端·typescript·electron·vite·nestjs
Mr Xu_2 小时前
【Vue3 + ECharts 实战】正确使用 showLoading、resize 与 dispose 避免内存泄漏
前端·信息可视化·vue·echarts
0思必得02 小时前
[Web自动化] Selenium设置相关执行文件路径
前端·爬虫·python·selenium·自动化
雯0609~3 小时前
hiprint:实现项目部署与打印1-官网提供普通html版本
前端·html
不绝1913 小时前
UGUI——进阶篇
前端
Exquisite.3 小时前
企业高性能web服务器(4)
运维·服务器·前端·网络·mysql
2501_944525544 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 账户详情页面
android·java·开发语言·前端·javascript·flutter
2601_949857434 小时前
Flutter for OpenHarmony Web开发助手App实战:快捷键参考
前端·flutter
wangdaoyin20104 小时前
若依vue2前后端分离集成flowable
开发语言·前端·javascript