相關(guān) API此系列文章的應(yīng)用示例已發(fā)布于 GitHub: koa-docs-Zh-CN. 可以 Fork 幫助改進(jìn)或 Star 關(guān)注更新. 歡迎 Star.
上下文(Context)
請求(Request)
響應(yīng)(Response)
安裝Koa 依賴 node v7.6.0 或 ES2015及更高版本和 async 方法支持.
你可以使用自己喜歡的版本管理器快速安裝支持的 node 版本:
$ nvm install 7 $ npm i koa $ node my-koa-app.js使用 Babel 實現(xiàn) Async 方法
要在 node < 7.6 版本的 Koa 中使用 async 方法, 我們推薦使用 babel"s require hook.
require("babel-register"); // 應(yīng)用的其余 require 需要被放到 hook 后面 const app = require("./app");
要解析和編譯 async 方法, 你至少應(yīng)該有 transform-async-to-generator
或 transform-async-to-module-method 插件.
例如, 在你的 .babelrc 文件中, 你應(yīng)該有:
{ "plugins": ["transform-async-to-generator"] }
你也可以用 env preset 的 target 參數(shù) "node": "current" 替代.
應(yīng)用程序Koa 應(yīng)用程序是一個包含一組中間件函數(shù)的對象,它是按照類似堆棧的方式組織和執(zhí)行的。
Koa 類似于你可能遇到過的許多其他中間件系統(tǒng),例如 Ruby 的 Rack ,Connect 等,然而,一個關(guān)鍵的設(shè)計點是在其低級中間件層中提供高級“語法糖”。 這提高了互操作性,穩(wěn)健性,并使書寫中間件更加愉快。
這包括諸如內(nèi)容協(xié)商,緩存清理,代理支持和重定向等常見任務(wù)的方法。 盡管提供了相當(dāng)多的有用的方法 Koa 仍保持了一個很小的體積,因為沒有捆綁中間件。
必修的 hello world 應(yīng)用:
const Koa = require("koa"); const app = new Koa(); app.use(async ctx => { ctx.body = "Hello World"; }); app.listen(3000);級聯(lián)
Koa 中間件以更傳統(tǒng)的方式級聯(lián),您可能習(xí)慣使用類似的工具 - 之前難以讓用戶友好地使用 node 的回調(diào)。然而,使用 async 功能,我們可以實現(xiàn) “真實” 的中間件。對比 Connect 的實現(xiàn),通過一系列功能直接傳遞控制,直到一個返回,Koa 調(diào)用“下游”,然后控制流回“上游”。
下面以 “Hello World” 的響應(yīng)作為示例,首先請求流通過 x-response-time 和 logging 中間件來請求何時開始,然后繼續(xù)移交控制給 response 中間件。當(dāng)一個中間件調(diào)用 next() 則該函數(shù)暫停并將控制傳遞給定義的下一個中間件。當(dāng)在下游沒有更多的中間件執(zhí)行后,堆棧將展開并且每個中間件恢復(fù)執(zhí)行其上游行為。
const Koa = require("koa"); const app = new Koa(); // x-response-time app.use(async (ctx, next) => { const start = Date.now(); await next(); const ms = Date.now() - start; ctx.set("X-Response-Time", `${ms}ms`); }); // logger app.use(async (ctx, next) => { const start = Date.now(); await next(); const ms = Date.now() - start; console.log(`${ctx.method} ${ctx.url} - ${ms}`); }); // response app.use(async ctx => { ctx.body = "Hello World"; }); app.listen(3000);設(shè)置
應(yīng)用程序設(shè)置是 app 實例上的屬性,目前支持如下:
app.env 默認(rèn)是 NODE_ENV 或 "development"
app.proxy 當(dāng)真正的代理頭字段將被信任時
app.subdomainOffset 對于要忽略的 .subdomains 偏移[2]
app.listen(...)Koa 應(yīng)用程序不是 HTTP 服務(wù)器的1對1展現(xiàn)。
可以將一個或多個 Koa 應(yīng)用程序安裝在一起以形成具有單個HTTP服務(wù)器的更大應(yīng)用程序。
創(chuàng)建并返回 HTTP 服務(wù)器,將給定的參數(shù)傳遞給 Server#listen()。這些內(nèi)容都記錄在 nodejs.org.
以下是一個無作用的 Koa 應(yīng)用程序被綁定到 3000 端口:
const Koa = require("koa"); const app = new Koa(); app.listen(3000);
這里的 app.listen(...) 方法只是以下方法的語法糖:
const http = require("http"); const Koa = require("koa"); const app = new Koa(); http.createServer(app.callback()).listen(3000);
這意味著您可以將同一個應(yīng)用程序同時作為 HTTP 和 HTTPS 或多個地址:
const http = require("http"); const https = require("https"); const Koa = require("koa"); const app = new Koa(); http.createServer(app.callback()).listen(3000); https.createServer(app.callback()).listen(3001);app.callback()
返回適用于 http.createServer() 方法的回調(diào)函數(shù)來處理請求。你也可以使用此回調(diào)函數(shù)將 koa 應(yīng)用程序掛載到 Connect/Express 應(yīng)用程序中。
app.use(function)將給定的中間件方法添加到此應(yīng)用程序。參閱 Middleware 獲取更多信息.
app.keys=設(shè)置簽名的 Cookie 密鑰。
這些被傳遞給 KeyGrip,但是你也可以傳遞你自己的 KeyGrip 實例。
例如,以下是可以接受的:
app.keys = ["im a newer secret", "i like turtle"]; app.keys = new KeyGrip(["im a newer secret", "i like turtle"], "sha256");
這些密鑰可以倒換,并在使用 { signed: true } 參數(shù)簽名 Cookie 時使用。
ctx.cookies.set("name", "tobi", { signed: true });app.context
app.context 是從其創(chuàng)建 ctx 的原型。您可以通過編輯 app.context 為 ctx 添加其他屬性。這對于將 ctx 添加到整個應(yīng)用程序中使用的屬性或方法非常有用,這可能會更加有效(不需要中間件)和/或 更簡單(更少的 require()),而更多地依賴于ctx,這可以被認(rèn)為是一種反模式。
例如,要從 ctx 添加對數(shù)據(jù)庫的引用:
app.context.db = db(); app.use(async ctx => { console.log(ctx.db); });
注意:
ctx 上的許多屬性都是使用 getter ,setter 和 Object.defineProperty() 定義的。你只能通過在 app.context 上使用 Object.defineProperty() 來編輯這些屬性(不推薦)。查閱 https://github.com/koajs/koa/...
安裝的應(yīng)用程序目前使用其父級的 ctx 和設(shè)置。 因此,安裝的應(yīng)用程序只是一組中間件。
錯誤處理默認(rèn)情況下,將所有錯誤輸出到 stderr,除非 app.silent 為 true。
當(dāng) err.status 是 404 或 err.expose 是 true 時默認(rèn)錯誤處理程序也不會輸出錯誤。
要執(zhí)行自定義錯誤處理邏輯,如集中式日志記錄,您可以添加一個 “error” 事件偵聽器:
app.on("error", err => { log.error("server error", err) });
如果 req/res 期間出現(xiàn)錯誤,并且 無法 響應(yīng)客戶端,Context實例仍然被傳遞:
app.on("error", (err, ctx) => { log.error("server error", err, ctx) });
當(dāng)發(fā)生錯誤 并且 仍然可以響應(yīng)客戶端時,也沒有數(shù)據(jù)被寫入 socket 中,Koa 將用一個 500 “內(nèi)部服務(wù)器錯誤” 進(jìn)行適當(dāng)?shù)捻憫?yīng)。在任一情況下,為了記錄目的,都會發(fā)出應(yīng)用級 “錯誤”。
如果這篇文章對您有幫助, 感謝 下方點贊 或 Star GitHub: koa-docs-Zh-CN 支持, 謝謝.
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/89472.html
摘要:的對象提供了用于處理響應(yīng)的方法,該響應(yīng)委托給。應(yīng)用對象是與的服務(wù)器和處理中間件注冊的接口,從發(fā)送到中間件,默認(rèn)錯誤處理,以及上下文,請求和響應(yīng)對象的配置。 此系列文章的應(yīng)用示例已發(fā)布于 GitHub: koa-docs-Zh-CN. 可以 Fork 幫助改進(jìn)或 Star 關(guān)注更新. 歡迎 Star. showImg(https://segmentfault.com/img/bVNQYf...
摘要:方法拋出一個屬性默認(rèn)為的錯誤,這將允許做出適當(dāng)?shù)仨憫?yīng)。這用于修飾其人機(jī)友好型錯誤并向上游的請求者報告非常有用。請注意,不支持使用此功能。這可能會破壞中間件和本身的預(yù)期功能。 上下文(Context) 此系列文章的應(yīng)用示例已發(fā)布于 GitHub: koa-docs-Zh-CN. 可以 Fork 幫助改進(jìn)或 Star 關(guān)注更新. 歡迎 Star. Koa Context 將 node 的 ...
摘要:當(dāng)中間件運行時,它必須手動調(diào)用來運行下游中間件。例如,這個中間件從讀取文件名,然后在將給指定合并結(jié)果之前并行讀取每個文件的內(nèi)容。當(dāng)你無法控制中間件的名稱時,這很有用。 指南 此系列文章的應(yīng)用示例已發(fā)布于 GitHub: koa-docs-Zh-CN. 可以 Fork 幫助改進(jìn)或 Star 關(guān)注更新. 歡迎 Star. 本指南涵蓋的 Koa 主題不與 API 直接相關(guān),例如編寫中間件的最...
摘要:一個遷移方式是逐個更新它們。刪除特定的日志記錄行為對于環(huán)境的顯式檢查從錯誤處理中刪除。直接或它不再使用并已廢棄。支持仍然支持分支,但應(yīng)該不會得到功能性更新。除了此遷移指南外,文檔將針對最新版本。 從 Koa v1.x 遷移到 v2.x 此系列文章的應(yīng)用示例已發(fā)布于 GitHub: koa-docs-Zh-CN. 可以 Fork 幫助改進(jìn)或 Star 關(guān)注更新. 歡迎 Star. 新的中...
摘要:別名為設(shè)置請求標(biāo)頭對象。獲取請求路徑名。設(shè)置請求路徑名,并在存在時保留查詢字符串。請注意,此不支持嵌套對象。檢查請求緩存是否新鮮,也就是內(nèi)容沒有改變。通過來檢查請求是否通過發(fā)出。返回請求套接字。 請求(Request) 此系列文章的應(yīng)用示例已發(fā)布于 GitHub: koa-docs-Zh-CN. 可以 Fork 幫助改進(jìn)或 Star 關(guān)注更新. 歡迎 Star. Koa Request...
閱讀 2588·2019-08-30 10:53
閱讀 3191·2019-08-29 16:20
閱讀 2947·2019-08-29 15:35
閱讀 1767·2019-08-29 12:24
閱讀 2875·2019-08-28 18:19
閱讀 1851·2019-08-23 18:07
閱讀 2331·2019-08-23 15:31
閱讀 1168·2019-08-23 14:05