request method ‘DELETE‘ is not supported问题

1.问题描述

在采用spring boot 3.0 以上 + Vue3开发引应用时,前端发起删除请求,后端提供了对应删除接口情况下,删除业务失败,并提示request method 'DELETE' is not supported.

2.问题分析

首先,如果碰到类似问题,首先考虑后端代码cotroller层是否提供了对应的接口方法,然后依次往后查看相关业务的代码,如果发现没有问题,那么可能是前端发起请求时,传递参数不规范或者是其他问题。

3.当前场景

后端接口代码

java 复制代码
@RestController
@RequestMapping("/category")
public class CategoryController {
	/**
     * 删除文章分类
     * @param id  分类id
     * @return 返回状态
     */
    @DeleteMapping("/{id}")
    public Result<Category> deleteCategory(@PathVariable("id") Integer id) {
        categoryService.delCategoryService(id);
        return Result.success();
    }

}

前段请求代码

javascript 复制代码
/**
 * 删除分类
 *
 * @param id 分类ID
 * @returns 返回Promise对象,表示异步请求的结果
 */
export const delCategory=(id)=>{
  return request.delete('/category?id='+id) //注意这一行⭐
}

而问题恰恰就出在这一行,当我们使用了 @DeleteMapping("/{id}"),这意味着你不需要在 URL 中显式地添加 ?id= 参数,而是通过路径变量 {id} 来获取 ID

4.问题解决

javascript 复制代码
export const delCategory=(id)=>{
  return request.delete('/category/'+id) //注意这一行,与前面对比 ⭐
}

5.写在最后

可能在大家看来,这都是低级错误,但是需要考验细心,希望对大家有一定的启发,感谢评论+转发!!!

相关推荐
一叶飘零_sweeeet8 分钟前
吃透 Spring 体系结构
java·spring
隔壁阿布都9 分钟前
使用LangChain4j +Springboot 实现大模型与向量化数据库协同回答
人工智能·spring boot·后端
2401_8370885023 分钟前
简要总结 HashSet 和 HashMap(Java)
java·开发语言
毕设源码-钟学长42 分钟前
【开题答辩全过程】以 基于Java的家政服务管理系统的设计与实现为例,包含答辩的问题和答案
java·开发语言
小白学大数据1 小时前
Java 爬虫对百科词条分类信息的抓取与处理
java·开发语言·爬虫
古城小栈1 小时前
Spring Boot 数据持久化:MyBatis-Plus 分库分表实战指南
spring boot·后端·mybatis
悟能不能悟1 小时前
springboot全局异常
大数据·hive·spring boot
Coder_Boy_2 小时前
Spring 核心思想与企业级最佳特性(实践级)事务相关
java·数据库·spring
+VX:Fegn08952 小时前
计算机毕业设计|基于springboot + vue宠物寄养系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计·宠物
历程里程碑2 小时前
hot 206
java·开发语言·数据结构·c++·python·算法·排序算法