node,koa2实现nginx服务器代理功能

文章目录

  • vue项目打包,api设置为替换api


一、vue项目打包,api设置为替换api

             那么调用接口的时候默认是本地调用,这个时候部署到node上的项目会自己调用自己的资源,那么是调用不到的

二、使用koa2的koa2-proxy-middleware功能进行代理操作

        一定不要使用koa-bodyparser,那么请求转发只能转发请求get,post无效也可能会503

const Koa = require('koa')
const app = new Koa()
const views = require('koa-views')
const json = require('koa-json')
const onerror = require('koa-onerror')
const logger = require('koa-logger')
const fs = require("fs");
const path = require("path");
const proxy = require('koa2-proxy-middleware');
// error handler
onerror(app)

// middlewares
app.use(json())
app.use(logger())
app.use(require('koa-static')(__dirname + '/public'))

app.use(views(__dirname + '/views', {
  extension: 'pug'
}))

const options = {
  targets: {
    '/api/(.*)': {
      target: 'http://xx.xxx.xx.xx:80/',
      ws: true,
      changeOrigin: true,
      pathRewrite: {
        '^/api/': '' //和前端代理一样,选择api替换为什么
      }
    },
  }
}

app.use(proxy(options));

// logger
app.use(async (ctx, next) => {
  ctx.set("Access-Control-Allow-Origin", "*");
  if (ctx.url == "/") {
    await next();
  } else {
    const html = await fs.readFileSync(path.resolve(__dirname + "/public/index.html"));
    ctx.body = html.toString();
  }
})

// error-handling
app.on('error', (err, ctx) => {
  console.error('server error', err, ctx)
});

module.exports = app

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值