JAVA加密演算法(1)- 密碼學概述及BASE64演算法使用
阿新 • • 發佈:2018-12-21
密碼學綜述
密碼學綜述
密碼學基本功能
機密性、鑑別、報文完整性、不可否認性
基本模型
sender-->加密演算法 --> 密文 --> 解密演算法 --> receiver
金鑰源
密碼學演算法分類:
訊息編碼:Base64
訊息摘要:MD類,SHA類,MAC
對稱加密:DES,3DES,AES
非對稱加密:RSA,DH金鑰交換
數字簽名:RSA signature,DSA signature
密碼學五元組
明文、密文、加密演算法、解密演算法、金鑰
加密解密演算法都要使用公開演算法(經過驗證)
Java程式設計中的常用類
(1)訊息編碼
BASE64Encoder,BASE64Decoder
(2)訊息摘要
MessageDigest
(3)對稱密碼
KeyGenerator、SecretKey、Cipher
(4)非對稱密碼
KeyPairGenerator、KeyFactory、KeyPair、PublicKey、PrivateKey、Cipher
(5)數字簽名
Signature
JDK提供的Base64編碼操作
import java.io.IOException; import sun.misc.BASE64Decoder; import sun.misc.BASE64Encoder; public class Base64Util { public static String encrypt(byte[] data) { return new BASE64Encoder().encode(data); } public static String decrypt(String data) throws IOException { return new String(new BASE64Decoder().decodeBuffer(data)); } public static void main(String[] args) throws IOException { String data = "1234567890"; String result = Base64Util.encrypt(data.getBytes()); System.out.println(data +" 使用Base64編碼的結果: "+result); String result2 = Base64Util.decrypt(result); System.out.println(result + "使用Base64解碼的結果:" +result2); } }
執行結果:
1234567890 使用Base64編碼的結果: MTIzNDU2Nzg5MA==
MTIzNDU2Nzg5MA==使用Base64解碼的結果:1234567890
PS1:
Eclipse中找不到sun.misc.BASE64Encoder包的解決方法:
在工程的build path中先移除JRE System Library,再新增庫JRE System Library,重新編譯後就一切正常了。
PS2:
其他提供Base64操作的jar包,
Apache Commons Codec(簡稱CC),
Bouncy Castle(BC)