密码学综述

密码学基本功能

机密性、鉴别、报文完整性、不可否认性

基本模型

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
03-05 18:25