Koa代理问题

背景介绍:Koa.js 是一个流行的 Node.js 后端框架,它旨在提供一种更简单、更强大、更有表现力的方式来构建 Web 应用程序和 API。Koa.js 是 Express.js 的继任者,由 Express.js 的团队创建,并在许多方面提供了更现代和强大的工具。

在聊Koa的代理问题之前我先介绍一下起因。我司在做一个多项目的整合工作,就是把原先多个项目打包成一个。这就涉及到请求工具类的整合(比如Axios),每个子项目之前分别存在自己的接口地址比如A项目接口地址www.aaa.com, B项目接口地址www.bbb.com 。这里我是通过为api加不同的前缀来进行区分。

在开发阶段我们可以通过webpack-dev-server启动代理服务来搞定

js 复制代码
  devServer: {
    proxy: {
      // 设置服务器代理
      '/a': {
        target: `http://www.aaa.com`
      },
      '/b': {
        target: 'http://www.bbb.com',
      }
    }
  }

但是如果是生产环境我们应该怎么处理呢?我们可以选择通过第三方工具进行代理,如:nginx。笔者这里使用Koajs进行代理,原因是项目内部本身就存在Koa项目服务所以不需要引入额外的工具来完成代理功能。 下面我们来创建一个简单的koa应用

一、安装

Koa 依赖 node v7.6.0 或 ES2015及更高版本和 async 方法支持.

你可以使用自己喜欢的版本管理器快速安装支持的 node 版本:

ruby 复制代码
$ npm init -y
$ npm i koa
$ node my-koa-app.js

编写项目代码

js 复制代码
const Koa = require('koa');
const bodyParser = require('koa-bodyparser');
const App = new Koa();

App.use(bodyParser());

App.use(async ctx=>{
    ctx.body=ctx.request.body
})

App.listen(3000)

代码运行良好,为了进行代理 这里采用 http-proxy-middleware

js 复制代码
const Koa = require('koa');
const bodyParser = require('koa-bodyparser');
const { createProxyMiddleware } = require('http-proxy-middleware');
const App = new Koa();

const proxyMiddleware = createProxyMiddleware('/a', {
    target: 'https://v1.jinrishici.com/siji.txt',
    changeOrigin: true,
    pathRewrite: {
        '^/a': '/', // rewrite path
    },
  })

App.use(proxyMiddleware);
App.use(bodyParser());

App.use(async ctx=>{
    ctx.body=ctx.request.body
})

App.listen(3000)

不出意外的报错了,这是因为Koa 中没有 next,所以肯定会报,那要怎么解决?这里我引入了插件koa2-connect来兼容Koa。

这里采用的诗词接口是**v1.jinrishici.com/siji.txt** 代码范例如下:

js 复制代码
const Koa = require('koa');
const c2k = require('koa2-connect');
const bodyParser = require('koa-bodyparser');
const { createProxyMiddleware } = require('http-proxy-middleware');
const App = new Koa();

const proxyMiddleware = createProxyMiddleware('/a', {
    target: 'https://v1.jinrishici.com/siji.json',
    changeOrigin: true,
    secure: false,
    pathRewrite: {
        '^/a': '', // rewrite path
    },
  })

  App.use(bodyParser());
  App.use(c2k(proxyMiddleware));

App.use(async ctx=>{
    ctx.body=ctx.request.body
})

App.listen(3000)

PS 注意之前本人在项目中遇到过该方法报错的问题本人目前无法通过demo重现,项目中的解决方式是将App.use(bodyParser())放在proxyMiddleware之后

相关推荐
wuxia211812 小时前
微信小程序单击元素切换元素的显示和隐藏
javascript·微信小程序·setdata
JustHappy12 小时前
古法编程秘籍(二):什么是代码模块化?别背概念,把房间收拾明白就够了
前端·后端
小江的记录本12 小时前
【JVM虚拟机】堆内存分代模型:年轻代(Eden+Survivor)、老年代、元空间Metaspace(附《思维导图》+《面试高频考点清单》)
java·前端·jvm·后端·python·spring·面试
weixin_4713830312 小时前
图片预解码缓存
前端·浏览器缓存·图片预解码
一起学开源13 小时前
一文读懂 ReAct 范式:让 AI Agent 真正学会“思考+行动“
java·javascript·react.js·ecmascript·react·alibaba·智能体开发
郑洁文14 小时前
基于网络爬虫的Web敏感信息泄露自动化检测工具
前端·爬虫·网络安全·自动化
游九尘14 小时前
JavaScript 实现三段式版本号对比函数(app升级用)
javascript·uni-app
zhiSiBuYu051714 小时前
Claude-Code 新手极速上手指南
javascript·node.js
郑洁文15 小时前
可视化Web渗透分析工具的设计与实现
前端
罗超驿15 小时前
18.Web API 实战:元素与表单属性的获取和修改
开发语言·前端·javascript