猿问

@nuxtjs/axios 模块如何配置跨域

想跨域调用一个接口,按照官方文档, nuxt.config.js中配置如下:

  modules: ['@nuxtjs/axios'],  axios: {    proxy: true,    baseURL: 'http://localhost:8000/api',    // prefix: '/api', // it not work
    credentials: true,
  },  proxy: {    '/api/douban': {      target: 'https://api.douban.com/v2/book/search',      changeOrigin: true,      pathRewrite: { '^/api': '' },
    },
  },

调用部分代码:

    async search({ commit, state }, data) {      const res = await this.$axios.$get('/douban/book/search', { params: data });
      commit('SET_BOOK_QUERY', res);      return res;
    },

但是不起作用,在http-proxy-middleware包中增加如下日志:

  function shouldProxy (context, req) {    var path = (req.originalUrl || req.url)    console.log('shouldProxy  path:', context, path);// 输出:shouldProxy  path: /api/douban /admin/tag
    return contextMatcher.match(context, path, req)
  }

说明配置确实被正确初始化了,问题是只有刷新页面进行服务端渲染时才有这个日志,这时的path是页面路由而不是api请求,而页面上的请求却没有被代理。
很奇怪,不知道是哪里配置有问题,请各路大神帮忙。


胡子哥哥
浏览 3597回答 1
1回答
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答