成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

Spring Boot 中密碼加密的兩種方法

瀏覽:2日期:2023-08-17 08:48:45

先說一句:密碼是無法解密的。大家也不要再問松哥微人事項目中的密碼怎么解密了!

密碼無法解密,還是為了確保系統安全。今天松哥就來和大家聊一聊,密碼要如何處理,才能在最大程度上確保我們的系統安全。

1.為什么要加密

2011 年 12 月 21 日,有人在網絡上公開了一個包含 600 萬個 CSDN 用戶資料的數據庫,數據全部為明文儲存,包含用戶名、密碼以及注冊郵箱。事件發生后 CSDN 在微博、官方網站等渠道發出了聲明,解釋說此數據庫系 2009 年備份所用,因不明原因泄露,已經向警方報案,后又在官網發出了公開道歉信。在接下來的十多天里,金山、網易、京東、當當、新浪等多家公司被卷入到這次事件中。整個事件中最觸目驚心的莫過于 CSDN 把用戶密碼明文存儲,由于很多用戶是多個網站共用一個密碼,因此一個網站密碼泄露就會造成很大的安全隱患。由于有了這么多前車之鑒,我們現在做系統時,密碼都要加密處理。

這次泄密,也留下了一些有趣的事情,特別是對于廣大程序員設置密碼這一項。人們從 CSDN 泄密的文件中,發現了一些好玩的密碼,例如如下這些:

ppnn13%dkstFeb.1st 這段密碼的中文解析是:娉娉裊裊十三余,豆蔻梢頭二月初。 csbt34.ydhl12s 這段密碼的中文解析是:池上碧苔三四點,葉底黃鸝一兩聲 ...

等等不一而足,你會發現很多程序員的人文素養還是非常高的,讓人嘖嘖稱奇。

2.加密方案

密碼加密我們一般會用到散列函數,又稱散列算法、哈希函數,這是一種從任何數據中創建數字“指紋”的方法。

散列函數把消息或數據壓縮成摘要,使得數據量變小,將數據的格式固定下來,然后將數據打亂混合,重新創建一個散列值。散列值通常用一個短的隨機字母和數字組成的字符串來代表。好的散列函數在輸入域中很少出現散列沖突。在散列表和數據處理中,不抑制沖突來區別數據,會使得數據庫記錄更難找到。

我們常用的散列函數有 MD5 消息摘要算法、安全散列算法(Secure Hash Algorithm)。

但是僅僅使用散列函數還不夠,單純的只使用散列函數,如果兩個用戶密碼明文相同,生成的密文也會相同,這樣就增加的密碼泄漏的風險。

為了增加密碼的安全性,一般在密碼加密過程中還需要加鹽,所謂的鹽可以是一個隨機數也可以是用戶名,加鹽之后,即使密碼明文相同的用戶生成的密碼密文也不相同,這可以極大的提高密碼的安全性。

傳統的加鹽方式需要在數據庫中有專門的字段來記錄鹽值,這個字段可能是用戶名字段(因為用戶名唯一),也可能是一個專門記錄鹽值的字段,這樣的配置比較繁瑣。

Spring Security 提供了多種密碼加密方案,官方推薦使用 BCryptPasswordEncoder,BCryptPasswordEncoder 使用 BCrypt 強哈希函數,開發者在使用時可以選擇提供 strength 和 SecureRandom 實例。strength 越大,密鑰的迭代次數越多,密鑰迭代次數為 2^strength。strength 取值在 4~31 之間,默認為 10。

不同于 Shiro 中需要自己處理密碼加鹽,在 Spring Security 中,BCryptPasswordEncoder 就自帶了鹽,處理起來非常方便。

3.實踐

3.1 codec 加密

