admin管理员组文章数量:1794759
解决The value of the ‘Access
1.问题描述:
前台vue项目中需要在request_header中传cookie给后台 但是控制台报错如下;
Access to XMLHttpRequest at ‘192.168.0.230:9800/v1/user/wwwlogin’ from Origin ‘192.168.0.230:8888’ has been blocked by CORS policy: response to preflight request doesn’t pass access Control check: The value of the ‘Access-Control-Allow-Origin’ header in the response must not be the wildcard ‘*’ when the request’s credentials mode is ‘include’. The credentials mode of requests initiated by the XMLHttpRequest is controlled by the withCredentials attribute.
2.问题分析:跨域配置修改: 通过动态的获取origin,可解决此问题
res.addHeader("Access-Control-Allow-Origin", req.getHeader("origin"));springboot完整的跨域配置:
package com.cxstar.dao.data.config; import org.springframework.stereotype.Component; import javax.servlet.*; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.IOException; /** * 单机测试时如果有跨域问题,就用这个Filter解决,把@Component前的注释移除即可 * 如果是在微服务中,跨域问题在网关层进行了解决,服务没必要再次进行处理,把@Component注释掉即可 */ @Component public class CORSFilter implements Filter { @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletResponse res = (HttpServletResponse) response; HttpServletRequest req = (HttpServletRequest) request; res.addHeader("Access-Control-Allow-Credentials", "true"); res.addHeader("Access-Control-Allow-Origin", req.getHeader("origin")); res.addHeader("Access-Control-Allow-Methods", "GET, POST, DELETE, PUT"); res.addHeader("Access-Control-Allow-Headers", "Content-Type,X-CAF-Authorization-Token,sessionToken,X-TOKEN,customercoderoute,authorization,conntectionid,Cookie"); if (((HttpServletRequest) request).getMethod().equals("OPTIONS")) { response.getWriter().println("ok"); return; } chain.doFilter(request, response); } @Override public void destroy() { } @Override public void init(FilterConfig filterConfig) throws ServletException { } }本文标签: Access
版权声明:本文标题:解决The value of the ‘Access 内容由林淑君副主任自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.xiehuijuan.com/baike/1686961914a122699.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论