vue-cli 项目,页面写完,和后台调试接口时,之前的传参都是简单的字符串形式(据说后台也是string 来接收参数,我也搞不懂);
例如:
var querystring = require("querystring");
var data = {};
data.a = "4";
data.b = "5";
var sendData = queryString.stringify(data);
//经过console,发现变成字符串形式-a=4&b=5
页面post传参时,只需将sendData 传给后台,接口即可调通;
但是后台将入参改为json形式后,同时需要传递的数据格式也变成多级。例如:
var data = {};
data.a = "4";
data.b = {
c:"2",
d:"3"
}
我同样尝试用queryString来解析发现接口报415错误,同时querystring 出来它并不能解析第二层的data.b,为 a=4&b= ;
入参肯定不对;
1、又使用var sendData = JSON.stringify(data);
将json 变为字符串形式,入参到是全了,但是请求依然是415;
2、将content-type改为 application/json.结果只要一修改,post请求就变成了options请求,报403,查阅资料原来是跨域时,conetnt-type是这种类型,属于浏览器复杂请求,会先发送一次options请求,同意后才继续发送post请求
解决方案:
1、本来想在本地自己建一个node服务,我本地请求自己的node服务,node服务充当中间层,转发请求到另一个服务端,这样就不会是跨域问题,但显然各种搜资料,自己尝试用express框架搭建了一个node服务,监听端口号,但也是直接把请求参数和地址接口写在node中请求亲测可以拿到数据,再通过res.sendData()将数据返回。但显然比较麻烦,没有达到实现简单请求转发的功能,可是自己也没学过node,时间有限,只能搁置;
2、据说后台java端配置解决了问题,附上地址;
https://www.waitig.com/spring-boot-cros%E8%A7%A3%E5%86%B3%E8%B7%A8%E5%9F%9F%E9%97%AE%E9%A2%98%E4%B8%83.html;
所以最后不是前端解决的,我也没有其他更好办法,有其他方法还望指教