首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么服务器从用axios发出的POST http请求中得到空的request.body?

服务器从用axios发出的POST http请求中得到空的request.body的原因可能有以下几点:

  1. 请求头未设置正确的Content-Type:在使用axios发送POST请求时,需要设置正确的Content-Type头部信息,以告知服务器请求体的格式。常见的Content-Type类型有application/json、application/x-www-form-urlencoded等。如果未设置正确的Content-Type,服务器可能无法正确解析请求体,导致request.body为空。
  2. 请求体未正确序列化:在使用axios发送POST请求时,需要将请求体正确序列化为字符串。如果未进行正确的序列化,服务器可能无法正确解析请求体,导致request.body为空。常见的序列化方式有JSON.stringify()和qs.stringify()。
  3. 服务器端未正确解析请求体:服务器端需要正确解析请求体,将其转换为可读取的数据格式。常见的解析方式有body-parser中间件、express.json()等。如果服务器端未正确解析请求体,request.body可能为空。
  4. 请求体数据未正确传输:在网络传输过程中,请求体数据可能会丢失或损坏,导致服务器无法正确接收请求体数据。这可能是由于网络不稳定或其他原因引起的。可以尝试重新发送请求或检查网络连接。

综上所述,服务器从用axios发出的POST http请求中得到空的request.body可能是由于请求头未设置正确的Content-Type、请求体未正确序列化、服务器端未正确解析请求体或请求体数据未正确传输等原因导致的。在解决问题时,可以逐步排查以上可能的原因,并进行相应的调试和修复。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

全面分析前端网络请求方式

send 用于发送 HTTP请求,即调用该方法后 HTTP请求才会被真正发出,用法: xhr.send(param) param:http请求参数,可以为 string、Blob等类型。...尤雨溪在他文档推荐大家用 axios进行网络请求axios基于 Promise对原生 XHR进行了非常全面的封装,使用方式也非常优雅。...还有很多别的注意事项,这也是为什么大家现阶段还是更喜欢 axios 多一些。...fetch封装好了,可以愉快使用了。 嗯,axios真好用... 十二、跨域总结 谈到网络请求,就不得不提跨域。 浏览器同源策略限制了同一个源加载文档或脚本如何与来自另一个源资源进行交互。...它允许浏览器向跨源服务器发出 XMLHttpRequest请求。 服务端设置 Access-Control-Allow-Origin就可以开启 CORS。

