關(guān)于Base64的使用,相對(duì)應(yīng)的可以延伸的了解學(xué)習(xí)其他相關(guān)加密方式的使用方法刑桑。
一般加密都可以使用三種加密方式氯质,JDK自帶API(JDK),Apache的common codes(CC)祠斧,用bouncy castle(BC)實(shí)現(xiàn)闻察。
三種實(shí)際,就Base64而言:
- jdk琢锋,支持jdk1.8以上辕漂,但是不推薦使用,后面多加換行吴超,安卓和java使用的補(bǔ)=好的方式也不太相同(未深入研究)钉嘹。
- common codes相當(dāng)于是對(duì)jdk實(shí)現(xiàn)加密方式的封裝,更簡(jiǎn)潔方便鲸阻,并兼容問(wèn)題跋涣,常推薦使用赘娄。
- bouncy castle的實(shí)現(xiàn)仆潮,相當(dāng)于補(bǔ)充了jdk所不存在的加密方式,不管是字節(jié)數(shù)遣臼,還是填充方式等性置,在做IOS安卓的聯(lián)調(diào)時(shí),需要的填充方式揍堰,還有加密方式可能都需要用到此種方式鹏浅,當(dāng)然也支持Base64,為了不引入更多的jar包嗅义,使用BC方式加密時(shí),建議使用BC的base64轉(zhuǎn)碼方式隐砸。
JDK的Base64的實(shí)現(xiàn)之碗,不許多余jar:
import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;
// 用jdk實(shí)現(xiàn)
public static void jdkBase64(){
try {
BASE64Encoder encoder = new BASE64Encoder();
String encode = encoder.encode(src.getBytes());
System.out.println("encode:" + encode);
BASE64Decoder decoder = new BASE64Decoder();
System.out.println("decode:" + new String(decoder.decodeBuffer(encode)));
} catch (Exception e) {
e.printStackTrace();
}
}
CC的Base64的實(shí)現(xiàn),需引入jar(commons-codec-1.10.jar):
import org.apache.commons.codec.binary.Base64;
// 用Apache的common codes實(shí)現(xiàn)
public static void commonsCodesBase64() {
byte[] encodeBytes = Base64.encodeBase64(src.getBytes());
System.out.println("common codes encode:" + new String(encodeBytes));
byte[] dencodeBytes = Base64.decodeBase64(encodeBytes);
System.out.println("common codes decode:" + new String(dencodeBytes));
}
BC的Base64的實(shí)現(xiàn)季希,需引入jar(bcprov-jdk15on-149.jar):
import org.bouncycastle.util.encoders.Base64;
// 用bouncy castle實(shí)現(xiàn)
public static void bouncyCastleBase64(){
byte[] encodeBytes = Base64.encode(src.getBytes());
System.out.println("bouncy castle encode:" + new String(encodeBytes));
byte[] dencodeBytes = Base64.decode(encodeBytes);
System.out.println("bouncy castle decode:" + new String(dencodeBytes));
}
BC和CC的加密方式褪那,不盡相同,但是實(shí)現(xiàn)的效果是一致的式塌,具體使用哪種方式博敬,當(dāng)根據(jù)項(xiàng)目需求引入。
除Base64外峰尝,AES偏窝,RSA都能夠使用JDK,BC武学,CC的方式實(shí)現(xiàn)祭往,在使用BC做加密操作的時(shí)候,可以不使用BC原生jar所持有的方式創(chuàng)建Key等操作火窒,而是使用JDK引入BC的注入方式來(lái)使用BC加密硼补,更加的簡(jiǎn)單操作,具體實(shí)現(xiàn)可以更具不同的加密方式搜索下沛鸵。
這周可能要忙一周括勺,所以下周會(huì)貼出所有的AES和RAS加密的實(shí)現(xiàn)方式缆八,使用JDK注入BC的方式曲掰,選擇不同的最終兼容安卓IOS的填充方式實(shí)現(xiàn),有興趣可以點(diǎn)一波關(guān)注下周更新哦~