在nuxt.js中引入@gauseen/nuxt-proxy模塊解決接口跨域限制,但是頁面訪問報錯
nuxt.config.js配置如下
module.exports = {
...
modules: [
// 請求代理配置,解決跨域
'@gauseen/nuxt-proxy',
],
proxyTable: [
'/api',
{
target: 'http://192.168.1.181:3004', // api主機
ws: true,
pathRewrite: { '^/api': '/' }
}
]
...
}
axios請求如下
axios.post('/login', data)
但是把proxyTable這個注釋掉就行了,頁面回復訪問,到底是什么原因引起的呢?有沒有解決方案
如果你翻出來vue-cli腳手架生成的vue項目,你會發(fā)現(xiàn)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))
})
沒錯,你說的這個proxyTable 就是一個express的中間件,但是這個express中間件和nuxt的中間件又不一樣。具體怎么添加進去,貌似官方也沒有說明。nuxt本地開發(fā)的時候貌似也是用的express。
經(jīng)過我一番努力,終于把你這個東西弄出來了。在nuxt中如何添加express中間件?
首先,安裝依賴
npm install --save-dev express http-proxy-middleware
然后在根目錄創(chuàng)建一個文件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"
}
}北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達內教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構,是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學校辦產業(yè)為響應國家深化產教融合/校企合作的政策,積極推進“中國制造2025”,實現(xiàn)中華民族偉大復興的升級產業(yè)鏈。利用北京大學優(yōu)質教育資源及背
博為峰,中國職業(yè)人才培訓領域的先行者
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務負責iOS教學及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術, 熟練的跨平臺面向對象開發(fā)經(jīng)驗,技術功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術顧問,美國Dachieve 系統(tǒng)架構師,美國AngelEngineers Inc. 系統(tǒng)架構師。