nodejs 代理中间件 http-proxy-middleware

前言

平时用 express 编写服务端比较多,介绍一下代理中间件 http-proxy-middleware ,结合 express 使用非常方便,我们可以将请求转发去别的地址进行反馈。

本文做简单使用记录与案例,想了解更多配置可以移步npm:http-proxy-middleware

服务端

  1. 我们引入了 cors 解决一下跨域问题,因为今天研究的是服务端的请求代理,所以我们不要把关注点放在解决前后端跨域的代理上。

  2. 可以将 config 单独编写为一个文件导入,这里为了方便阅读就写在这里了。

  3. Object.entries(config.proxy).forEach(([path, pathConfig]) 这里的 pathpathConfigproxy 里面的所有键值对,也就是代理路径和代理配置,遍历对象的语法不理解可以阅读:js 遍历对象方法大全

import {createProxyMiddleware} from 'http-proxy-middleware'
import express from 'express'
import cors from 'cors'

const app = new express()
app.use(cors())

// 可以将 config 单独编写为一个文件导入,这里为了方便阅读就写在这里了
const config = {
    proxy: {
        '/api': {
            'target': 'https://unidemo.dcloud.net.cn/api/news',
            'changeOrigin': true,
            'pathRewrite': {'^/api': ''},
        }
    }
}

if (config.proxy) {
    // path与pathConfig是proxy里面的所有键值对,也就是代理路径和代理配置
    Object.entries(config.proxy).forEach(([path, pathConfig]) => {
        const target = pathConfig.target;
        if (target) {
            app.use(
                path,
                createProxyMiddleware(path, pathConfig),
            );
        }
    });
}

app.listen(3000, () => {
    console.log('服务器开启')
})
$ node app.js
服务器开启中

客户端

  1. 这里请求服务端地址的 /api ,可以发现我们并没有编写该服务,但是却得到了数据,就是因为服务端将 /api 请求转发到了 https://unidemo.dcloud.net.cn/api/news
  2. fetch 请求使用语法不会请阅读这篇:fetch异步请求使用详解
<body>
<script>
    const getData = async () => {
        const response = await fetch('http://localhost:3000/api')
        const data = await response.json()
        console.log(data)
    }
    getData()
</script>
</body>

请添加图片描述

尾言

如果觉得文章对你有帮助的话,欢迎点赞收藏哦,有什么错误或者意见建议也可以留言,感谢~

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

在下月亮有何贵干

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值