java必懂的冷知識(shí)點(diǎn)之Base64加密與解密
為了安全地進(jìn)行數(shù)據(jù)傳輸,就需要對(duì)數(shù)據(jù)進(jìn)行加密與解密操作,Base64就是Java提供的加密處理器。本博客主要講解Base64工具類的使用以及加密和解密信息操作實(shí)現(xiàn)。
Base64是一種直接利用64個(gè)可打印字符來(lái)表示二進(jìn)制數(shù)據(jù)的算法,也是網(wǎng)絡(luò)傳輸中較為常見(jiàn)的一種加密算法。從JDK1.8版本開(kāi)始提供java.util.Base64的工具類,同時(shí)提供了兩個(gè)Base64的內(nèi)部類實(shí)現(xiàn)數(shù)據(jù)加密與解密操作。
【數(shù)據(jù)加密】java.util.Base64.Encoder, 對(duì)象獲取方法:public static Base64.Encoder getEncoder()。數(shù)據(jù)加密處理:public byte[] encoder(byte[] src)。
【數(shù)據(jù)解密】java.util.Base64.Decoder, 對(duì)象獲取方法:public static Base64.Decoder getDecoder()。數(shù)據(jù)解密處理:public byte[] decoer (String src)。
### 范例:實(shí)現(xiàn)Base64加密與解密操作package cn.mldn.demo;import java.util.Base64;public class JavaAPIDemo{ public static void main(String[] args) throws Exception{ String msg='www.mldn.cn'; //原始內(nèi)容 String encMsg=new String(Base64.getEncoder().encode(msg.getBytes()));//數(shù)據(jù)加密 System.out.println(encMsg); //輸出密文 String oldMsg=new String(Base64.getDecoder().decode(encMsg)); //數(shù)據(jù)解密 System.out.println(oldMsg); //輸出明文 }}
程序執(zhí)行結(jié)果:d3d3Lm1sZG4uY24=(密文)www.mldn.cn(明文)
本程序直接利用Base64提供的方法獲取了Base64.Encoder與Base64.Decoder實(shí)例化對(duì)象,并且對(duì)原始數(shù)據(jù)進(jìn)行了加密與解密處理。但需要注意的是,由于Base64屬于JDK的原始實(shí)現(xiàn),所以單純地加密是不安全的,此時(shí)為了獲取更加安全的數(shù)據(jù)加密操作,可以利用鹽值(salt)、自定義格式以及多次加密的方式來(lái)保證項(xiàng)目中的數(shù)據(jù)安全。
### 范例:基于Base64定義復(fù)雜加密與解密操作package cn.mldn.demo;import java.util.Base64;class StringUtil{private static final String SALT='mldnjava'; //公共的鹽值private static final int REPEAT=5; //加密次數(shù)public static String encode(String str) { //加密處理String temp=str+'{'+SALT+'}';//鹽值對(duì)外不公布byte data[]=temp.getBytes();//將字符串變?yōu)樽止?jié)數(shù)組for(int x=0;x<REPEAT;x++)data=Base64.getEncoder().encode(data); //重復(fù)加密return new String(data); //返回加密后的內(nèi)容}public static String decode(String str) {byte data[]=str.getBytes();//獲取加密內(nèi)容for(int x=0;x<REPEAT;x++)data=Base64.getDecoder().decode(data); //多次解密return new String(data).replaceAll('{w+}',''); //刪除鹽值格式}} public class JavaAPIDemo{ public static void main(String[] args) throws Exception{ String str=StringUtil.encode('www.mldn.cn'); System.out.println(StringUtil.decode(str)); } }
本程序基于Base64類的功能實(shí)現(xiàn)了一個(gè)自定義加密與解密程序,為了保證加密后的數(shù)據(jù)安全,采用的鹽值格式為“鹽值{原始數(shù)據(jù)}”,同時(shí)利用多次加密的形式確保了密文數(shù)據(jù)的可靠性。在實(shí)際開(kāi)發(fā)中只要不對(duì)外公布鹽值內(nèi)容和加密次數(shù)就可以在較為安全的環(huán)境下進(jìn)行數(shù)據(jù)傳輸.
到此這篇關(guān)于java必懂的冷知識(shí)點(diǎn)之Base64加密與解密的文章就介紹到這了,更多相關(guān)java Base64加密與解密內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. python中scrapy處理項(xiàng)目數(shù)據(jù)的實(shí)例分析2. 教你在 IntelliJ IDEA 中使用 VIM插件的詳細(xì)教程3. IntelliJ IDEA導(dǎo)入jar包的方法4. js抽獎(jiǎng)轉(zhuǎn)盤(pán)實(shí)現(xiàn)方法分析5. Python requests庫(kù)參數(shù)提交的注意事項(xiàng)總結(jié)6. vue-electron中修改表格內(nèi)容并修改樣式7. iOS實(shí)現(xiàn)點(diǎn)贊動(dòng)畫(huà)特效8. 通過(guò)Python pyecharts輸出保存圖片代碼實(shí)例9. JavaScript中l(wèi)ayim之整合右鍵菜單的示例代碼10. SpringBoot參數(shù)校驗(yàn)與國(guó)際化使用教程
