vue proxyTable

作者: 一碗米粉的故事 | 来源:发表于2019-10-25 19:26 被阅读0次

    webpack配置接口地址代理

    我们打开下面路径的文件

    config/index.js

    在其中的dev对象里面找到:proxyTable: {}

    这里就是配置代理的地方,我们进行如下设置:

    module.exports = { // ...
    dev: { // 代理配置表,在这里可以配置特定的请求代理到对应的API接口
    proxyTable: { '/api': {
    target: 'http://www.xxx.com', // 你接口的域名
    secure: false, // 如果是https接口,需要配置这个参数为true
    changeOrigin: true, // 如果接口跨域,需要进行这个参数配置为true
    }
    },
    }
    }

    接口地址原本是 /save/post,但是为了匹配代理地址,在前面加一个 /api, 因此接口地址需要写成这样的即可生效 /api/save/post

    即:前端本地启动接口为:http://localhost:8080/api/save/post,转发的代理接口为:http://www.xxx.com/api/save/post,其中的/api为匹配项。

    /api 是本地路径和后端接口路径的匹配前缀,若后端接口给了/api这个前缀,可用上面的写法。

    若后端前缀不统一,则可继续添加,写法如下:

    module.exports = { // ...
    dev: { // 代理配置表,在这里可以配置特定的请求代理到对应的API接口
    proxyTable: { '/api': {
    target: 'http://www.xxx.com', // 你接口的域名
    secure: false, // 如果是https接口,需要配置这个参数为true
    changeOrigin: true, // 如果接口跨域,需要进行这个参数配置为true
    }, '/api': {
    target: 'http://www.xxx.com', // 你接口的域名
    secure: false, // 如果是https接口,需要配置这个参数为true
    changeOrigin: true, // 如果接口跨域,需要进行这个参数配置为true
    }
    },
    }
    }

    那么还有一种情况,是后端的接口没有我们想要的匹配项(前缀)'/api',是直接的http://www.xxx.com/save/post,这样的接口,我们就要用到pathRewrite来重写地址,将本地路径上的带匹配前缀的路径:http://localhost:8080/api/save/post上的前缀'/api'转成 ‘ / ’。以下第一种是网络上大部分推荐的,但是我亲测是无效的,估计他们多数用的上面的方法,没有实际使用下面的方法,LZ用以下第一种方法折腾了2天无果,后去看了webpack-dev-server的issue,无意义试通了接口,即下面第二种方法,当然也不排除第一种方法是我的版本问题而没有效果,所以如果大家试了第一种方法有效就当我的方法没说,如果无效,不妨试试我的第二种方法:

    第一种方法(网上写的方法)

    module.exports = { // ...
    dev: { // 代理配置表,在这里可以配置特定的请求代理到对应的API接口
    proxyTable: { '/api': {
    target: 'http://www.xxx.com', // 你接口的域名
    secure: false, // 如果是https接口,需要配置这个参数为true
    changeOrigin: true, // 如果接口跨域,需要进行这个参数配置为true
    pathRewrite: { '^/api': '/' }
    }
    },
    }
    }

    第二种方法(亲测有效的方法)

    module.exports = { // ...
    dev: { // 代理配置表,在这里可以配置特定的请求代理到对应的API接口
    proxyTable: { '/api/*':{
    target: "http://XXX.XXX.com/api",
    changeOrigin: true,
    pathRewrite: {'/api':'/'}
    }
    },
    }
    }</pre>

    相关文章

      网友评论

        本文标题:vue proxyTable

        本文链接:https://www.haomeiwen.com/subject/madsmctx.html