您的位置:首页 > 汽车 > 新车 > 关注公众号赚钱_logo设计公司介绍_宁波网站推广制作_网络营销毕业论文8000字

关注公众号赚钱_logo设计公司介绍_宁波网站推广制作_网络营销毕业论文8000字

2025/6/21 8:35:07 来源:https://blog.csdn.net/sxf359/article/details/147115915  浏览:    关键词:关注公众号赚钱_logo设计公司介绍_宁波网站推广制作_网络营销毕业论文8000字
关注公众号赚钱_logo设计公司介绍_宁波网站推广制作_网络营销毕业论文8000字

后端接口地址:

/api/Menu/GetMenuPageList

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

 [HttpPost][Route("GetMenuPageList")]public JsonResult GetMenuPageList(MenuDTO request, int pageIndex, int pageSize)

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

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

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接口获取菜单列表语句:

 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方法:

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方法为:

case 'POST_JSON':return _axios.post(url, params, config);

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

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

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

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com