ToB企服应用市场:ToB评测及商务社交产业平台

标题: axios 传递参数的方式(data 与 params 的区别与后端取值方式) [打印本页]

作者: 忿忿的泥巴坨    时间: 2022-6-23 17:02
标题: axios 传递参数的方式(data 与 params 的区别与后端取值方式)
axios 大家都非常的清楚,一个既可以用于客户端或者 服务端发送http请求的库。但是在前后端联调的时候有的时候会很难受,所以这里我来做一个总结。希望能帮助到有缘人。
  参数的传递方式

   参数传递一般有两种,一种是 使用 params, 另一种是 data的方式,有很多的时候我们看到的前端代码是这样的。
  params 是get请求会把参数放到url 中
  data 是post请求会把参数添加到请求体(body)中,如何获取请求体中的数据我后面有写到
  get 请求

  1. axios({
  2.     method: 'GET',
  3.     url: 'xxxxx',
  4.     params: param,
  5.   })
  6. 或者
  7. axios({
  8.     method: 'GET',
  9.     url: '/xxx?message=' + msg,
  10.   })
复制代码
post 请求

  1. axios({
  2.     method: 'POST',
  3.     url: '/xxxxx',
  4.     data: param,
  5.   })
  6.   或者
  7. axios({
  8.     method: 'POST',
  9.     url: '/xxxxx',
  10.     params: param,
  11.   })
复制代码
正确传递

   传递参数的解决办法分为post和get,咋们从这里来看一下
  post

   post 是大多数人会搞错的,咋们来看看。
  data 的形式

从例子中说话,使用的案例代码是post参数,并且没有做任何的转码。

  1. method: 'POST',
  2.     url: '/xxxxx',
  3.     data: param,
  4.   })
复制代码
控制台结果


   使用data传递的是一个对象,在控制台中看到的话是 request payload
  参数的view sources如下:

node 后台接收参数的方式

   这里我采用的是koa 来搭建的后台。需要使用 koa-bodyparser 这个插件来解析body 的参数
  1. import Koa from 'koa';
  2. import bodyParser from 'koa-bodyparser'
  3. const app = new Koa();
  4. // 解析body
  5. app.use(bodyParser());
  6. app.listen(9020, () => {
  7.   console.log('the server is listen 9020 port');
  8. })
复制代码
接受方式如下:

java 后台接收参数的方式

   对于 java 来说,本人并不是那么熟悉,但是知道的是。如果需要接受axios 以data 传递的参数。需要使用注解 @responseBody 并且使用的是实体类来接收的.

post data 的形式 ,不管是 哪种服务端的语言,都需要从body中获取参数。主要用于 传递 对象的参数,后台拿到的数据是一个 obj。 data 形式的数据有可以做好多事情, 文件上传表单提交
  params 的形式

这个是一个对象形式传递的,案例代码如下:

  1. axios({
  2.     method: 'POST',
  3.     url: '/xxxxx',
  4.     params: param,
  5.   })
复制代码
浏览器结果分析


查看view sourcer 如下:

node 后台接收参数的方式

   启动服务和上面一样,但是接收参数的方式有点变化
  
java 后台接收参数的方式

   使用request的可以获取到其值
  
get 请求

   get 请求不管使用哪种方式,最后的参数都会放到路径上。
使用param 只是axios帮你把这个参数进行了序列化,并且拼接在 url上面。原因的话,请查看下面
  出现两种的原因

   遇到这个问题,咋们就需要去看 axios 的源码了.这里 只会看处理参数的部分。有兴趣的自己去查看源码。
  处理data

   在axios文件中 的 core/dispatchRequest.js 中,我们可以看到 ,axois会 data
  
在 axios 的 default.js 中,有一个函数专门转换 data 参数的 。

   注意: 上面只是举例 data 传递参数的一种情况哈!其实data 也有在地址栏 上拼接的情况,或者 是文件上传的等情况。太多了,这里 只是讲清楚使用的方式。
  处理 params

   在axios文件中 的 adapt/ xhr.js 中,我们可以看到 ,axois会 params的参数放到url路径中。
  
buildUrl 一些关键代码如下 :

总结

其实前端和后端 对接参数过程,对于post请求,data 不行,那就使用 params来 进行 传递,如果都不行,那就可能后端有问题了。
彩蛋

后台测试数据可以使用 postman, 如果可以传递的参数可以调用通过。postman是可以看到请求的代码的方式的。


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4