关于接口请求(application/json)跨域问题

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;

所以最后不是前端解决的,我也没有其他更好办法,有其他方法还望指教


你可能感兴趣的:(node)