一、出现Provisional headers are shown的几种可能性
- 跨域,请求被浏览器拦截
- 请求被浏览器插件拦截
- 服务器出错或者超时,没有真正的返回
- 强缓存from disk cache或者from memory cache,此时也不会显示
这几种都是前端的问题,我们都尝试了,对我们的问题没有效果
二、还是后端的锅
前端发送post请求,用的是json格式,但是没请求到后端,也没有返回状态吗,最开始以为是前端跨域问题,然后后前端大佬一起找前端的错误,尝试了网上的各种方法都没有效果,最后发现居然是后端的锅。
在filter中设置请求头的时候,没有加入content-type这个请求头,导致前端传不了json数据,因为浏览器是根据option返回的结果来确定请求参数的,所以前端浏览器发送option时,后端response的Access-Control-Allow-Headers中没有content-type,导致浏览器post请求content-type,被认为是非法的,直接浏览器拦截了(浏览器和postman这些区别就在于,浏览器在正式请求之前会发送一个option试探,通过option试探来确定需要的请求参数)。正确的设置应该为
response.setHeader("Access-Control-Allow-Origin", origin); response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE"); response.setHeader("Access-Control-Max-Age", "3600"); response.setHeader("Access-Control-Allow-Headers", "x-requested-with,Authorization,token, content-type"); //这里要加上content-type response.setHeader("Access-Control-Allow-Credentials", "true");
转载自:https://blog.csdn.net/qq_42396168/article/details/105547334