问题来源: 在使用axios时,和java联调,发现调接口服务器始终拿不到参数data,但是检查network也的确传了data,才有了该文章。
基于 vue-axios 和 $.ajax 两种请求方式中数据传输的思考
以java为例,数据传输的起源:
一开始,Java为了实现前后端通信,在http协议允许下,制定了数据传输必须遵守的规则:
1) 数据传输 仅允许 以 字符串 或者 二进制流数据的方式传输, number object等格式 都不允许。
2) 规定了字符串数据传输的内容类型格式,即content-type,有以下几种:
a) 底层的xmlhttprequest 默认的Content-Type 是 text/plain;charset=UTF-8
即: 数据可以为 “aaaa” , “[12313],{dsafdsafsd:12313}”
b) 原生的Form表单提交, 对 xmlhttprequest 的字符串数据加了规则校验,
即 字符串数据 必须以key-value的方式存在,以便区分参数,于是键值对的概念出现了。
键值对以 & 隔开, 如: username=1111 & password=2222
为了和 以前的数据类型区分,则修改 Content-Type 为 application/x-www-form-urlencoded
并且以 input 的 name 为 键,value为值, 多个 input 以 & 隔开