1.8K40
  • axios + ajax 面试题总结

    安全性更高,客户端支持防御 XSRF,就是让你每个请求都带一个cookie拿到key, 根据浏览器同源策略,假冒网站是拿不到你cookie得key,这样,后台就可以轻松辨别出这个请求是否是用户在假冒网站上误导输入...(): 是否是一个取消请求错误 axios.all(promises): 用于批量执行多个异步请求 axios.spread(): 用来指定接收所有成功数据回调函数方法 axios为什么既能在浏览器环境运行又能在服务器...依赖于浏览器提供XMLHttpRequest对象,这个对象使得浏览器可以发出HTTP请求与接收HTTP响应。实现了在页面不刷新情况下和服务器进行数据交互。...AJAX应用和传统Web应用有什么不同 在传统Javascript编程,如果想得到服务器端数据库或文件上信息,或者发送客户端信息到服务器,需要建立一个HTML form然后GET或者POST数据到服务器端...Firefox通过newXMLHttpRequest()得到 介绍一下XMLHttpRequest对象常用方法和属性 open(“method”,”URL”) 建立对服务器调用,第一个参数是HTTP

    2.1K30

    【Node.js】 bodyparser实现原理解析

    当我们尝试从一个浏览器发来POST请求取得请求报文实体时候,这个时候,我们想,这个Koa自带ctx.body里面取出来就可以了嘛! 唉!...等等,但根据Koa文档,ctx.body等同于ctx.res.body,所以ctx.body取出来响应报文,而不是请求报文实体哦 于是这时候又打算Node文档里找找request对象有没有可以提供查询请求报文属性...最后,根据Content-Type,如application/json或'application/x-www-form-urlencoded'对4得到字符串做相应解析处理,得到最后对象,作为request.body...我们连续三次发出不同POST请求,携带不同类型body数据,看看服务端会输出什么 var iconv = require('iconv-lite'); var querystring = require...")); request({ method: 'POST', url: 'http://127.0.0.1:3000/post', headers: {//设置请求

    1.8K20

    Fetch还是Axios——哪个更适合HTTP请求

    前端开发最重要部分之一是通过发出 HTTP 请求与后端进行通信,我们有几种方法可以异步地在 Javascript 中进行 API 调用。...现在,让我们仔细看看axiosAxios 概述和语法 Axios 是一个 Javascript 库,用于 Node.js 或 XMLHttpRequests 或浏览器发出 HTTP 请求。...在 axios ,它是自动完成,所以我们只需在请求传递数据或响应获取数据。它是自动字符串化,所以不需要其他操作。 让我们看看如何 fetch() 和 axios 获取数据。...每次我们 .fetch() 方法得到响应时,我们需要检查状态是否成功,因为即使不是,我们也会得到响应。在 .fetch() 情况下,只有当请求没有完成时,promise 才会被解决。...HTTP 拦截 当我们需要检查或改变我们应用程序到服务器 HTTP 请求时,或者以其他方式,例如,为了验证,HTTP 拦截可能是重要

    4.9K20

    Python 接口测试requests.post方法data与json参数区别

    引言   在随笔分类Jmeter入门基础,分享过一篇《Jmeter处理http请求Content-Type类型和传参方式》,这篇文章主要讲述Jmeter做接口测试时,针对POST请求参数传递方式...表单提交形式,会将表单内数据转换成键值对,此时数据可以request.POST里面获取,而request.body内容则为a=1&b=2这种键值对形式。...综上所述,两种参数使用情况: data参数提交数据时,request.body内容则为a=1&b=2这种形式,json参数提交数据时,request.body内容则为'{"a": 1, "b...其实方法1和方法2是等价。报文是json字符串数据,分别以data与json两种参数形式发送请求得到请求体数据格式是一样。...总结 总而言之,记住这句话:data参数提交数据时,request.body内容则为a=1&b=2这种形式,json参数提交数据时,request.body内容则为'{"a": 1, "b"

    74230

    Ajax笔记(2) -Axios

    URL修改为: 此时网页显示数据就会变成这样: 只有5条 如果axios请求就需要加上params属性,注意post的话就用data属性 可以看到得到了5条数据 post请求 axios...body 参数 下面讲一下get和post请求区别 (参考了别人文章) Post请求和get请求区别 1.get是服务器上获取数据,post是向服务器传送数据。...3.对于get方式,服务器Request.QueryString获取变量值,对于post方式,服务器Request.Form获取提交数据。 4.get传送数据量较小,不能大于2KB。...post传送数据量较大,一般被默认为不受限制。但理论上,IIS4最大量为80KB,IIS5为100KB。 5.get安全性非常低,post安全性较高。但是执行效率却比Post方法好。...我们令查找数据id为1,可以看到就只显示了第一条数据,那我们要如何更新这条数据呢 写法: delete 也差不多, 但是要指定要删除数据 对象为对象了 批量请求数据 axios.all

    1.4K30

    目前5种最流行发送HTTP请求方法

    现代Javascript提供了许多向远程服务器发送HTTP请求方法。...原生XMLHttpRequest对象到Axios等第三方库,拥有如此丰富选择集合使得在web应用程序请求和动态加载内容比以往任何时候都更加轻松。...所以,在今天帖子,我们将讨论Javascript发送HTTP请求不同方法。语言提供本地选项开始,我们将查看以下五个模块,并使用它们发送不同类型HTTP请求。...Axios AxiosJavascript发出HTTP请求最流行第三方包之一。...SuperAgent缺点 添加一个外部依赖项,因为该模块不是本机。 不支持监听请求进度。 Ky Ky是一个相对较新Javascript包,可用于web应用程序前端发出异步HTTP请求

    3.1K20

    djangoRequest-7

    请求体 4.1 Form表单 4.2 非表单类型 请求头 其他 利用HTTP协议向服务器传参有以下几种方式 url截取 使用查询字符串 在请求体中发送数据 在http报文头 header 中发送数据...url获取截取 在定义路由规则时候,可以使用正则表达式截取数据,然后传到视图函数,在视图函数中使用参数接收。...,响应结果 beijing20171001 url截取参数不区分 get post请求方式。...QueryDict 在django HttpRequest 对象,属性 GET 和 POST 得到都是 django.http.QueryDict 所创建实例,这是django自定义一个类似字典类...请求请求体获得参数各种有多种,例如 表单,json,xml...不同格式数据要区别对待 可以发送请求体数据请求方式有POST、PUT、PATCH、DELETE。

    1.2K30

    在 JS 如何使用 Ajax 来进行请求

    在本教程,我们将学习如何使用 JS 进行AJAX调用。 1.AJAX 术语AJAX 表示 异步 JavaScript 和 XML。 AJAX 在 JS 中用于发出异步网络请求来获取资源。...当然,不像名称所暗示那样,资源并不局限于XML,还用于获取JSON、HTML或纯文本等资源。 有多种方法可以发出网络请求并从服务器获取数据。 我们将一一介绍。...2.XMLHttpRequest XMLHttpRequest对象(简称XHR)在较早时候用于服务器异步检索数据。 之所以使用XML,是因为它首先用于检索XML数据。...不需要提供这个参数来发出简单GET请求。...我个人更喜欢使用Axios API而不是fetch() API,原因如下: 为GET 请求提供 axios.get(),为 POST 请求提供 axios.post()等提供不同方法,这样使我们代码更简洁

    8.9K20

    【面试题】HTTP知识点整理(附答案)

    比如,在浏览器刚请求HTML时候就提前把可能会用到JS、CSS文件发给客户端,减少等待延迟,这被称为"服务器推送"( Server Push,也叫 Cache push) HTTP/1 几种优化可以弃...若在握手过程某个阶段莫名中断,TCP协议会再次以相同顺序发送相同数据包。 握手为什么是三次?...试想如果是两次握手,则会出现下面这种情况: 如客户端发出连接请求,但因连接请求报文丢失而未收到确认,于是客户端再重传一次连接请求。后来收到了确认,建立了连接。...参数: GET 一般放在 URL ,因此不安全,POST 放在请求,更适合传输敏感信息。 幂等: GET是幂等,而POST不是。...(幂等表示执行相同操作,结果也是相同) TCP: GET请求会把浏览器会把http header和data一次性发出去,而POST会分成两个TCP数据包,首先发Header部分,如果服务器响应100

    1.4K30

    Fetch vs Axios

    API,我们都使用Axios和Fetch这样HTTP客户端来执行此类请求。...比较Fetch和Axios特性 让我们语法开始。 语法 Fetch接收两个参数。第一个参数是我们要获取资源URL。第二个参数是可选参数,它是一个对象,包含发出请求配置项。...options }) 和fetch方法一样,我们也可以忽略axiosHTTP方法,默认为GET,就像这样: axios(url) 同样地,我们可以使用第二个参数,为请求定义一些自定义设置: axios...此时,我们没有得到我们所需要JSON数据格式,因此,我们对响应对象调用.json()方法。这将返回另一个promise,该promiseJSON形式来解决(resolved)数据。...响应超时/取消请求 让我们看看HTTP客户端针对HTTP请求,如何处理响应超时。对于Axios,我们可以在配置对象添加一个timeout属性,并指定请求终止前时间,单位为毫秒。

    1.3K10

    乐优项目:使用域名访问本地项目,实现商品分类查询,cors解决跨域,品牌查询(二)

    :决定我们GetMapping还是PostMapping请求路径:决定映射路径请求参数:决定方法参数返回值结果:决定方法返回值在刚才页面发起请求,我们就能得到绝大多数信息:请求方式:Get,插叙肯定是...它允许浏览器向跨源服务器发出XMLHttpRequest请求,从而克服了AJAX只能同源使用限制。CORS需要浏览器和服务器同时支持。目前,所有浏览器都支持该功能,IE浏览器不能低于IE10。...浏览器先询问服务器,当前网页所在域名是否在服务器许可名单之中,以及可以使用哪些HTTP动词和头信息字段。只有得到肯定答复,浏览器才会发出正式XMLHttpRequest请求,否则就报错。...post()方法第二个参数对象,就是将来要传递参数PUT和DELETE请求POST请求类似4.2.2.axios全局配置而在我们项目中,已经引入了axios,并且进行了简单封装,在src下...$http = axios,将axios赋值给了 Vue原型$http。这样以后所有的Vue实例都可以访问到$http,也就是访问到了axios了。

    8210

    Django学习笔记之Ajax与文件上传

    同步交互:客户端发出一个请求后,需要等待服务器响应结束后,才能发出第二个请求; 异步交互:客户端发出一个请求后,无需等待服务器响应结束,就可以发出第二个请求。...AJAX除了异步特点外,还有一个就是:浏览器页面局部刷新;(这一特点给用户感受是在不知不觉完成请求和响应过程) 场景: ?...-Ajax流程图 略 Ajax应用案例 1 用户名是否已被注册 在注册表单,当用户填写了用户名后,把光标移开后,会自动向服务器发送异步请求。...服务器返回true或false,返回true表示这个用户名已经被注册过,返回false表示没有注册过。客户端得到服务器返回结果后,确定是否在用户名文本框后显示“用户名已被注册”错误信息!...请求类似于下面这样(无关请求头在本文中都省略掉了): POST http://www.example.com HTTP/1.1 Content-Type: application/x-www-form-urlencoded

    1.6K10

    node后端接收到axiospost请求体为

    node后端接收到axiospost请求体为???...使用axios发送post请求,传入了Object格式参数,在node后端req.body接收到参数为,但是网页上抓包检查时,发现请求body确实是携带了参数?...于是我在页面F12进行网络抓包来查看发出request请求 抓到请求体确实携带了页面发送参数,然后我就开始意识到事情不对劲了,开始在网上搜索答案。...经过漫长网上冲浪,并查了一下axios源码,我发现axios文档上有这样一句话 这就能解释为什么我之前发obj对象数据,请求体携带的确是json格式数据,说明axios会自动转换数据为json格式后来我又在源码上看到了转换请求体参数格式相关代码...2:在node配置body-parser可以获取到除formdata之外数据 3:在node配置connect-multiparty可以所有数据 vue中使用axios发送post请求

    7210

    axios

    1 XHR 传统Ajax基于XMLHttpRequest 不多 2 JQuery ajax 我第一次接触ajax是JQuery ajax开始。...这是一个接口, 测试请求 刚才我们上面的请求请求是我本地node编写后端,如需要可自行下载 当然,不是所有人都愿意去触摸后端,那么可以使用这个网站进行测试http://httpbin.org...所以本质上请求方式都是request。因此可以 axios()这么写也就是第一种写法。 2. 并没有 axios.get 那么为什么可以使用 axios.get那?...,可以看到这四种方式是没有传入data参数只有url和config,return后面调用request函数data是config或者是对象data。...` 允许在向服务器发送前,修改请求数据 // 只能用在 'PUT', 'POST' 和 'PATCH' 这几个请求方法 // 后面数组函数必须返回一个字符串,或 ArrayBuffer,或 Stream

    4K10

    【收藏干货】axios配置大全

    ]]) 四、请求配置(request config) 以下就是请求配置选项,只有url选项是必须,如果method选项未定义,那么它默认是以GET方式发出请求 { //`url`是请求服务器地址...`选项允许我们在请求发送到服务器之前对请求数据做出一些改动 //该选项只适用于以下请求方式:`put/post/patch` //数组里面的最后一个函数必须返回一个字符串、-一个`ArrayBuffer...httpsAgent`定义了当发送http/https请求要用到自定义代理 //keeyAlive在选项没有被默认激活 httpAgent: new http.Agent({keeyAlive...data:{}, status:200, //服务器返回http状态文本 statusText:'OK', //响应头信息 headers: {}, //`config...//请求已经发出,但是服务器响应返回状态吗不在2xx范围内 console.log(error.response.data); console.log(error.response.status

    1K11
    领券