Vapor 2.0 - 用戶名+密碼(基本)認(rèn)證(Username + Password (Basic) Auth)

前往 Vapor 2.0 - 文檔目錄

Authorization: Basic ...頭可以被用于發(fā)送用戶名和密碼憑據(jù)進(jìn)行身份驗(yàn)證毕箍。

此頁(yè)面將向您展示如何在您的網(wǎng)絡(luò)應(yīng)用程序中使用此類型的身份驗(yàn)證抽高。

注意
應(yīng)盡可能避免發(fā)送和存儲(chǔ)密碼。使用令牌或會(huì)話持久性柑蛇,以防止在每個(gè)請(qǐng)求中發(fā)送密碼。

密碼認(rèn)證(Password Authenticatable)

首先將您的用戶模型繼承PasswordAuthenticatable協(xié)議驱闷。

import AuthProvider

extension User: PasswordAuthenticatable { }

自定義(Custom)

如果您的用戶符合Model要求耻台,則所有必需的方法將自動(dòng)實(shí)現(xiàn)。
但是空另,如果你想做一些自定義的操作盆耽,你可以實(shí)現(xiàn)它們。

extension User: PasswordAuthenticatable {
    /// Return the user matching the supplied
    /// username and password
    ///返回用戶匹配提供的用戶名和密碼
    static func authenticate(_: Password) throws -> Self {
        // something custom 自定義的東西
    }

    /// The entity's hashed password used for
    /// validating against Password credentials
    /// with a PasswordVerifier
    /// 實(shí)體的散列密碼用于驗(yàn)證密碼PasswordVerifier憑證
    var hashedPassword: String? {
        // something custom 自定義的東西
    }

    /// The key under which the user's username,
    /// email, or other identifing value is stored.
    /// 的關(guān)鍵用戶的用戶名痹换、電子郵件或其他鑒別值存儲(chǔ)征字。
    static var usernameKey: String {
        // something custom 自定義的東西
    }

    /// The key under which the user's password
    /// is stored.
    /// 的關(guān)鍵是存儲(chǔ)用戶的密碼。
    static var passwordKey: String {
        // something custom 自定義的東西
    }

    /// Optional password verifier to use when
    /// comparing plaintext passwords from the 
    /// Authorization header to hashed passwords
    /// in the database.
    /// 可選的密碼校驗(yàn)時(shí)使用比較的明文密碼授權(quán)頭哈希密碼在數(shù)據(jù)庫(kù)中娇豫。
    static var passwordVerifier: PasswordVerifier? {
        // some hasher
    }
}

中間件(Middleware)

一旦您的model符合PasswordAuthenticatable協(xié)議匙姜,就可以創(chuàng)建中間件。

import Vapor
import AuthProvider

let drop = try Droplet()

let passwordMiddleware = PasswordAuthenticationMiddleware(User.self)

let authed = try drop.grouped(passwordMiddleware)

try drop.run()

添加到authed路由組的所有路由將受到密碼中間件的保護(hù)冯痢。

瞧一瞧
如果您只想全局要求密碼中間件氮昧,請(qǐng)檢查HTTP文檔中
中間件配置部分框杜。

路由(Route)

現(xiàn)在,您可以添加路由以返回經(jīng)過(guò)身份驗(yàn)證的用戶袖肥。

authed.get("me") { req in
    // return the authenticated user
    return try req.auth.assertAuthenticated(User.self)
}

調(diào)用req.user.authenticated(User.self)以訪問經(jīng)過(guò)身份驗(yàn)證的用戶咪辱。

請(qǐng)求(Request)

現(xiàn)在我們可以向我們的Vapor應(yīng)用程序發(fā)出請(qǐng)求。

GET /me HTTP/1.1
Authorization: Basic dmFwb3I6Zm9v 

注意
dmFwb3I6Zm9v是“vapor:foo”base64編碼椎组,其中“vapor”是用戶名油狂,“foo”是密碼。這是基本授權(quán)標(biāo)頭的格式寸癌。

我們應(yīng)該得到一個(gè)回應(yīng)专筷。

HTTP/1.1 200 OK
Content-Type: text/plain

Vapor
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市蒸苇,隨后出現(xiàn)的幾起案子磷蛹,更是在濱河造成了極大的恐慌,老刑警劉巖溪烤,帶你破解...
    沈念sama閱讀 221,273評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件味咳,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡檬嘀,警方通過(guò)查閱死者的電腦和手機(jī)槽驶,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)枪眉,“玉大人捺檬,你說(shuō)我怎么就攤上這事∶惩” “怎么了堡纬?”我有些...
    開封第一講書人閱讀 167,709評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)蒿秦。 經(jīng)常有香客問我烤镐,道長(zhǎng),這世上最難降的妖魔是什么棍鳖? 我笑而不...
    開封第一講書人閱讀 59,520評(píng)論 1 296
  • 正文 為了忘掉前任炮叶,我火速辦了婚禮,結(jié)果婚禮上渡处,老公的妹妹穿的比我還像新娘镜悉。我一直安慰自己,他們只是感情好医瘫,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,515評(píng)論 6 397
  • 文/花漫 我一把揭開白布侣肄。 她就那樣靜靜地躺著,像睡著了一般醇份。 火紅的嫁衣襯著肌膚如雪稼锅。 梳的紋絲不亂的頭發(fā)上吼具,一...
    開封第一講書人閱讀 52,158評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音矩距,去河邊找鬼拗盒。 笑死,一個(gè)胖子當(dāng)著我的面吹牛锥债,可吹牛的內(nèi)容都是我干的陡蝇。 我是一名探鬼主播,決...
    沈念sama閱讀 40,755評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼哮肚,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼毅整!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起绽左,我...
    開封第一講書人閱讀 39,660評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎艇潭,沒想到半個(gè)月后拼窥,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,203評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蹋凝,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,287評(píng)論 3 340
  • 正文 我和宋清朗相戀三年鲁纠,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片鳍寂。...
    茶點(diǎn)故事閱讀 40,427評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡改含,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出迄汛,到底是詐尸還是另有隱情捍壤,我是刑警寧澤,帶...
    沈念sama閱讀 36,122評(píng)論 5 349
  • 正文 年R本政府宣布鞍爱,位于F島的核電站鹃觉,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏睹逃。R本人自食惡果不足惜盗扇,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,801評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望沉填。 院中可真熱鬧疗隶,春花似錦、人聲如沸翼闹。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)橄碾。三九已至卵沉,卻和暖如春颠锉,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背史汗。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工琼掠, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人停撞。 一個(gè)月前我還...
    沈念sama閱讀 48,808評(píng)論 3 376
  • 正文 我出身青樓瓷蛙,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親戈毒。 傳聞我的和親對(duì)象是個(gè)殘疾皇子艰猬,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,440評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容