互聯(lián)網(wǎng)應(yīng)用中身份登記與身份認(rèn)證功能的安全方案

在互聯(lián)網(wǎng)應(yīng)用中营密,身份登記(注冊(cè))和身份認(rèn)證(登錄)這兩個(gè)功能的關(guān)鍵是密碼械媒。使用密碼自然是為了安全。如果你開(kāi)發(fā)的互聯(lián)網(wǎng)應(yīng)用沒(méi)能正確的使用并處理密碼,將會(huì)給用戶(hù)造成一定的安全隱患纷捞。要正確的使用并處理密碼痢虹,首先需要了解用戶(hù)為什么要設(shè)置密碼,設(shè)置密碼是為了防誰(shuí)主儡?

用戶(hù)設(shè)置密碼是為了防誰(shuí)

有些男士在雙十一等節(jié)日前夕修改支付寶或銀行卡的密碼可能是為了防老婆奖唯。
(哈哈……不要怪我說(shuō)出了你的心聲……)

對(duì)于系統(tǒng)來(lái)說(shuō),用戶(hù)名和密碼是用來(lái)做身份認(rèn)證(登錄)的糜值。只要輸入了正確的用戶(hù)名和密碼丰捷,系統(tǒng)就認(rèn)為那個(gè)在計(jì)算機(jī)前坐著的就是用戶(hù)本人。所以用戶(hù)的密碼是為了防除了用戶(hù)自己之外的“所有人”寂汇。

有幾類(lèi)特殊的“所有人”需要列一下:

  1. 和用戶(hù)在同一局域網(wǎng)的人病往;
    因?yàn)樗麄兛梢酝ㄟ^(guò)抓取局域網(wǎng)內(nèi)的網(wǎng)絡(luò)數(shù)據(jù)包,而窺視用戶(hù)與服務(wù)器之間交互的任何數(shù)據(jù)健无。并且還可以模仿用戶(hù)反復(fù)多次向服務(wù)器發(fā)送用戶(hù)之前發(fā)送過(guò)的數(shù)據(jù)包荣恐。
  2. 為用戶(hù)提供網(wǎng)絡(luò)服務(wù)的電信運(yùn)營(yíng)商;
    因?yàn)橛脩?hù)與服務(wù)器通信過(guò)程中累贤,所有數(shù)據(jù)都要經(jīng)過(guò)電信運(yùn)營(yíng)商叠穆,他們可以做的事并不比“和用戶(hù)在同一局域網(wǎng)的人”少。
  3. 用戶(hù)與服務(wù)器之間的所有路徑器臼膏;
    和電信運(yùn)營(yíng)商一樣硼被,用戶(hù)與服務(wù)器交互的所有數(shù)據(jù),也都逃不過(guò)這些路由器的眼睛渗磅。
  4. 用戶(hù)訪問(wèn)的那臺(tái)服務(wù)器嚷硫;
    對(duì)用戶(hù)來(lái)說(shuō)他訪問(wèn)的那臺(tái)服務(wù)器和那臺(tái)服務(wù)器背后的公司同樣不可信,并且那臺(tái)服務(wù)器還可能會(huì)被黑客攻破始鱼。

作為開(kāi)發(fā)者需要保證在身份登記與身份認(rèn)證過(guò)程中仔掸,用戶(hù)輸入的密碼不會(huì)被漏洞給除用戶(hù)本人之外的其他任何人(包括用戶(hù)訪問(wèn)的那臺(tái)服務(wù)器)。除此之外医清,還需要防重放攻擊起暮。

安全方案

  1. 為了不讓“局域網(wǎng)內(nèi)的用戶(hù)”,“電信運(yùn)營(yíng)商”会烙,“各跳路由器”负懦,“系統(tǒng)服務(wù)器”看到用戶(hù)的密碼,用戶(hù)的密碼不能明文提交柏腻。
  2. 為了防重放攻擊纸厉,用戶(hù)每次提交給服務(wù)器的密碼都不能相同。

安全方案實(shí)踐

身份登記

  1. 設(shè) pwd 為用戶(hù)的密碼明文五嫂,username 為用戶(hù)的用戶(hù)名明文
  2. 客戶(hù)端生成隨機(jī)數(shù)(最好是guid): token
  3. 客戶(hù)端計(jì)算 password = sha256_hmac(pwd,token)
  4. 客戶(hù)端做注冊(cè)請(qǐng)求颗品,把 username ,password 和 token 提交到服務(wù)器端
  5. 服務(wù)器端生成隨機(jī)數(shù)(最好是guid): salt
  6. 服務(wù)器端計(jì)算 spassword = sha256_hmac(password ,salt)
  7. 服務(wù)器端把 username、 spassword 抛猫、token 和 salt 存到數(shù)據(jù)庫(kù)中

