axios增加的自定义header,后端request取不到

发布于 2022-09-04 18:19:56 字数 1202 浏览 10 评论 0

前台采用axios提交数据,采用拦截方式设置header信息

// http request 拦截器
axios.interceptors.request.use(
  config => {
    config.headers.common['MUserAgent'] = userAgent
    if (store.state.token) {
      config.headers.common['MToken'] = store.state.token
    }
    if (store.state.uid) {
      config.headers.common['UID'] = store.state.uid
    }
    return config
  },
  err => {
    return Promise.reject(err)
  })

后台spring mvc,采用filter进行权限过滤,但发现request取不到相应的header

String token = request.getHeader("MToken");

已设置了跨域

@Override
public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {
        HttpServletResponse response = (HttpServletResponse) res;
        response.setHeader("Access-Control-Allow-Origin", "*");
        response.setHeader("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS, HEAD"); // or *
        // response.setHeader("Access-Control-Max-Age", "3600");
        response.setHeader("Access-Control-Allow-Headers", "x-requested-with, Content-Type, MUserAgent, MToken, UID"); // or *
        chain.doFilter(req, res);
    }

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

離殇 2022-09-11 18:19:57

可以了,前端没问题,是后台过滤器(处理用户登录的,AuthFilter)问题,现在的处理方式是不走这个过滤器(AuthFilter)。

config.headers['MToken'] = store.state.token
风铃鹿 2022-09-11 18:19:57

@yangjiandong 你好 我也碰到了相同的问题 请问你们最后过滤器是怎么处理的 感谢

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文