Java如何實現(xiàn)密碼加密
在查詢時,我們?nèi)绻獙τ脩舻牡卿浶畔⑦M行加密,通常會將其密碼進行加密.
1) 可以借助spring框架工具類DigestUtils
2) 也可以使用shiro框架來實現(xiàn)
//保存用戶自身信息
//1構(gòu)建一個鹽值對象
String salt=UUID.randomUUID().toString();//隨機字符串
//2對密碼進行鹽值加密(加密算法MD5-特點:不可逆,相同內(nèi)容加密結(jié)果也相同)
//2.1加密方式1(借助spring框架工具類DigestUtils)
//String newPassword=DigestUtils.md5DigestAsHex((salt+entity.getPassword()).getBytes());
//2.2加密方式2(借助shiro框架中的API)
SimpleHash sh=new SimpleHash("MD5", entity.getPassword(), salt, 1);
String newPassword=sh.toHex();
System.out.println("newPassword="+newPassword);
entity.setSalt(salt);
entity.setPassword(newPassword);
以上就是兩者方式分別使用,
注意:
鹽值salt:UUID.randomUUID().toString();生成的是一個隨機字符串.
SimpleHash sh=new SimpleHash("MD5", entity.getPassword(), salt, 1);
這行shiro框架提供的加密中,
第一個參數(shù)"MD5"為加密算法,其特點:不可逆(只能加密不能解密),但是相同內(nèi)容加密結(jié)果也相同;
第二個參數(shù)source,代表原密碼;
第三個參數(shù)salt,就是我們先生成的鹽值隨機數(shù);
第四個參數(shù)1,代表加密次數(shù),我們這里只加密了一次.
entity.setSalt(salt); entity.setPassword(sh.toHex());
加密處理過后,我們再將新修改的密碼轉(zhuǎn)換為16進制數(shù)賦值給對象,salt的傳遞看你對象屬性的設置.
然后再根據(jù)新的對象內(nèi)的數(shù)據(jù)進行操作即可.
以上就是Java如何實現(xiàn)密碼加密的詳細內(nèi)容,更多關(guān)于Java密碼加密的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Java中Executor和Executors的區(qū)別小結(jié)
在Java并發(fā)編程中,Executor是一個核心接口,提供了任務執(zhí)行的抽象方法,而Executors是一個工具類,提供了創(chuàng)建各種線程池的工廠方法,Executor關(guān)注任務的執(zhí)行,而Executors關(guān)注如何創(chuàng)建適合的執(zhí)行器,感興趣的可以了解一下2024-10-10
解決spring AOP中自身方法調(diào)用無法應用代理的問題
這篇文章主要介紹了解決spring AOP中自身方法調(diào)用無法應用代理的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08
SpringCloud客戶端報錯:- was unable to send&nb
這篇文章主要介紹了SpringCloud客戶端報錯:- was unable to send heartbeat!的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05

