Java实现Base64加密-济南IT培训
MD5是单向加密,不存在解密的过程;
明文:待加密的信息;
密文:经过加密后的明文;
加密:明文转换为密文的过程;
加密算法:明文转为密文的转换算法;
加密密钥:通过加密算法进行加密操作作用的密钥;
解密:将密文转为明文的过程;
解密算法:密文转为明文的算法;
解密密钥:通过解密算法进行解密操作作用的密钥;
密钥分析:截获密文者,试图通过分析截获的密文,从而推断出原来的明文或者密钥的过程;
主动攻击:攻击者非法入侵密码系统,采用伪造,修改,删除等手段向系统注入假消息进行欺骗;
(对密文具有破坏作用)
被动攻击:对一个保密系统采取截获密文并对其进行分析和攻击(对密文没有破坏作用)
密码体制:由明文空间,密文空间,密钥空间,加密算法和解密算法五部分组成;
密码协议:也叫安全协议,以密码学为基础的消息交换j的通信协议,目的是在网络环境中提供安全的服务;
密码系统:是指用于加密,解密的系统;
柯克霍夫原则:数据的安全基于密钥而不是算法的保密;即系统的安全取决于密钥;
对密钥保密,对算法公开;是现代密钥学设计的基本原则;
密码分类:古典密码和现代密码;
古典密码:以字符为基本加密单元;
现代密码:以信息块为基本加密单元;
散列函数是用来验证数据的完整性;特点:长度不受限制,哈希值容易计算;散列运算过程不可逆;
散列函数的相关算法:消息摘要算法MD5等,SHA--安全散列算法,MAC--消息认证码算法(针对于苹果操作系统);
数字签名:主要是针对于以数字的形式存储的消息进行的处理;
一下是相关的代码案例:
import java.io.IOException;
import org.apache.commons.codec.binary.Base64;
import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;
public class ImoocBase64 {
private static String src="security base64";
public static void main(String[] args) {
//jdkBase64();
//commonsCodesBase64();
bouncyCastleBase64();
}
/**
* jdk实现base64算法
*/
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 (IOException e) {
e.printStackTrace();
}
}
/**
* CC实现Base64算法
*/
public static void commonsCodesBase64(){
byte[] encodeBytes=Base64.encodeBase64(src.getBytes());
System.out.println("encode:"+new String(encodeBytes));//加密后的结果
byte[] decodeBytes=Base64.decodeBase64(encodeBytes);
System.out.println("decode:"+new String(decodeBytes));//解密后的结果
}
/**
* BC实现Base64算法
*/
public static void bouncyCastleBase64(){
byte[] encodeBytes=org.bouncycastle.util.encoders.Base64.encode(src.getBytes());//加密后的结果
System.out.println("encode:"+new String(encodeBytes));
byte[] decodeBytes=org.bouncycastle.util.encoders.Base64.decode(encodeBytes);
System.out.println("decode:"+new String(decodeBytes));//解密后的结果
}
}
更多济南IT培训相关咨询,请扫描下方二维码