commons-codec 是一個 Apache 上的開源項目,用它可以方便的實現密碼加密。松哥在 V 部落 項目中就是采用的這種方案(https://github.com/lenve/VBlog)。在 Spring Security 還未推出 BCryptPasswordEncoder 的時候,commons-codec 還是一個比較常見的解決方案。

所以,這里我先來給大家介紹下 commons-codec 的用法。

首先我們需要引入 commons-codec 的依賴:

<dependency> <groupId>commons-codec</groupId> <artifactId>commons-codec</artifactId> <version>1.11</version></dependency>

然后自定義一個 PasswordEncoder:

@Componentpublic class MyPasswordEncoder implements PasswordEncoder { @Override public String encode(CharSequence rawPassword) { return DigestUtils.md5DigestAsHex(rawPassword.toString().getBytes()); } @Override public boolean matches(CharSequence rawPassword, String encodedPassword) { return encodedPassword.equals(DigestUtils.md5DigestAsHex(rawPassword.toString().getBytes())); }}

在 Spring Security 中,PasswordEncoder 專門用來處理密碼的加密與比對工作,我們自定義 MyPasswordEncoder 并實現 PasswordEncoder 接口,還需要實現該接口中的兩個方法:

encode 方法表示對密碼進行加密,參數 rawPassword 就是你傳入的明文密碼,返回的則是加密之后的密文,這里的加密方案采用了 MD5。 matches 方法表示對密碼進行比對,參數 rawPassword 相當于是用戶登錄時傳入的密碼,encodedPassword 則相當于是加密后的密碼(從數據庫中查詢而來)。

最后記得將 MyPasswordEncoder 通過 @Component 注解標記為 Spring 容器中的一個組件。

這樣用戶在登錄時,就會自動調用 matches 方法進行密碼比對。

當然,使用了 MyPasswordEncoder 之后,在用戶注冊時,就需要將密碼加密之后存入數據庫中,方式如下:

public int reg(User user) { ... //插入用戶,插入之前先對密碼進行加密 user.setPassword(passwordEncoder.encode(user.getPassword())); result = userMapper.reg(user); ...}

其實很簡單,就是調用 encode 方法對密碼進行加密。完整代碼大家可以參考 V 部落(https://github.com/lenve/VBlog),我這里就不贅述了。

3.2 BCryptPasswordEncoder 加密

但是自己定義 PasswordEncoder 還是有些麻煩,特別是處理密碼加鹽問題的時候。

所以在 Spring Security 中提供了 BCryptPasswordEncoder,使得密碼加密加鹽變得非常容易。只需要提供 BCryptPasswordEncoder 這個 Bean 的實例即可,微人事就是采用了這種方案(https://github.com/lenve/vhr),如下:

@BeanPasswordEncoder passwordEncoder() { return new BCryptPasswordEncoder(10);}

創建 BCryptPasswordEncoder 時傳入的參數 10 就是 strength,即密鑰的迭代次數(也可以不配置,默認為 10)。同時,配置的內存用戶的密碼也不再是 123 了,如下:

auth.inMemoryAuthentication().withUser('admin').password('$2a$10$RMuFXGQ5AtH4wOvkUqyvuecpqUSeoxZYqilXzbz50dceRsga.WYiq').roles('ADMIN', 'USER').and().withUser('sang').password('$2a$10$eUHbAOMq4bpxTvOVz33LIehLe3fu6NwqC9tdOcxJXEhyZ4simqXTC').roles('USER');

這里的密碼就是使用 BCryptPasswordEncoder 加密后的密碼,雖然 admin 和 sang 加密后的密碼不一樣,但是明文都是 123。配置完成后,使用 admin/123 或者 sang/123 就可以實現登錄。

本案例使用了配置在內存中的用戶,一般情況下,用戶信息是存儲在數據庫中的,因此需要在用戶注冊時對密碼進行加密處理,如下:

@Servicepublic class RegService { public int reg(String username, String password) { BCryptPasswordEncoder encoder = new BCryptPasswordEncoder(10); String encodePasswod = encoder.encode(password); return saveToDb(username, encodePasswod); }}

用戶將密碼從前端傳來之后,通過調用 BCryptPasswordEncoder 實例中的 encode 方法對密碼進行加密處理,加密完成后將密文存入數據庫。

4.源碼淺析

最后我們再來稍微看一下 PasswordEncoder。

PasswordEncoder 是一個接口,里邊只有三個方法:

public interface PasswordEncoder { String encode(CharSequence rawPassword); boolean matches(CharSequence rawPassword, String encodedPassword); default boolean upgradeEncoding(String encodedPassword) { return false; }} encode 方法用來對密碼進行加密。 matches 方法用來對密碼進行比對。 upgradeEncoding 表示是否需要對密碼進行再次加密以使得密碼更加安全,默認為 false。

Spring Security 為 PasswordEncoder 提供了很多實現:

Spring Boot 中密碼加密的兩種方法

但是老實說,自從有了 BCryptPasswordEncoder,我們很少關注其他實現類了。

PasswordEncoder 中的 encode 方法,是我們在用戶注冊的時候手動調用。

matches 方法,則是由系統調用,默認是在 DaoAuthenticationProvider#additionalAuthenticationChecks 方法中調用的。

protected void additionalAuthenticationChecks(UserDetails userDetails, UsernamePasswordAuthenticationToken authentication) throws AuthenticationException { if (authentication.getCredentials() == null) { logger.debug('Authentication failed: no credentials provided'); throw new BadCredentialsException(messages.getMessage( 'AbstractUserDetailsAuthenticationProvider.badCredentials', 'Bad credentials')); } String presentedPassword = authentication.getCredentials().toString(); if (!passwordEncoder.matches(presentedPassword, userDetails.getPassword())) { logger.debug('Authentication failed: password does not match stored value'); throw new BadCredentialsException(messages.getMessage( 'AbstractUserDetailsAuthenticationProvider.badCredentials', 'Bad credentials')); }}

可以看到,密碼比對就是通過 passwordEncoder.matches 方法來進行的。

關于 DaoAuthenticationProvider 的調用流程,大家可以參考 SpringSecurity 自定義認證邏輯的兩種方式(高級玩法)一文。

好了,今天就和小伙伴們簡單聊一聊 Spring Security 加密問題,小伙伴們要是有收獲記得點個在看鼓勵下松哥哦~

以上就是Spring Boot 中密碼加密的兩種方法的詳細內容,更多關于Spring Boot 密碼加密的資料請關注好吧啦網其它相關文章!

標簽: Spring
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
亚洲大黄网站| 欧美亚洲免费在线一区| 色婷婷精品大在线视频| 综合自拍亚洲综合图不卡区| 91麻豆免费观看| 精品久久久久一区| 国产91高潮流白浆在线麻豆| 欧美色爱综合网| 天天操天天干天天综合网| 99精品99久久久久久宅男| 久久综合色播五月| 成人aaaa免费全部观看| 91精品国产91久久综合桃花| 黄一区二区三区| 欧美男人的天堂一二区| 久久国产视频网| 欧美猛男gaygay网站| 极品尤物av久久免费看| 欧美日韩视频专区在线播放| 精品无人码麻豆乱码1区2区 | 国产福利一区二区三区在线视频| 欧美日韩国产一区二区三区地区| 九色综合狠狠综合久久| 在线观看91av| 国产成人精品综合在线观看| 日韩一区二区电影| 不卡的av在线| 国产人成亚洲第一网站在线播放| 国产精品swag| 亚洲人成在线观看一区二区| 亚洲精品影视| 亚洲国产毛片aaaaa无费看 | 欧美成人在线免费观看| 中文一区在线播放| 亚洲精品欧洲精品| 偷窥国产亚洲免费视频| 在线观看免费一区| 久久国产精品免费| 777亚洲妇女| caoporn国产精品| 国产精品色噜噜| 亚洲高清视频一区二区| 夜夜嗨av一区二区三区四季av | 久久久夜夜夜| 国产一区二区主播在线| 26uuu亚洲综合色| 欧美另类视频在线| 亚洲视频在线一区| 性高湖久久久久久久久| 老司机免费视频一区二区| 欧美一卡在线观看| 午夜免费电影一区在线观看| 亚洲免费av网站| 欧日韩精品视频| av亚洲精华国产精华精华| 国产精品婷婷午夜在线观看| 国产欧美午夜| 蜜桃视频一区二区三区| 日韩一二三区视频| 欧美精品啪啪| 亚洲成精国产精品女| 欧美色精品在线视频| 99国产欧美另类久久久精品| 亚洲少妇最新在线视频| 欧洲国产伦久久久久久久| 国产二区国产一区在线观看| 久久欧美一区二区| 国产一区二区三区高清| 精品一区二区三区免费| 亚洲国产高清aⅴ视频| 色综合久久久久| 白白色亚洲国产精品| 夜夜精品视频一区二区| 6080国产精品一区二区| 女人色偷偷aa久久天堂| 亚洲不卡一区二区三区| 欧美一三区三区四区免费在线看 | 欧美视频在线观看一区二区| 91麻豆国产香蕉久久精品| 一区二区三区高清在线| 9191精品国产综合久久久久久| 91日韩在线专区| 亚洲不卡在线观看| 精品国产乱码久久久久久图片 | 国产欧美不卡| 国产九色精品成人porny| 亚洲欧洲日本在线| 欧美日韩精品福利| 欧美日本一区二区高清播放视频| 五月激情丁香一区二区三区| 精品国一区二区三区| 久久国产精品久久w女人spa| 不卡一区中文字幕| 亚洲h在线观看| 久久综合色综合88| 噜噜噜噜噜久久久久久91| 成人精品gif动图一区| 伊人夜夜躁av伊人久久| 欧美一区二区播放| 亚洲在线视频| av不卡在线观看| 日本一道高清亚洲日美韩| 中国色在线观看另类| 欧美亚洲国产一区在线观看网站| 亚洲欧美文学| 国产一区二区0| 亚洲综合一区二区精品导航| 精品日韩一区二区| 美女诱惑黄网站一区| 欧美69视频| 国内外成人在线| 亚洲欧美国产77777| 欧美一区二区在线免费观看| 亚洲综合电影一区二区三区| 91网上在线视频| 经典一区二区三区| 亚洲高清三级视频| 国产精品麻豆99久久久久久| 欧美伦理影视网| 国产一级久久| 色综合视频一区二区三区高清| 免费成人美女在线观看.| 中文字幕在线一区二区三区| 日韩一卡二卡三卡国产欧美| 久久九九精品| 亚洲激情影院| 99久久99久久精品免费看蜜桃| 日韩经典中文字幕一区| 最新欧美精品一区二区三区| 日韩欧美一二区| 欧美视频一区二区三区| 亚洲狼人精品一区二区三区| 成人激情午夜影院| 另类调教123区| 亚洲成人动漫一区| 亚洲欧洲av一区二区三区久久| 欧美tickling挠脚心丨vk| 欧美日韩免费观看一区三区| 亚洲专区一区| 日韩视频精品在线观看| 欧美69视频| 欧美一区二区三区久久精品茉莉花 | 日韩亚洲国产精品| 女女同性女同一区二区三区91| 国产成人免费高清| 久久国内精品自在自线400部| 亚洲国产精品久久人人爱蜜臀| 国产精品久久精品日日| 欧美不卡一二三| 777精品伊人久久久久大香线蕉| 一区二区日韩免费看| 亚洲第一黄色| 悠悠资源网久久精品| 午夜精品久久| 国产不卡视频在线观看| 欧美精品入口| 91丝袜美腿高跟国产极品老师 | 欧美三级蜜桃2在线观看| 免费h精品视频在线播放| 日韩午夜免费视频| 亚洲狼人精品一区二区三区| 欧美午夜国产| 欧美另类亚洲| 欧美亚洲不卡| 亚洲婷婷在线| 欧美日韩精品一区| 色综合久久综合网97色综合| 99精品欧美一区| 成人h精品动漫一区二区三区| 国产成人8x视频一区二区| 国产91在线观看| 成人在线综合网站| 国产成人av一区二区| 国产精品资源在线观看| 国产精品中文有码| 国产一区视频在线看| 国产伦精品一区二区三区在线观看 | 欧美电影免费观看完整版| 51精品秘密在线观看| 7777精品伊人久久久大香线蕉最新版| 欧美精品第1页| 欧美一区二区三区在线看| 日韩精品最新网址| 337p粉嫩大胆噜噜噜噜噜91av| 久久亚洲春色中文字幕久久久| 久久久亚洲高清| 中文字幕av一区 二区| 国产精品高潮久久久久无| 亚洲欧美另类久久久精品| 亚洲精品免费一二三区| 五月婷婷另类国产| 看片网站欧美日韩| 国产精品一区在线观看你懂的| 极品美女销魂一区二区三区| 国产精品99久久久久久有的能看| 国产成人免费视| 欧美不卡一卡二卡免费版| 亚洲欧洲综合| 色94色欧美sute亚洲线路一ni| 精品一区二区日韩|