身份認(rèn)證

  1. 設(shè) pwd 為用戶(hù)的密碼明文蟆盹,username 為用戶(hù)的用戶(hù)名明文
  2. 客戶(hù)端做預(yù)登錄請(qǐng)求,把 username 為參數(shù)提交給服務(wù)器端
  3. 服務(wù)器端根據(jù) username 從數(shù)據(jù)庫(kù)中查詢(xún)得到 spassword 闺金、token 和 salt
  4. 服務(wù)器端生成隨機(jī)數(shù)(最好是guid): stoken
  5. 服務(wù)器端把 token逾滥、salt 和 stoken 返回給客戶(hù)端
  6. 客戶(hù)端計(jì)算 spwd = sha256_hmac(sha256_hmac(sha256_hmac(pwd ,token), salt), stoken)
  7. 客戶(hù)端做登錄請(qǐng)求把 username 和 spwd 提交到服務(wù)器端
  8. 服務(wù)器端做計(jì)算 sspwd = sha256_hmac(spassword,stoken)
  9. 服務(wù)器端比較 sspwd 與spwd 是否相等,以確定是身份認(rèn)證是否成功
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末败匹,一起剝皮案震驚了整個(gè)濱河市寨昙,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌掀亩,老刑警劉巖舔哪,帶你破解...
    沈念sama閱讀 216,402評(píng)論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異槽棍,居然都是意外死亡捉蚤,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)炼七,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)缆巧,“玉大人,你說(shuō)我怎么就攤上這事豌拙∩滦” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,483評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵按傅,是天一觀的道長(zhǎng)捉超。 經(jīng)常有香客問(wèn)我,道長(zhǎng)唯绍,這世上最難降的妖魔是什么拼岳? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,165評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮况芒,結(jié)果婚禮上裂问,老公的妹妹穿的比我還像新娘。我一直安慰自己牛柒,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,176評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布痊乾。 她就那樣靜靜地躺著皮壁,像睡著了一般。 火紅的嫁衣襯著肌膚如雪哪审。 梳的紋絲不亂的頭發(fā)上蛾魄,一...
    開(kāi)封第一講書(shū)人閱讀 51,146評(píng)論 1 297
  • 那天平委,我揣著相機(jī)與錄音洼畅,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛葡兑,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播舞骆,決...
    沈念sama閱讀 40,032評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼曹步,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了魔市?” 一聲冷哼從身側(cè)響起主届,我...
    開(kāi)封第一講書(shū)人閱讀 38,896評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎待德,沒(méi)想到半個(gè)月后君丁,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,311評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡将宪,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,536評(píng)論 2 332
  • 正文 我和宋清朗相戀三年绘闷,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片较坛。...
    茶點(diǎn)故事閱讀 39,696評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡印蔗,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出燎潮,到底是詐尸還是另有隱情喻鳄,我是刑警寧澤,帶...
    沈念sama閱讀 35,413評(píng)論 5 343
  • 正文 年R本政府宣布确封,位于F島的核電站除呵,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏爪喘。R本人自食惡果不足惜颜曾,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,008評(píng)論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望秉剑。 院中可真熱鬧泛豪,春花似錦、人聲如沸侦鹏。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)略水。三九已至价卤,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間渊涝,已是汗流浹背慎璧。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,815評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工床嫌, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人胸私。 一個(gè)月前我還...
    沈念sama閱讀 47,698評(píng)論 2 368
  • 正文 我出身青樓厌处,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親岁疼。 傳聞我的和親對(duì)象是個(gè)殘疾皇子阔涉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,592評(píng)論 2 353

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

  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)五续,斷路器洒敏,智...
    卡卡羅2017閱讀 134,651評(píng)論 18 139
  • 1.ios高性能編程 (1).內(nèi)層 最小的內(nèi)層平均值和峰值(2).耗電量 高效的算法和數(shù)據(jù)結(jié)構(gòu)(3).初始化時(shí)...
    歐辰_OSR閱讀 29,372評(píng)論 8 265
  • 何為更安全 有比較才有“更”,這里所謂的“更”安全是與傳統(tǒng)方法相比較的疙驾。 全局說(shuō)明 以 "$" 符號(hào)開(kāi)始的標(biāo)識(shí)符凶伙,...
    JSON_NULL閱讀 4,529評(píng)論 2 3
  • 現(xiàn)在比較流行的密碼存儲(chǔ)是對(duì)密碼明文做 HASH運(yùn)算,把得到HASH值存儲(chǔ)到數(shù)據(jù)庫(kù)中它碎。驗(yàn)證過(guò)程就是再次對(duì)用戶(hù)發(fā)過(guò)來(lái)的...
    JSON_NULL閱讀 3,509評(píng)論 4 7
  • 插件系統(tǒng)是 Webpack 靈活性所在函荣,Loaders做不到的,便可以在這里使用 Webpack API 豐富你的...
    Transnet2014閱讀 1,185評(píng)論 0 0