成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

koa中利用nginx反向代理動(dòng)態(tài)及靜態(tài)文件

opengps / 3003人閱讀

摘要:背景最近在做一個(gè)基于的微信公眾平臺(tái)腳手架,由于我只有一個(gè)域名,現(xiàn)在同時(shí)有好幾個(gè)應(yīng)用在上面掛載著,所以只能做一下反向代理,可是反向代理只能代理動(dòng)態(tài)文件,對(duì)于靜態(tài)資源貌似沒有什么好的解決方法本文針對(duì)以上問題進(jìn)行逐步解決,通過修改相關(guān)配置,并結(jié)合

背景

最近在做一個(gè)基于koa的微信公眾平臺(tái)腳手架,由于我只有一個(gè)域名demozhan.com,現(xiàn)在同時(shí)有好幾個(gè)web應(yīng)用在上面掛載著,所以只能做一下反向代理,可是反向代理只能代理動(dòng)態(tài)文件,對(duì)于靜態(tài)資源貌似沒有什么好的解決方法

本文針對(duì)以上問題進(jìn)行逐步解決,通過修改nginx相關(guān)配置,并結(jié)合koa-router以及koa-static,就可以解決上述問題。

配置koa-static解決端口下靜態(tài)文件的問題
var serve = require("koa-static");
// 使用./public下的靜態(tài)文件
app.use(serve(__dirname + "/public"));

通過以上配置就可以將public文件夾作為靜態(tài)文件夾,在請(qǐng)求 http://localhost:3333/login/css/index.cs... 的時(shí)候就會(huì)去查找本地文件夾

通過以上過程就解決了,不做反向代理情況下的靜態(tài)文件的配置

配置nginx實(shí)現(xiàn)反向代理 配置nginx
location /weixin {
        proxy_pass http://localhost:3333;
}

這個(gè)沒什么好講的,可是直接這樣的操作導(dǎo)致整個(gè)頁面都訪問不到

直接反向代理請(qǐng)求/weixin/login/會(huì)代理到3333端口,但是請(qǐng)求的path依舊是/weixin/login/

解決方案:添加router前綴,保證請(qǐng)求鏈接一致

var router = new Router({
  prefix: "/weixin"
});

通過以上方法,請(qǐng)求/weixin/login鏈接就對(duì)應(yīng)router中的login

靜態(tài)文件失效

通過以上配置,login頁面渲染出來了,可是加載的css文件都404了。

通過調(diào)試koa-static分析原因,由于修改了router的前綴了,所以所有靜態(tài)文件請(qǐng)求都變成/weixin/css/login.css;請(qǐng)求鏈接錯(cuò)誤

解決方法

大概思路就是通過傳入一個(gè)參數(shù),表示要去除的路徑,改變path路徑,koa-static的具體原理我還沒有深入

修改koa-static源碼

  if (!opts.defer) {
    return function * serve(next) {
      if (this.method == "HEAD" || this.method == "GET") {
        //在默認(rèn)情況下this.path = "/css/style.css" 會(huì)轉(zhuǎn)變?yōu)楸镜?../public/css/style.css文件路徑
        //由于做了反向代理this.path = "/weixin/css/style.css"
        //由于做了反向代理需要修改靜態(tài)文件的path = "/css/style.css"
        var path;
        if (opts.proxy) {
          path = this.path.replace(opts.proxy, "");
        } else {
          path = this.path;
        }

        if (yield send(this, path, opts)) return;
      }
      yield* next;
    };
  }
匯總

index.js的代碼

var koa = require("koa");
var Router = require("koa-router");
var serve = require("koa-static");
var app = koa();
var Weixin = require("./weixin/weixin")("zhanfang");
var router = new Router({
  prefix: "/weixin"
});

//路由配置
router.get("/login", Weixin.webLogin());

// 使用./public下的靜態(tài)文件
app.use(serve(__dirname + "/public", {
  proxy: "/weixin"
}));

app.use(logger());
app.use(router.routes())
  .use(router.allowedMethods());

app.on("error", function(err) {
  console.log(err);
})
app.listen(3333);

login.html的部分代碼


原文地址

http://demozhan.com/2016/03/30/koa-nginx...

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/79087.html

相關(guān)文章

  • koa利用nginx反向代理動(dòng)態(tài)靜態(tài)文件

    摘要:背景最近在做一個(gè)基于的微信公眾平臺(tái)腳手架,由于我只有一個(gè)域名,現(xiàn)在同時(shí)有好幾個(gè)應(yīng)用在上面掛載著,所以只能做一下反向代理,可是反向代理只能代理動(dòng)態(tài)文件,對(duì)于靜態(tài)資源貌似沒有什么好的解決方法本文針對(duì)以上問題進(jìn)行逐步解決,通過修改相關(guān)配置,并結(jié)合 背景 最近在做一個(gè)基于koa的微信公眾平臺(tái)腳手架,由于我只有一個(gè)域名demozhan.com,現(xiàn)在同時(shí)有好幾個(gè)web應(yīng)用在上面掛載著,所以只能做一...

    figofuture 評(píng)論0 收藏0
  • 下一代基于Koa的NodeJS全棧開發(fā)框架

    Github上的腳手架實(shí)在太多,可能大多數(shù)都是只專注在前端的web開發(fā),例如流行的React生態(tài)中的create-react-app和Vue生態(tài)中的Vue-cli, 但是可能作為像我一樣的全棧開發(fā),一個(gè)只關(guān)注在前端開發(fā)的腳手架滿足不了所有的需求,我們可能需要開發(fā)更復(fù)雜的全棧JS的項(xiàng)目,所以這里介紹又一個(gè)基于NodeJS的全棧開發(fā)框架 koa-web-kit,不一定適合所有人,但至少又多了個(gè)選擇?。...

    oliverhuang 評(píng)論0 收藏0
  • 老項(xiàng)目改造記

    摘要:前言老項(xiàng)目,項(xiàng)目情況端配置運(yùn)行環(huán)境方面有些人開發(fā)環(huán)境是,有些是。以我的開發(fā)環(huán)境為例老項(xiàng)目的運(yùn)行,開發(fā)時(shí)需要先執(zhí)行一個(gè)腳本經(jīng)歷過一次風(fēng)波之后做的人走光啦,但是老項(xiàng)目要繼續(xù)維護(hù)。老項(xiàng)目改造其實(shí)還有不少坑,等我想起來再慢慢更新。 前言 老項(xiàng)目,React + PHP + nginx 項(xiàng)目情況 PHP端配置 PHP運(yùn)行環(huán)境方面:有些人開發(fā)環(huán)境是wamp(apache + PHP),有些是np...

    SimonMa 評(píng)論0 收藏0
  • Nginx

    摘要:此外,其也能夠提供強(qiáng)大的反向代理功能。是由為俄羅斯訪問量第二的站點(diǎn)開發(fā)的,第一個(gè)公開版本發(fā)布于年月日。 keepalived+nginx 實(shí)現(xiàn)高可用雙機(jī)熱備 + 負(fù)載均衡架構(gòu) 1 準(zhǔn)備4個(gè)ubuntu16.04虛擬機(jī)(啟用網(wǎng)卡二并使用橋接模式):A服務(wù)器:192.168.0.103 主B服務(wù)器:192.168.0.104 主(備) 前端工程師學(xué)習(xí) Nginx ...

    syoya 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<