基于Swift的Web框架Vapor2.0文檔(翻譯)HTTP-Body

轉載請附原文鏈接:http://blog.fandong.me/2017/08/20/iOS-SwiftVaporWeb23/

前言

之前一直有做Java后臺開發的興趣,可是想到要看好多的Java教程,作為一個iOS開發者,我放棄了,
后來從朋友韓云智VL那里知道了這個框架,竟是用Swift寫的,不得不說,它燃起了我的興趣。
Vapor是一個基于Swift開發的服務端框架,可以工作于iOS,Mac OS,Ubuntu。
為了配合Swift部署到服務器,我把ECS的服務器系統改為Ubuntu16.04。

Vapor 2.0 - 文檔目錄
以下文字翻譯自Vapor Docs/HTTP/Body

請求體

HTTP.Body表示的是HTTP.Message的有效載荷,并用于傳遞底層數據,在這次練習中的一些例子是JSON,HTML文本或者二進制圖像,我們來看一下具體實現

public enum Body {
    case data(Bytes)
    case chunked((ChunkStream) throws -> Void)
}

數據案例

Data Case是一個目前最常見的Body中的HTTP.Message.它只是一個字節數組,與這些字節數組關聯的序列化協議或類型通常由Content-Type請求頭定義,我們來看些例子

Application/JSON

如果我們的Content-Type請求頭包含application/json,那么底層二級制數據表示序列化的JSON

if let contentType = req.headers["Content-Type"], contentType.contains("application/json"), let bytes = req.body.bytes {
  let json = try JSON(bytes: bytes)
  print("Got JSON: \(json)")
}

Image/PNG

如果我們的Content-Type包含image/png,則底層二進制數據表示編碼的png.

if let contentType = req.headers["Content-Type"], contentType.contains("image/png"), let bytes = req.body.bytes {
  try database.save(image: bytes)
}

分塊案例

分塊案例只適用于Vapor的外發的HTTP.Message,傳統意義上,響應者的角色是在傳遞之前收集整個分塊編碼,我們可以使用它來異步發送一個正文.

let body: Body = Body.chunked(sender)
return Response(status: .ok, body: body)

我們也可以手動實現,也可以使用Vapor的內置便利的初始化器來進行對請求體進行分塊.

return Response(status: .ok) { chunker in
  for name in ["joe", "pam", "cheryl"] {
      sleep(1)
      try chunker.send(name)
  }

  try chunker.close()
}

確保在分塊離開范圍之前調用close()

BodyRepressentable

除了具體的Body類型,就像在Vapor中常見,我們也廣泛的支持BodyRepresentable.這意味著我們通常轉換的類型的對象可以互換使用,舉個栗子

return Response(body: "Hello, World!")

在上面的例子中,字符串被轉換成二進制,并且添加到了請求體中

作為練習,最好使用Hello,World!Vapor會自動設置Content-Type為合適的值

我們來看看它是如何實現的:

public protocol BodyRepresentable {
    func makeBody() -> Body
}

自定義

我們也可以在適用的情況下遵照我們自己的類型,假設我們有一個自定義的數據類型,.vpr讓我們符合我們的VPR文件類型

extension VPRFile: HTTP.BodyRepresentable {
  func makeBody() -> Body {
    // collect bytes
    return .data(bytes)
  }
}

你可能已經注意到,協議拋出,但是我們沒有實現,這在Swift中完全有效,如果你曾經手動調用過這個方法,那你將無法拋出.

現在我們可以直接在我們的Responses中包含我們的VPR文件.

drop.get("files", ":file-name") { request in
  let filename = try request.parameters.extract("file-name") as String
  let file = VPRFileManager.fetch(filename)
  return Response(status: .ok, headers: ["Content-Type": "file/vpr"], body: file)
}

作為練習,如果我們經常重復這些過程,我們可能會讓VPRFile直接遵循ResponseRepresentable

extension VPRFile: HTTP.ResponseRepresentable {
  func makeResponse() -> Response {
    return Response(
      status: .ok,
      headers: ["Content-Type": "file/vpr"],
      body: file
    )
  }
}

這是我們上面的例子

drop.get("files", ":file-name") { request in
  let filename = try request.parameters.extract("file-name") as String
  return VPRFileManager.fetch(filename)
}

我們也可以使用類型安全的路由使其更簡潔:

drop.get("files", String.self) { request, filename in
  return VPRFileManager.fetch(filename)
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,362評論 6 544
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,577評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,486評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,852評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,600評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,944評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,944評論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,108評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,652評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,385評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,616評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,111評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,798評論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,205評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,537評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,334評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,570評論 2 379

推薦閱讀更多精彩內容

  • Spring Cloud為開發人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發現,斷路器,智...
    卡卡羅2017閱讀 134,828評論 18 139
  • 發現 關注 消息 iOS 第三方庫、插件、知名博客總結 作者大灰狼的小綿羊哥哥關注 2017.06.26 09:4...
    肇東周閱讀 12,176評論 4 61
  • 月亮瞪著亮晃晃的眼睛 瞪著瞪著就迷糊了 時鐘嘀嗒嘀嗒地走著 走著走著就停了 玫瑰花攏著頭 一陣輕微的氣息 吐出一室...
    阿笀閱讀 295評論 0 0
  • 我沒有堅持自我,時間幫我考驗了所謂的愛情。
    O上閱讀 183評論 0 0
  • 得到 劉潤五分鐘商學院 32課 1:用戶滿意不代表忠誠度,65-85%滿意的顧客會轉向他人。 2:養成用戶粘度需要...
    探花磨刀石閱讀 733評論 0 1