Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Webpack 如何配置代理? #121

Open
xuya227939 opened this issue Jun 10, 2021 · 0 comments
Open

Webpack 如何配置代理? #121

xuya227939 opened this issue Jun 10, 2021 · 0 comments
Labels
Question 遇到的一些问题,怎么处理的。 Technology 技术分享 Webpack

Comments

@xuya227939
Copy link
Owner

xuya227939 commented Jun 10, 2021

前言

Webpack 提供的 devServer 配置,使我们可以非常方便的设置请求代理目标,通过改配置,有时候可以帮我们解决本地环境的跨域问题。

正向代理

当拥有单独的 API 后端开发服务器并且希望在同一域上发送 API 请求时,代理某些 URL 可能会很有用。

webpack.dev.js

devServer: {
    // ...
    proxy: {
        '/api2': {
            target: 'http://192.168.10.183:8103',
            changeOrigin: true
        }
    }
},

axios:

axios({
    baseURL: '/api2/',
    url: '/user/login',
    method: 'GET'
})

配置 proxy,本地环境中的请求,以 /api 开头的,都会把请求代理转发到 target 目标中,但是在浏览器中查看 network,发现请求依旧没有改变,实际上可以看到控制台打印或看后端 log,请求已经转发。

image

proxy,仅针对本地环境有效,对线上环境无效,一般线上环境是通过 Nginx 做转发。

反向代理

当需要对域名进行校验,比如企业微信或微信公众号的一些可信域名配置,需要通过域名来访问,会非常有用。

编辑你的本地hosts,是本地转发到指定域名,这里不要带端口号,如果有端口号,输入域名的时候,带上端口号。

127.0.0.1	order.downfuture.com

B A CLATTE zsx-test ikandy cn8080commonIndex html#userlogin

如果访问报这个错误,需要在

devServer: {
    // ...
    disableHostCheck: true
},

配置完之后,本地启动开发服务,输入域名和端口号跳转页面,则可以看到修改了,受缓存影响,最好用无痕浏览器噢。

@xuya227939 xuya227939 added Question 遇到的一些问题,怎么处理的。 Technology 技术分享 Webpack labels Jun 10, 2021
@xuya227939 xuya227939 changed the title Webpack 如何配置反向代理? Webpack 如何配置代理? Jun 18, 2021
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Question 遇到的一些问题,怎么处理的。 Technology 技术分享 Webpack
Projects
None yet
Development

No branches or pull requests

1 participant