關于maven項目中使用BCrypt加密方式
maven項目中使用BCrypt加密
BCrypt是一種密碼散列函數,主要用于安全地存儲和驗證用戶密碼。
它是Blowfish加密算法的一種變體,由Niels Provos設計并在1999年發(fā)布。
BCrypt的設計目標是為了抵御彩虹表攻擊和暴力/破解,它通過引入鹽(salt)和工作因子(cost factor)來增加計算復雜度,從而使得密碼哈希更加安全。
- 1. Salt(鹽):每個密碼哈希都使用不同的隨機鹽值,這使得即使兩個用戶使用相同的密碼,他們的哈希也會不同,增加了密碼被破解的難度。
- 2. Adaptive Work Factor(適應性工作因子):BCrypt允許設置一個工作因子,它決定了計算哈希所需的時間。較高的工作因子意味著更長的計算時間和更高的安全性,但同時也意味著更多的CPU資源消耗。
- 3. Cost Parameter(成本參數):工作因子通常被稱為“成本參數”,因為它反映了計算哈希的成本。隨著硬件性能的提升,可以逐漸增加成本參數以保持哈希計算的難度,確保安全性不隨時間降低。
- 4. Iterative Hashing(迭代哈希):BCrypt使用迭代哈希過程,這意味著它會多次運行哈希算法,以增加破解難度。
- 5. Key Stretching(密鑰擴展):BCrypt的迭代過程也是一種密鑰擴展技術,它增加了密碼到密鑰轉換的時間,降低了暴力攻擊的速度。
在實際應用中,BCrypt通常用于Web應用程序和其他需要安全存儲用戶密碼的系統(tǒng)中。
許多現代框架和庫,如Spring Security、Django、Ruby on Rails等,都內置了對BCrypt的支持。
第一步
maven的pom文件里引入依賴
<!--BCrypt依賴--> <dependency> <groupId>org.mindrot</groupId> <artifactId>jbcrypt</artifactId> <version>0.4</version> </dependency>
第二步
service的實現類serviceImpl里引入(根據自己的需要更改代碼)
user.setPassword(BCrypt.hashpw(reqVo.getPassword(),BCrypt.gensalt()));
第三步
測試
{ "username": "134", "account": "dkk", "password": "144", "address": "小王", "phone": "135555551" , "create_time":"2011" }
效果如圖
總結
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Java使用Apache POI庫讀取Excel表格文檔的示例
POI庫是Apache提供的用于在Windows下讀寫各類微軟Office文檔的Java庫,這里我們就來看一下Java使用Apache POI庫讀取Excel表格文檔的示例:2016-06-06java 較大數據量取差集,list.removeAll性能優(yōu)化詳解
這篇文章主要介紹了java 較大數據量取差集,list.removeAll性能優(yōu)化詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09