vue项目调用netcore webapi接口提示:400 Bad Request的解决

后端接口地址:

/api/Menu/GetMenuPageList

后端接口既有requestParams参数,也有requestBody参数

cs 复制代码
 [HttpPost]
 [Route("GetMenuPageList")]
 public JsonResult GetMenuPageList(MenuDTO request, int pageIndex, int pageSize)

使用post请求,这里request不需要使用 FromBody 标签

原来的获取菜单列表语句是如此写的:

TypeScript 复制代码
return http
      .request<MenuProps[], Response<MenuProps[]>>(Api.getMenuPageList, 'POST',{"pageIndex":1,"pageSize":10},{'data':{"parentId": 1,"name":""}})

出现了400 bad request错误

打开chrome的网络标签,在webapi预览项中发现如下错误:

The request field is required.

网上搜索,多次尝试,终于找到适合的方法

新的webapi接口获取菜单列表语句:

TypeScript 复制代码
 return http.request<MenuProps[], Response<MenuProps[]>>(Api.getMenuPageList+'?pageIndex=1&pageSize=10',"post_json",{'parentId': 0, 'name': ''} )
 .then((res) => {

此处request方法中method参数必须使用post_json形式,如果使用post。也会报 400错误,bad request

这里的post_json是程序自定义的method类型。具体所作的处理如下:

post形式,根据方法类型调用了axios的post方法:

TypeScript 复制代码
case 'POST':
          return _axios.post(url, toUrlencoded(params), config);

function toUrlencoded(params?: Record<string | number, any>) {
  const urlencoded = new URLSearchParams();
  for (const key in params) {
    if (params[key] !== undefined) {
      urlencoded.append(key, params[key]);
    }
  }
  return urlencoded;
}

这里可见,对传递进来的requestbody对象:{'parentId': 0, 'name': ''},做了编码处理

而post_json形式调用所调用的axios的post方法为:

TypeScript 复制代码
case 'POST_JSON':
          return _axios.post(url, params, config);

对传递的 requestbody对象:{'parentId': 0, 'name': ''}未做任何处理。因为 {'parentId': 0, 'name': ''}此对象本身就是json格式,不进行任何处理就能够使用。反而使用toUrlencoded进行处理后却会造成问题,不再是标准的json对象了。

400错误时候载荷标签的参数解析结果:

200正确获取页面载荷标签解析结果:

相关推荐
原则猫17 分钟前
前端基础大厦
前端
陈随易1 小时前
编程语言级别的Skill市场,AI Agent 的未来形态
前端·后端·程序员
SoaringHeart2 小时前
Flutter进阶:基于 EasyRefresh 的下拉刷新封装 n_easy_refresh_mixin.dart
前端·flutter
IT_陈寒4 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
子兮曰5 小时前
Agency-Agents 深度解析:400+ AI 专家的"梦之队"如何重塑开发工作流
前端·后端·vibecoding
竹林8185 小时前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
karry_k6 小时前
MyBatis批量insert-select踩坑:useGeneratedKeys=true 可能让PostgreSQL返回大量插入结果
java·后端
妙码生花6 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
karry_k6 小时前
PostgreSQL 在 MyBatis 中执行正常 SQL 失效:一次 DELETE USING 踩坑记录
java·后端
Awu12276 小时前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude