密码学综述
密码学基本功能
机密性、鉴别、报文完整性、不可否认性
基本模型
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)