国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 學(xué)院 > 編程設(shè)計(jì) > 正文

密碼哈希函數(shù) Bcrypt的最大密碼長(zhǎng)度限制詳解

2020-02-02 19:00:53
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

密碼哈希函數(shù) Bcrypt的最大密碼長(zhǎng)度限制

Bcrypt是一個(gè)很流行的密碼哈希算法,是Niels Provos和DavidMazières基于Blowfish加密算法設(shè)計(jì)的密碼哈希算法,于1999年在USENIX協(xié)會(huì)上提交。Bcrypt在設(shè)計(jì)上包含了一個(gè)鹽Salt來(lái)防御彩虹表攻擊,還提供了一種自適應(yīng)功能,可以隨著時(shí)間的推移,通過增加迭代計(jì)數(shù)以使其執(zhí)行更慢,使得即便在增加計(jì)算能力的情況下,Bcrypt仍然能保持抵抗暴力攻擊。

Bcrypt是OpenBSD和SUSE Linux等操作系統(tǒng)默認(rèn)的密碼哈希算法。但是在使用Bcrypt算法的實(shí)現(xiàn)時(shí),要注意它有最大密碼長(zhǎng)度限制,通常為50~72字符,準(zhǔn)確的長(zhǎng)度限制取決于具體的Bcrypt實(shí)現(xiàn)。超過最大長(zhǎng)度的密碼將被截?cái)唷?/p>

下面使用spring Security的BCryptPasswordEncoder為例:

BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder();// 72 字符String password1 = "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa";// 73 字符String password2 = "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaab";String encodedPassword1 = passwordEncoder.encode(password1);boolean matches = passwordEncoder.matches(password2, encodedPassword1);System.out.println("encodedPassword1: " + encodedPassword1);System.out.println("matches: " + matches);

當(dāng)運(yùn)行程序時(shí),會(huì)輸出這樣的結(jié)果:

encodedPassword1: $2a$10$A5OpVKgjEZzmy6UNsqzkjuG2xGET1wp3b/9ET5dz/tHQ3eRvyXSSOmatches: true

這證明了Password字符串超過72字符的部分被截?cái)鄟G棄了。

要解決Bcrypt密碼算法72字符長(zhǎng)度限制的問題,可以這樣:

先使用SHA-256算法對(duì)字符串進(jìn)行加密,再使用Bcrypt算法加密,用偽碼示意如下:

hashpw(sha256('password'), salt);

感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 迁安市| 牡丹江市| 囊谦县| 华宁县| 文安县| 漯河市| 德兴市| 茌平县| 晋城| 克东县| 上虞市| 通化县| 江华| 巢湖市| 汝城县| 凉城县| 青神县| 珠海市| 临泉县| 西贡区| 都安| 五莲县| 佛冈县| 正定县| 博野县| 明溪县| 西乡县| 玛沁县| 开封县| 杭锦后旗| 安阳县| 明水县| 桂平市| 闵行区| 余干县| 聂荣县| 嘉善县| 泸州市| 金湖县| 老河口市| 朝阳区|