区块链学习之网站如何保存用户密码(哈希函数简介)

当你被提示您的用户有被攻破,有风险时,是否意味着你的密码已经被黑客得到了呢?也许并不是这样。为了说明这个问题,我们来看下一般网站是如何来保护并安全的存储你的密码。

通常密码会以三种方式来存储用户密码:纯文本存储,加密存储,或者使用散列函数存储。首先是纯文本形式存储,这是最危险的方式,一旦网站的数据库被攻破,所有用户的密码都会被看到,而很多人有不同网站使用相同密码的习惯,那么很可能一个密码被泄露会导致更多的账户被入侵。事实上有很多百万级用户的网站都在使用这种原始的纯文本方式来保存用户密码。

作为一种替代方法,那就是通过加密来保存密码,在保存密码之前,先将用户密码进行加密,这样数据库被攻破时,获取到的是加密后的密码,但这仍然是风险很高的,因为一旦加密的密钥泄露,加密保存的数据和纯文本就是没有区别的了。

第三种密码存储方式就是使用哈希散列来存储,哈希是如何工作的呢?哈希函数需要一个输入,可以使一段文本,如密码,或者也可以是一个文件,哈希算法会将输入最终转换成一个定长的字符串,有很多种哈希算法。哈希散列的方式和加密的方式有一个根本的不同点:哈希是单向的,你可以计算得到密码的哈希值,但是你不能通过一个哈希值计算出他的原始数据,这非常有用,通过哈希散列,网站可以验证你是否有使用正确的密码登录,但网站并没有存储的你的真实密码。

哈希算法也并不完美,大多数哈希算法都针对速度进行了优化,也就是每秒能计算的哈希值越大,通常会被认为是更好的哈希算法。这就是的哈希散列容易受到暴力攻击,通过简单重复尝试每一个可能的密码,攻击者就可以实现逆向哈希散列,现代GPU可以每秒2.92一次哈希计算,使用这种技术,破解散列密码只是时间问题,如果速度不够,攻击者也可以通过一个彩虹表来进一步加速。通过存储预先计算哈希值的表,可以用于快速的查找比较常见的密码组合。

哈希算法的速度在某些领域是积极的,越快越好,但对于机密存储这个角度,计算速度可能起到的作用并不一定是积极的,尤其是当用户使用相同的密码是,又会引入新的问题。如果Alice和Bob都是用密码“qwerty”,密码的哈希就会相同,当破解了一个他们中一个人的密码时,那么另外一个人的密码也就会被知道。你也许认为不同的人会使用相同密码的可能性很小,但事实上,”qwerty“这个密码被发现使用超过300万次。

为了抵御这些攻击,我们在对密码散列之前,可以“加盐”,盐是一些随机数据,但它可以确保您的密码哈希值始终和其他人不同,这样使用相同密码的用户,存储的哈希值就不会再相同。那么黑客再进行密码破解时,就需要对每个用户的哈希值去破解。这会减慢黑客的破解速度,但仍然是有可能的。

有些哈希算法为了解决这种问题,使用特殊的技术来特意降低哈希的计算速度,例如bcrypt, scrpyt还有argon2,他们能有效抵消暴力破解。这些算法将密码,盐和花费作为输入,成本非常有趣,他定义了算法循环的次数,通过这种特性,有效的减缓了哈希计算速度。

随着时间的推移,计算机的速度会越来越快,那么对于这些算法的暴力攻击也会变的更容易,算法要做的只是增加成本参数,那么就又能提高被破解的难度。

这就是公司存储和保护你的密码的三种可选方式,有多种方法,为什么一定要使用多种方法呢,当涉及到安全问题时,你应该尽力的将保护措施用到极致。一个例子Dropbox使用多重保护,首先,将密码做一个简单的哈希运算,它没有加盐,这只是他的第一道防线,然后它暂通过bscrpyt算法将哈希值,盐和一个值为10的开销作为输入来运算出新的哈希值,这有效的避免了暴力攻击。最后的到的哈希值再通过高级加密算法加密,而加密的密钥并不存储在数据库中而是分开存储。也就是说你要破解Dropbox的数据库,就要攻破它的每一层保护程序,这需要花费很多的时间和成本,甚至远超过破解的回报。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342

推荐阅读更多精彩内容

  • 所有货币都需要一些方法来控制供应,并强制执行各种安全属性以防止作弊。在法定货币方面,像中央银行这样的组织控制货币供...
    Nutbox_Lab阅读 3,070评论 1 3
  • Hash 算法与数字摘要 Hash (哈希或散列)算法它能将任意长度的二进制明文串映射为较短的(通常是固定长度的)...
    你看我像豆子嘛阅读 1,215评论 0 2
  • 区块链系统的核心之二-加密技术 加密技术主要是用来解决区块链系统记录的数据的所有权问题。 1哈希算法 1)...
    yrm23阅读 1,585评论 0 4
  • 大树在微风中炫耀着自己智慧的头脑一摇一摆多么和谐的旋律 一片树叶落了微风将真理带到了远方 心事莫名其妙的就在心里定...
    心花园子阅读 413评论 4 12
  • 简书第一篇写给这几天的我 开始一段恋情 但最终以我不喜欢为由告终 时期两个月 因为偶然的原因 我说出了埋在心里许久...
    Aimee_0706阅读 177评论 0 1