如何在nuxt中添加proxyTable代理
代理 如何 添加 Nuxt
2023-09-11 14:16:54 时间
背景
在本地开发vue项目的时候,当你习惯了proxyTable
解决本地跨域的问题,切换到nuxt
的时候,你会发现,添加了proxyTable
设置并没有什么作用,那是因为你是用的vue脚手架生成的vue项目,它里面已经帮你写好了相关的proxyTable
的设置代码。
build/dev-server.js
// proxy api requests
Object.keys(proxyTable).forEach(function (context) {
var options = proxyTable[context]
if (typeof options === 'string') {
options = { target: options }
}
app.use(proxyMiddleware(options.filter || context, options))
})
这里是采用的express中间件的形式,使用的依赖是http-proxy-middleware
nuxt也有中间件的概念,不过这个中间件不是express的中间件,那么我们怎么添加到nuxt里面去呢?
怎么做
首先,安装依赖```npm install --save-dev express http-proxy-middleware ```
然后在根目录创建一个文件server.js
const { Nuxt, Builder } = require('nuxt')
const app = require('express')()
var proxyMiddleware = require('http-proxy-middleware')
var config = require('./nuxt.config')
// 我们用这些选项初始化 Nuxt.js:
const isProd = process.env.NODE_ENV === 'production'
const nuxt = new Nuxt({ dev: !isProd })
// 生产模式不需要 build
if (!isProd) {
const builder = new Builder(nuxt)
builder.build()
}
// proxy api requests这里就是添加的proxyTable中间价的设置了
var proxyTable = config.dev.proxyTable
Object.keys(proxyTable).forEach(function (context) {
var options = proxyTable[context]
if (typeof options === 'string') {
options = { target: options }
}
app.use(proxyMiddleware(options.filter || context, options))
})
app.use(nuxt.render)//这里是添加nuxt渲染层服务的中间件
app.listen(3000)
console.log('Server is listening on http://localhost:3000')
然后在nuxt.config.js
中添加如下代码
module.exports = {
dev: {
proxyTable: {
'/api':
{
target: 'http://localhost:7001', //
pathRewrite: { '^/api': '/' }
}
}
}
}
然后node server.js
运行就可以了。
觉得运行不方便还可以把命令添加到package.json
文件里。
{
"scripts": {
"dev": "nuxt --port=8080",
"build": "nuxt build",
"start": "nuxt start",
"generate": "nuxt generate",
"lint": "eslint --ext .js,.vue --ignore-path .gitignore .",
"precommit": "npm run lint",
"server": "node server.js"
}
}
相关文章
- spring: 使用Aspectj代理EnabelAspectjAutoProxy
- 反射机制-动态代理
- 记一次IE代理异常故障
- nginx 如何代理websocket
- Delegate(代理)异常:该委托必须有一个目标
- 动态代理解决网站字符集编码
- 巧用代理设计模式(Proxy Design Pattern)改善前端图片加载体验
- 【Android 安全】DEX 加密 ( 代理 Application 开发 | 项目中配置 OpenSSL 开源库 | 使用 OpenSSL 开源库解密 dex 文件 )
- Java动态代理机制详解(JDK 和CGLIB,Javassist,ASM) AspectJ
- Centos代理上网设置
- 【Nginx】如何使用自签CA配置HTTPS加密反向代理访问?看了这篇我会了!!
- k8s部署dashboard.及反向代理services(十一)
- 如何设置单个 Git 仓库的代理从而提高更新速度
- Func的介绍——c#封装的代理
- 前端如何通过Nginx代理做到跨域访问API接口
- 爬虫----如何快速将模拟器或者手机终端的网络代理设置为fiddler的监听端口
- Nginx---反向代理,SSL支持
- 【vue】vue中如何使用http代理解决跨域问题_11