`

java 加密

    博客分类:
  • java
 
阅读更多


本篇内容简要介绍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加密的。



通过java代码实现如下:
Java代码  收藏代码

    /**
     * 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的串。就是用来验证文件是否一致的。



通过java代码实现如下:
Java代码 复制代码
Java代码  收藏代码

    /**
     * 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更为安全。



通过java代码实现如下:
Java代码 复制代码
Java代码  收藏代码

        /**
         * 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,并将其加入到消息中,然后传输。接收方利用与发送方共享的密钥进行鉴别认证等。



通过java代码实现如下:
Java代码 复制代码
Java代码  收藏代码

    /**
     * 初始化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); 
     
    } 



给出一个完整类,如下:
Java代码 复制代码
Java代码  收藏代码

    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 { 
     
            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); 
     
        } 
    } 



再给出一个测试类:
Java代码  收藏代码

    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)); 
        } 
    } 



控制台输出:
Console代码  收藏代码

    原文: 
    简单加密 
    BASE64加密后: 
    566A5Y2V5Yqg5a+G 
     
    BASE64解密后: 
    简单加密 
    Mac密钥: 
    uGxdHC+6ylRDaik++leFtGwiMbuYUJ6mqHWyhSgF4trVkVBBSQvY/a22xU8XT1RUemdCWW155Bke 
    pBIpkd7QHg== 
     
    MD5: 
    -550b4d90349ad4629462113e7934de56 
    SHA: 
    91k9vo7p400cjkgfhjh0ia9qthsjagfn 
    HMAC: 
    2287d192387e95694bdbba2fa941009a 



    BASE64的加密解密是双向的,可以求反解。
    MD5、SHA以及HMAC是单向加密,任何数据加密后只会产生唯一的一个加密串,通常用来校验数据在传输过程中是否被修改。其中HMAC算法有一个密钥,增强了数据传输过程中的安全性,强化了算法外的不可控因素。
    单向加密的用途主要是为了校验数据在传输过程中是否被修改。
分享到:
评论

相关推荐

    JAVA加密和解密的艺术(第二版).zip

    《JAVA加密和解密的艺术(第二版)》是一本深入探讨Java平台上的加密与解密技术的专业书籍。这本书不仅提供了理论知识,还包含了丰富的实践示例,帮助读者理解和掌握加密技术在实际应用中的运用。其内容涵盖了从基本...

    java加密和解密的方法

    java加密和解密的方法,利用指定的密钥,可逆的。密钥必须16位。

    JAVA加密与解密的艺术 第2版 pdf part2

    《Java加密与解密的艺术(第2版)》由梁栋著,以Java中的加密API和加密算法为切入点,全面介绍了Java SE 7的特性,及其中与安全相关的各种API,详细讲解了各种流行的加密算法及其在实际中的应用,为Java开发工程师和...

    JAVA加密与解密的艺术--第2版.rar

    全书包含3个部分,基础篇对Java企业级应用的安全知识、密码学核心知识、与Java加密相关的API和通过权限文件加强系统安全方面的知识进行了全面的介绍;实践篇不仅对电子邮件传输算法、消息摘要算法、对称加密算法、非...

    Java加密与解密的艺术.mobi

    若要构建安全坚固的Java企业级应用,不仅要深入了解每种算法的原理并将它们综合运用,而且还要悟透Java加密与解密技术的本质。全书包含3个部分,基础篇对Java企业级应用的安全知识、密码学核心知识、与Java加密相关...

    Java加密扩展基础

    Java加密扩展基础是Java开发工具包(Java SDK)中的一个重要组件,自1.4版本起,JCE(Java Cryptography Extension)被纳入核心库,为Java开发者提供了强大的安全功能。这个扩展提供了一套完整的框架,使得开发人员...

    JAVA加密与解密的艺术 第2版 pdf part1

    《Java加密与解密的艺术(第2版)》由梁栋著,以Java中的加密API和加密算法为切入点,全面介绍了Java SE 7的特性,及其中与安全相关的各种API,详细讲解了各种流行的加密算法及其在实际中的应用,为Java开发工程师和...

    java加密程序源代码

    Java加密程序源代码是关于使用Java编程语言进行数据加密和解密的技术实现。在Java中,我们可以使用多种方法来实现加密,这些方法通常基于标准的加密算法,如对称加密和非对称加密。对称加密算法如DES(Data ...

    Java加密算法(源代码)

    Java加密算法是信息安全领域的重要组成部分,它涉及到数据的保护、隐私的维护以及网络通信的安全。在Java中,我们可以使用多种加密技术来实现数据的加密和解密,包括对称加密、非对称加密以及数字签名等。下面将详细...

    一个java加密程序源代码

    Java加密程序源代码是用于保护数据安全的重要工具,它通过特定的算法将原始信息转换成不可读的形式,防止未经授权的访问或泄露。本程序可能涵盖了对称加密、非对称加密以及哈希函数等多种加密技术。 对称加密是最早...

    java加密解密zip压缩包

    Java加密通常使用Java Cryptography Extension (JCE) 提供的API。JCE包含各种加密算法,如AES(高级加密标准)和DES(数据加密标准)。在我们的项目中,可以使用AES来对ZIP文件内容进行加密,因为AES是一种强大且...

    java加密网址分享

    ### Java加密网址分享知识点概述 #### 一、Java加密技术概览 在互联网时代,数据安全变得尤为重要。Java作为一种广泛使用的编程语言,在处理敏感信息时提供了多种加密手段。本篇文章将探讨如何使用Java进行网址...

    Java加密与解密的艺术

    , 全书包含3个部分,基础篇对Java企业级应用的安全知识、密码学核心知识、与Java加密相关的API和通过权限文件加强系统安全方面的知识进行了全面的介绍;实践篇不仅对电子邮件传输算法、消息摘要算法、对称加密算法、...

    Java加密算法学习笔记的源码包

    Java加密算法是信息安全领域的重要组成部分,它在保护数据隐私、验证数据完整性和确认发送者身份等方面发挥着关键作用。这个名为"Java加密算法学习笔记的源码包"的压缩文件包含了关于Java中几种主要加密算法的实践...

    EncryptChatRoom--java加密聊天室

    《EncryptChatRoom--Java加密聊天室》是一款基于DES(Data Encryption Standard)算法的Java实现的加密聊天室项目。该项目旨在提供一个安全的通信环境,确保用户间的聊天信息不被未经授权的第三方窃取或篡改。下面...

    Java加密与解密的艺术.pdf

    本书名为《Java加密与解密的艺术》,由梁栋撰写,ISBN为978-7-111-29762-8。书籍内容围绕Java开发中的加密与解密技术,覆盖了大部分加解密问题,旨在帮助企业应用提高安全性,并提供实用的解决策略。文中介绍了一...

    java加密技术

    Java加密技术是Java编程语言中用于保障数据安全的一系列加密方法和技术,它包括了单向加密算法、对称加密算法、非对称加密算法以及加密算法的高级应用如数字签名和数字证书等。本文将详细介绍这些加密技术,并结合...

    java加密器Applet小程序

    Java加密器Applet小程序是一种基于Java编程语言的小型应用程序,它可以在Web浏览器环境中运行,用于对文件进行加密处理。Applet是Java平台早期的一种特性,允许开发者创建可以在客户端计算机上执行的互动内容,通常...

    JCT - java加密解密工具包.zip_Java加密_java 加密_jct java_加密 解密_加密工具

    Java加密解密工具包,通常用于保护敏感数据的安全,防止未经授权的访问或篡改。这个名为"JCT"的工具包提供了丰富的功能,使得开发者在Java应用中集成加密和解密操作变得更加简单。下面我们将详细探讨Java加密的相关...

    JAVA 加密算法(很好的算法,经典摘要)

    Java加密算法是信息安全领域中的重要组成部分,用于保护数据的隐私性和完整性。在Java平台上,有多种内置的加密库,如Java Cryptography Extension (JCE) 和 Java Cryptography Architecture (JCA),它们为开发者...

Global site tag (gtag.js) - Google Analytics