本篇内容简要介绍BASE64、MD5、SHA、HMAC几种加密算法。
BASE64编码算法不算是真正的加密算法。
MD5、SHA、HMAC这三种加密算法,可谓是非可逆加密,就是不可解密的加密方法,我们称之为单向加密算法。我们通常只把他们作为加密的基础。单纯的以上三种的加密并不可靠。
BASE64
按照RFC2045的定义,Base64被定义为:Base64内容传送编码被设计用来把任意序列的8位字节描述为一种不易被人直接识别的形式。(The Base64 Content-Transfer-Encoding is designed to represent arbitrary sequences of octets in a form that need not be humanly readable.)
常见于邮件、http加密,截取http信息,你就会发现登录操作的用户名、密码字段通过BASE64加密的.图1.
-----------------------------------------------------------------
代码
/**
* BASE64解密
*
* @param key
* @return
* @throws Exception
*/
public static byte[] decryptBASE64(String key) throws Exception {
return (new BASE64Decoder()).decodeBuffer(key);
}
/**
* BASE64加密
*
* @param key
* @return
* @throws Exception
*/
public static String encryptBASE64(byte[] key) throws Exception {
return (new BASE64Encoder()).encodeBuffer(key);
}
主要就是BASE64Encoder、BASE64Decoder两个类,我们只需要知道使用对应的方法即可。另,BASE加密后产生的字节位数是8的倍数,如果不够位数以=符号填充。
MD5
MD5 -- message-digest algorithm 5 (信息-摘要算法)缩写,广泛用于加密和解密技术,常用于文件校验。校验?不管文件多大,经过MD5后都能生成唯一的MD5值。好比现在的ISO校验,都是MD5校验。怎么用?当然是把ISO经过MD5后产生MD5的值。一般下载linux-ISO的朋友都见过下载链接旁边放着MD5的串。就是用来验证文件是否一致的。
-------------------------
详见图2
------------------------------
代码
/**
* MD5加密
*
* @param data
* @return
* @throws Exception
*/
public static byte[] encryptMD5(byte[] data) throws Exception {
MessageDigest md5 = MessageDigest.getInstance(KEY_MD5);
md5.update(data);
return md5.digest();
}
通常我们不直接使用上述MD5加密。通常将MD5产生的字节数组交给BASE64再加密一把,得到相应的字符串。
SHA
SHA(Secure Hash Algorithm,安全散列算法),数字签名等密码学应用中重要的工具,被广泛地应用于电子商务等信息安全领域。虽然,SHA与MD5通过碰撞法都被破解了, 但是SHA仍然是公认的安全加密算法,较之MD5更为安全。
----------------------------------
图3
----------------------------------
代码
/**
* SHA加密
*
* @param data
* @return
* @throws Exception
*/
public static byte[] encryptSHA(byte[] data) throws Exception {
MessageDigest sha = MessageDigest.getInstance(KEY_SHA);
sha.update(data);
return sha.digest();
}
}
HMAC
HMAC(Hash Message Authentication Code,散列消息鉴别码,基于密钥的Hash算法的认证协议。消息鉴别码实现鉴别的原理是,用公开函数和密钥产生一个固定长度的值作为认证标识,用这个标识鉴别消息的完整性。使用一个密钥生成一个固定大小的小数据块,即MAC,并将其加入到消息中,然后传输。接收方利用与发送方共享的密钥进行鉴别认证等。
------------------------
图4
------------------------------
/**
* 初始化HMAC密钥
*
* @return
* @throws Exception
*/
public static String initMacKey() throws Exception {
KeyGenerator keyGenerator = KeyGenerator.getInstance(KEY_MAC);
SecretKey secretKey = keyGenerator.generateKey();
return encryptBASE64(secretKey.getEncoded());
}
/**
* HMAC加密
*
* @param data
* @param key
* @return
* @throws Exception
*/
public static byte[] encryptHMAC(byte[] data, String key) throws Exception {
SecretKey secretKey = new SecretKeySpec(decryptBASE64(key), KEY_MAC);
Mac mac = Mac.getInstance(secretKey.getAlgorithm());
mac.init(secretKey);
return mac.doFinal(data);
}
写出一个完整类
import java.security.MessageDigest;
import javax.crypto.KeyGenerator;
import javax.crypto.Mac;
import javax.crypto.SecretKey;
import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;
/**
* 基础加密组件
*
* @author 梁栋
* @version 1.0
* @since 1.0
*/
public abstract class Coder {
public static final String KEY_SHA = "SHA";
public static final String KEY_MD5 = "MD5";
/**
* MAC算法可选以下多种算法
*
* <pre>
* HmacMD5
* HmacSHA1
* HmacSHA256
* HmacSHA384
* HmacSHA512
* </pre>
*/
public static final String KEY_MAC = "HmacMD5";
/**
* BASE64解密
*
* @param key
* @return
* @throws Exception
*/
public static byte[] decryptBASE64(String key) throws Exception {
return (new BASE64Decoder()).decodeBuffer(key);
}
/**
* BASE64加密
*
* @param key
* @return
* @throws Exception
*/
public static String encryptBASE64(byte[] key) throws Exception {
return (new BASE64Encoder()).encodeBuffer(key);
}
/**
* MD5加密
*
* @param data
* @return
* @throws Exception
*/
public static byte[] encryptMD5(byte[] data) throws Exception {
6
MessageDigest md5 = MessageDigest.getInstance(KEY_MD5);
md5.update(data);
return md5.digest();
}
/**
* SHA加密
*
* @param data
* @return
* @throws Exception
*/
public static byte[] encryptSHA(byte[] data) throws Exception {
MessageDigest sha = MessageDigest.getInstance(KEY_SHA);
sha.update(data);
return sha.digest();
}
/**
* 初始化HMAC密钥
*
* @return
* @throws Exception
*/
public static String initMacKey() throws Exception {
KeyGenerator keyGenerator = KeyGenerator.getInstance(KEY_MAC);
SecretKey secretKey = keyGenerator.generateKey();
return encryptBASE64(secretKey.getEncoded());
}
/**
* HMAC加密
*
* @param data
* @param key
* @return
* @throws Exception
*/
public static byte[] encryptHMAC(byte[] data, String key) throws Exception {
SecretKey secretKey = new SecretKeySpec(decryptBASE64(key), KEY_MAC);
Mac mac = Mac.getInstance(secretKey.getAlgorithm());
mac.init(secretKey);
return mac.doFinal(data);
}
}
在写个测试类
import static org.junit.Assert.*;
import org.junit.Test;
/**
*
* @author 梁栋
* @version 1.0
* @since 1.0
*/
public class CoderTest {
@Test
public void test() throws Exception {
String inputStr = "简单加密";
System.err.println("原文:\n" + inputStr);
byte[] inputData = inputStr.getBytes();
String code = Coder.encryptBASE64(inputData);
System.err.println("BASE64加密后:\n" + code);
byte[] output = Coder.decryptBASE64(code);
String outputStr = new String(output);
System.err.println("BASE64解密后:\n" + outputStr);
// 验证BASE64加密解密一致性
assertEquals(inputStr, outputStr);
// 验证MD5对于同一内容加密是否一致
assertArrayEquals(Coder.encryptMD5(inputData), Coder
.encryptMD5(inputData));
// 验证SHA对于同一内容加密是否一致
assertArrayEquals(Coder.encryptSHA(inputData), Coder
.encryptSHA(inputData));
String key = Coder.initMacKey();
System.err.println("Mac密钥:\n" + key);
// 验证HMAC对于同一内容,同一密钥加密是否一致
assertArrayEquals(Coder.encryptHMAC(inputData, key), Coder.encryptHMAC(
inputData, key));
BigInteger md5 = new BigInteger(Coder.encryptMD5(inputData));
System.err.println("MD5:\n" + md5.toString(16));
BigInteger sha = new BigInteger(Coder.encryptSHA(inputData));
System.err.println("SHA:\n" + sha.toString(32));
BigInteger mac = new BigInteger(Coder.encryptHMAC(inputData, inputStr));
System.err.println("HMAC:\n" + mac.toString(16));
}
}
控制台输出
原文:
简单加密
BASE64加密后:
566A5Y2V5Yqg5a+G
BASE64解密后:
简单加密
Mac密钥:
uGxdHC+6ylRDaik++leFtGwiMbuYUJ6mqHWyhSgF4trVkVBBSQvY/a22xU8XT1RUemdCWW155Bke
pBIpkd7QHg==
MD5:
-550b4d90349ad4629462113e7934de56
SHA:
91k9vo7p400cjkgfhjh0ia9qthsjagfn
HMAC:
2287d192387e95694bdbba2fa941009a
BASE64的加密解密是双向的,可以求反解。
MD5、SHA以及HMAC是单向加密,任何数据加密后只会产生唯一的一个加密串,通常用来校验数据在传输过程中是否被修改。其中HMAC算法有一个密钥,增强了数据传输过程中的安全性,强化了算法外的不可控因素。
单向加密的用途主要是为了校验数据在传输过程中是否被修改。
- 大小: 17.5 KB
- 大小: 25 KB
- 大小: 25.1 KB
- 大小: 25.9 KB
分享到:
相关推荐
在“https单项认证”中,只有服务器向客户端展示其证书并被验证,客户端的身份不需要验证,这是大多数网站使用的默认模式,适用于只需要保护服务器数据安全的场景。双向认证则要求客户端也需要提供证书,常用于银行...
为了实现文件加密,可能使用了Java的`javax.crypto`包,其中包含了一系列的加密算法,如AES(高级加密标准)或RSA(公钥加密技术)等。 对于文件加密,FileManager可能提供了用户友好的交互界面,允许用户设定密码...
在系统实现中,作者使用了 Browser/Server 技术和 Java 语言,实现了多机同时工作,并对数据进行加密操作,保证了系统的安全性。系统的设计也考虑了可移植性和模块化,方便操作和维护。 论文还对 Java 语言和 JSP ...
标题中的“Tomcat配置HTTPS单项认证”涉及到的是在Apache Tomcat服务器上设置安全套接层(SSL)以实现HTTPS通信的过程,尤其是关于单向认证(也称为客户端认证)的配置。在互联网上,HTTPS是HTTP协议的安全版本,...
- 后端语言(如Java、Python、Node.js):实现服务器端的业务逻辑。 - 框架(Spring Boot、Django、Express.js):提供快速开发环境,简化开发流程。 - RESTful API 设计:实现前后端分离,提升系统的可扩展性和...
### Java编码规范考试知识点解析 #### 一、单项选择题 ...以上知识点涵盖了Java编程中常见的编码规范、多线程处理、数据加密、异常处理、安全编程等多个方面,对于Java开发者来说具有很高的参考价值。
8. **安全性**:作为在线考试系统,安全性是关键,可能涉及用户认证、数据加密、防止作弊等措施。 9. **用户体验**:系统设计应考虑易用性,包括简洁的界面、直观的操作流程,以及良好的响应速度。 10. **部署与...
- **多题型测试**:包含10个单项选择题,用户需按顺序作答,可取消答题,异常退出时系统会备份答题记录。 - **答题操作**:“上一题”、“下一题”和“完成”按钮,根据答题进度启用。 5. **测试结果界面** - ...
- 每套测试包含10个单项选择题。 - 用户需按顺序答题。 - 提交前可取消答题。 - 异常退出后可恢复进度(未登录用户无效)。 - **测试结果**: - 显示正确率及每题对错情况。 - 点击题目可查看原题及正确答案。 ...
Java 编写的核心客户端加密类。 包括以下内容: EnhancedBitMatrix ,替代 COLT 位矩阵,在 GF(2) 上实现通用线性运算。 Monomial ,GF(2) 上的单个单项式项的 COLT BitVector表示的扩展,例如 x 1 x 3 x 4 。 对于...
【Java在线考试系统】课程设计说明书主要涵盖了系统前端界面的设计,包括用户注册、登录、欢迎...在实际开发中,可能还需要考虑安全性(如密码加密存储)、错误处理、性能优化等方面,以确保系统的稳定性和用户友好性。
这包括事务处理、错误恢复机制以及数据加密等措施,防止数据丢失或泄露。 总之,Aquila作为一个强大的数据库迁移工具,不仅简化了不同数据库系统之间的数据迁移,还实现了与大数据平台的无缝对接,为企业级数据迁移...
基于Java WEB的教务管理系统的设计与实现 需求分析 1.1 功能需求分析 概要说明: 学生效劳系统 信息维护 密码修改 学生信息申请修改 信息查询 学生信息查询 申请情况查询 选课信息查询 学生成绩查询 活动报名 选课 ...
- 系统采用了Tomcat作为应用服务器,它是一个开源的Java Servlet容器,适用于构建Web应用程序。 - 数据库管理系统选择了Oracle 9i,这是一个功能强大的关系型数据库管理系统,用于存储和处理司法鉴定管理的数据。 ...
开发者可以根据自己的需求修改或扩展源码,例如添加心跳检测机制、加密通信、多线程处理等特性。 7. **注意事项**: - 当在Android应用中使用TCP通信时,需考虑网络权限问题,确保在AndroidManifest.xml中声明了`...
在技术实现上,"运动会成绩管理系统"可能基于Web技术开发,采用前后端分离的架构,前端使用React或Vue等库构建用户界面,后端则用Node.js、Java或Python等语言处理业务逻辑和数据库交互。数据库选择通常会考虑性能和...
- **编程语言**:介绍常见的编程语言(如Python、Java、C++、JavaScript)及其应用领域,可能要求识别语言特性。 - **网络基础**:包括TCP/IP协议、DNS域名解析、HTTP/HTTPS协议、IP地址、子网掩码、路由器与交换机...