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;
});
相关推荐
铁皮饭盒40 分钟前
成为AI全栈 - 第4课:Drizzle ORM SQLite Elysia 数据库实战
前端·后端
ascarl201042 分钟前
Linux.do 帖子整理:AI 调用 Chrome DevTools 调试前端页面
linux·前端·人工智能
DanCheOo1 小时前
开源 | 我是怎么用 ai-memory 让 Cursor 每次开新对话都自动知道项目背景的
前端·人工智能·ai·ai编程
MPGWJPMTJT1 小时前
告别手动切换 Node 版本:从 nvm 迁移到 Volta
前端
Apifox1 小时前
Apifox 近期更新|AI Agent Debugger、A2A Debugger、Postman API 导入、Ask AI 侧边栏对话
前端·人工智能·后端
嗷o嗷o2 小时前
Android 前台服务为什么越来越难用了?很多问题不是限制多,而是你任务模型就不该用 FGS
前端
摇滚侠2 小时前
软件开发外包项目组,如何提高代码质量和开发效率
java·开发语言·前端·ide·intellij-idea
卷帘依旧2 小时前
Promise链式调用原理
前端·javascript
光影少年2 小时前
react 单向数据流理解
前端·react.js·掘金·金石计划
万少2 小时前
可以免费使用的 DeepSeek-V4-Flash,很多人还不知道!
前端