Java如何實(shí)現(xiàn)密碼加密
在查詢(xún)時(shí),我們?nèi)绻獙?duì)用戶(hù)的登錄信息進(jìn)行加密,通常會(huì)將其密碼進(jìn)行加密.
1) 可以借助spring框架工具類(lèi)DigestUtils
2) 也可以使用shiro框架來(lái)實(shí)現(xiàn)
//保存用戶(hù)自身信息//1構(gòu)建一個(gè)鹽值對(duì)象String salt=UUID.randomUUID().toString();//隨機(jī)字符串//2對(duì)密碼進(jìn)行鹽值加密(加密算法MD5-特點(diǎn):不可逆,相同內(nèi)容加密結(jié)果也相同)//2.1加密方式1(借助spring框架工具類(lèi)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();生成的是一個(gè)隨機(jī)字符串.
SimpleHash sh=new SimpleHash('MD5', entity.getPassword(), salt, 1);
這行shiro框架提供的加密中,
第一個(gè)參數(shù)'MD5'為加密算法,其特點(diǎn):不可逆(只能加密不能解密),但是相同內(nèi)容加密結(jié)果也相同;
第二個(gè)參數(shù)source,代表原密碼;
第三個(gè)參數(shù)salt,就是我們先生成的鹽值隨機(jī)數(shù);
第四個(gè)參數(shù)1,代表加密次數(shù),我們這里只加密了一次.
entity.setSalt(salt);entity.setPassword(sh.toHex());
加密處理過(guò)后,我們?cè)賹⑿滦薷牡拿艽a轉(zhuǎn)換為16進(jìn)制數(shù)賦值給對(duì)象,salt的傳遞看你對(duì)象屬性的設(shè)置.
然后再根據(jù)新的對(duì)象內(nèi)的數(shù)據(jù)進(jìn)行操作即可.
以上就是Java如何實(shí)現(xiàn)密碼加密的詳細(xì)內(nèi)容,更多關(guān)于Java密碼加密的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. ASP新手必備的基礎(chǔ)知識(shí)2. CentOS郵箱服務(wù)器搭建系列——SMTP服務(wù)器的構(gòu)建( Postfix )3. PHP基礎(chǔ)之生成器4——比較生成器和迭代器對(duì)象4. asp文件用什么軟件編輯5. Vue axios獲取token臨時(shí)令牌封裝案例6. 利用CSS制作3D動(dòng)畫(huà)7. golang中json小談之字符串轉(zhuǎn)浮點(diǎn)數(shù)的操作8. js實(shí)現(xiàn)計(jì)算器功能9. 通過(guò)IEAD+Maven快速搭建SSM項(xiàng)目的過(guò)程(Spring + Spring MVC + Mybatis)10. JS中6個(gè)對(duì)象數(shù)組去重的方法

網(wǎng)公網(wǎng)安備