我们知道现在我们服务端同学接收参数用的是 @RequestParam(通过字符串中解析出参数)
一般要用序列化qs.stringfy转化一下
其实还有另一种是 @RequestBody(从请求体中获取参数)。这个不用转化
有时候请求会先发送一个options预检的请求,之后再发post请求
简单请求包含:
请求方法是以下三种方法之一:
- HEAD
- GET
- POST
HTTP的头信息不超出以下几种字段:
-
Accept
-
Accept-Language
-
Content-Language
-
Last-Event-ID
-
Content-Type:只限于三个值application/x-www-form-urlencoded、multipart/form-data、text/plain
非简单请求(not-so-simple request)
复杂跨域请求要满足以下 -
请求方法不是GET/HEAD/POST 一般是put/delete
-
POST请求的Content-Type并非application/x-www-form-urlencoded, multipart/form-data, 或text/plain
-
请求设置了自定义的header字段
非简单请求是那种对服务器有特殊要求的请求,比如请求方法是PUT或DELETE,或者Content-Type字段的类型是application/json。
非简单请求的CORS请求,会在正式通信之前,增加一次HTTP查询请求,称为"预检"请求(preflight)。
"预检"请求用的请求方法是OPTIONS,表示这个请求是用来询问的。头信息里面,关键字段是Origin,表示请求来自哪个源。
浏览器先询问服务器,当前网页所在的域名是否在服务器的许可名单之中,以及可以使用哪些HTTP动词和头信息字段。只有得到肯定答复,浏览器才会发出正式的XMLHttpRequest请求,否则就报错。
解决方法待补充