这里有新鲜出炉的 Java 并发编程示例,程序狗速度看过来!
java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的 Java 程序设计语言和 Java 平台(即 JavaEE(j2ee), JavaME(j2me), JavaSE(j2se))的总称。
这篇文章主要介绍了 Java 详解单向加密 --MD5、SHA 和 HMAC 及简单实现实例的相关资料, 需要的朋友可以参考下
Java 详解单向加密 --MD5、SHA 和 HMAC 及简单实现实例
概要:
MD5、SHA、HMAC 这三种加密算法,可谓是非可逆加密,就是不可解密的加密方法。
MD5
MD5 即 Message-Digest Algorithm 5(信息 - 摘要算法 5),用于确保信息传输完整一致。MD5 是输入不定长度信息,输出固定长度 128-bits 的算法。
MD5 算法具有以下特点:
1、压缩性:任意长度的数据,算出的 MD5 值长度都是固定的。
2、容易计算:从原数据计算出 MD5 值很容易。
3、抗修改性:对原数据进行任何改动,哪怕只修改 1 个字节,所得到的 MD5 值都有很大区别。
4、强抗碰撞:已知原数据和其 MD5 值,想找到一个具有相同 MD5 值的数据(即伪造数据)是非常困难的。
MD5 还广泛用于操作系统的登陆认证上,如 Unix、各类 BSD 系统登录密码、数字签名等诸多方面。如在 Unix 系统中用户的密码是以 MD5(或其它类似的算法)经 Hash 运算后存储在文件系统中。当用户登录的时候,系统把用户输入的密码进行 MD5 Hash 运算,然后再去和保存在文件系统中的 MD5 值进行比较,进而确定输入的密码是否正确。通过这样的步骤,系统在并不知道用户密码的明码的情况下就可以确定用户登录系统的合法性。这可以避免用户的密码被具有系统管理员权限的用户知道。MD5 将任意长度的 "字节串" 映射为一个 128bit 的大整数,并且通过该 128bit 反推原始字符串是非常困难的。
SHA
SHA(Secure Hash Algorithm,安全散列算法),数字签名等密码学应用中重要的工具,被广泛地应用于电子商务等信息安全领域。虽然 SHA 与 MD5 通过碰撞法都被破解了, 但是 SHA 仍然是公认的安全加密算法,较之 MD5 更为安全。
SHA 所定义的长度
下表中的中继散列值(internal state)表示对每个数据区块压缩散列过后的中继值(internal hash sum)。
算法 | 输出散列值长度(bits) | 中继散列值长度(bits) | 数据区块长度(bits) | 最大输入消息长度(bits) | 一个 Word 长度(bits) | 循环次数 | 使用到的运算符 | 碰撞攻击 |
---|---|---|---|---|---|---|---|---|
SHA-0 | 160 | 160 | 512 | 264 − 1 | 32 | 80 | +,and,or,xor,rotl | 是 |
SHA-1 | 160 | 160 | 512 | 264 − 1 | 32 | 80 | +,and,or,xor,rotl | 存在 263 的攻击 |
SHA-256/224 | 256/224 | 256 | 512 | 264 − 1 | 32 | 64 | +,and,or,xor,shr,rotr | 尚未出现 |
SHA-512/384 | 512/384 | 512 | 1024 | 2128 − 1 | 64 | 80 | +,and,or,xor,shr,rotr | 尚未出现 |
HMAC
HMAC(Hash Message Authentication Code),散列消息鉴别码,基于密钥的 Hash 算法的认证协议。消息鉴别码实现鉴别的原理是,用公开函数和密钥产生一个固定长度的值作为认证标识,用这个标识鉴别消息的完整性。使用一个密钥生成一个固定大小的小数据块,即 MAC,并将其加入到消息中,然后传输。接收方利用与发送方共享的密钥进行鉴别认证等。
Java 示例
- package com.zzj.encryption;
- import java.security.MessageDigest;
- import javax.crypto.Mac;
- import javax.crypto.SecretKey;
- import javax.crypto.spec.SecretKeySpec;
- import org.apache.commons.codec.binary.Base64;
- /**
- * 单向加密(非可逆加密)
- * @author lenovo
- *
- */
- public class OneWayEncryption {
- static final String ALGORITHM_MD5 = "MD5";
- static final String ALGORITHM_SHA = "SHA";
- /**
- * MAC算法可选以下多种算法
- * <pre>
- * HmacMD5
- * HmacSHA1
- * HmacSHA256
- * HmacSHA384
- * HmacSHA512
- * </pre>
- */
- static final String ALGORITHM_MAC = "HmacMD5";
- /** 密钥 **/
- static final String MAC_KEY = "abcdef";
- public static void main(String[] args) throws Exception {
- String source = "我是程序猿!我很骄傲!";
- // MD5加密
- printBase64(encryptionMD5(source));
- // SHA加密
- printBase64(encryptionSHA(source));
- // HMAC加密
- printBase64(encryptionHMAC(source));
- }
- static void printBase64(byte[] out) throws Exception {
- System.out.println(encodeBase64(out));
- }
- /**
- * MD5加密
- * @param source
- * @return
- * @throws Exception
- */
- static byte[] encryptionMD5(String source) throws Exception {
- MessageDigest md = MessageDigest.getInstance(ALGORITHM_MD5);
- md.update(source.getBytes("UTF-8"));
- return md.digest();
- }
- /**
- * SHA加密
- * @param source
- * @return
- * @throws Exception
- */
- static byte[] encryptionSHA(String source) throws Exception {
- MessageDigest md = MessageDigest.getInstance(ALGORITHM_SHA);
- md.update(source.getBytes("UTF-8"));
- return md.digest();
- }
- /**
- * HMAC加密
- * @return
- * @throws Exception
- */
- static byte[] encryptionHMAC(String source) throws Exception {
- SecretKey secretKey = new SecretKeySpec(MAC_KEY.getBytes("UTF-8"), ALGORITHM_MAC);
- Mac mac = Mac.getInstance(ALGORITHM_MAC);
- mac.init(secretKey);
- mac.update(source.getBytes("UTF-8"));
- return mac.doFinal();
- }
- /**
- * base64编码
- * @param source
- * @return
- * @throws Exception
- */
- static String encodeBase64(byte[] source) throws Exception {
- return new String(Base64.encodeBase64(source), "UTF-8");
- }
- }
结果:
- 1cNbZhnhFsFV3BFPLA71wA==
- kl5KI61Xq44E/SzSPa2sUntMAEc=
- JF2v/u9td5l8yGAImNvTZw==
来源: http://www.phperz.com/article/17/1224/358540.html