专业的编程技术博客社区

网站首页 > 博客文章 正文

干货6:Java实现Base64加密(干货6:Java实现Base6加密工具)

baijin 2024-09-04 01:47:24 博客文章 5 ℃ 0 评论

Java实现Base64加密

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));//解密后的结果

}

}

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表