`

java(md5) 加密解密简单实现

    博客分类:
  • java
 
阅读更多
package test;
import java.io.FileInputStream;  


import java.io.FileOutputStream; 
import java.io.IOException; 
import java.io.ObjectInputStream; 
import java.io.ObjectOutputStream; 
import java.security.*; 
import javax.crypto.Cipher; 
import javax.crypto.KeyGenerator; 
import javax.crypto.SecretKey; 
/**
* 加密解密

* @author shy.qiu
* @since  http://blog.csdn.net/qiushyfm
*/ 
public class CryptTest { 
    /**
     * 进行MD5加密
     * 
     * @param info
     *            要加密的信息
     * @return String 加密后的字符串
     */ 
    public String encryptToMD5(String info) { 
        byte[] digesta = null; 
        try { 
            // 得到一个md5的消息摘要 
            MessageDigest alga = MessageDigest.getInstance("MD5"); 
            // 添加要进行计算摘要的信息 
            alga.update(info.getBytes()); 
            // 得到该摘要 
            digesta = alga.digest(); 
        } catch (NoSuchAlgorithmException e) { 
            e.printStackTrace(); 
        } 
        // 将摘要转为字符串 
        String rs = byte2hex(digesta); 
        return rs; 
    } 
    /**
     * 进行SHA加密
     * 
     * @param info
     *            要加密的信息
     * @return String 加密后的字符串
     */ 
    public String encryptToSHA(String info) { 
        byte[] digesta = null; 
        try { 
            // 得到一个SHA-1的消息摘要 
            MessageDigest alga = MessageDigest.getInstance("SHA-1"); 
            // 添加要进行计算摘要的信息 
            alga.update(info.getBytes()); 
            // 得到该摘要 
            digesta = alga.digest(); 
        } catch (NoSuchAlgorithmException e) { 
            e.printStackTrace(); 
        } 
        // 将摘要转为字符串 
        String rs = byte2hex(digesta); 
        return rs; 
    } 
    // ////////////////////////////////////////////////////////////////////////// 
    /**
     * 创建密匙
     * 
     * @param algorithm
     *            加密算法,可用 DES,DESede,Blowfish
     * @return SecretKey 秘密(对称)密钥
     */ 
    public SecretKey createSecretKey(String algorithm) { 
        // 声明KeyGenerator对象 
        KeyGenerator keygen; 
        // 声明 密钥对象 
        SecretKey deskey = null; 
        try { 
            // 返回生成指定算法的秘密密钥的 KeyGenerator 对象 
            keygen = KeyGenerator.getInstance(algorithm); 
            // 生成一个密钥 
            deskey = keygen.generateKey(); 
        } catch (NoSuchAlgorithmException e) { 
            e.printStackTrace(); 
        } 
        // 返回密匙 
        return deskey; 
    } 
    /**
     * 根据密匙进行DES加密
     * 
     * @param key
     *            密匙
     * @param info
     *            要加密的信息
     * @return String 加密后的信息
     */ 
    public String encryptToDES(SecretKey key, String info) { 
        // 定义 加密算法,可用 DES,DESede,Blowfish 
        String Algorithm = "DES"; 
        // 加密随机数生成器 (RNG),(可以不写) 
        SecureRandom sr = new SecureRandom(); 
        // 定义要生成的密文 
        byte[] cipherByte = null; 
        try { 
            // 得到加密/解密器 
            Cipher c1 = Cipher.getInstance(Algorithm); 
            // 用指定的密钥和模式初始化Cipher对象 
            // 参数:(ENCRYPT_MODE, DECRYPT_MODE, WRAP_MODE,UNWRAP_MODE) 
            c1.init(Cipher.ENCRYPT_MODE, key, sr); 
            // 对要加密的内容进行编码处理, 
            cipherByte = c1.doFinal(info.getBytes()); 
        } catch (Exception e) { 
            e.printStackTrace(); 
        } 
        // 返回密文的十六进制形式 
        return byte2hex(cipherByte); 
    } 
    /**
     * 根据密匙进行DES解密
     * 
     * @param key
     *            密匙
     * @param sInfo
     *            要解密的密文
     * @return String 返回解密后信息
     */ 
    public String decryptByDES(SecretKey key, String sInfo) { 
        // 定义 加密算法, 
        String Algorithm = "DES"; 
        // 加密随机数生成器 (RNG) 
        SecureRandom sr = new SecureRandom(); 
        byte[] cipherByte = null; 
        try { 
            // 得到加密/解密器 
            Cipher c1 = Cipher.getInstance(Algorithm); 
            // 用指定的密钥和模式初始化Cipher对象 
            c1.init(Cipher.DECRYPT_MODE, key, sr); 
            // 对要解密的内容进行编码处理 
            cipherByte = c1.doFinal(hex2byte(sInfo)); 
        } catch (Exception e) { 
            e.printStackTrace(); 
        } 
        // return byte2hex(cipherByte); 
        return new String(cipherByte); 
    } 
    // ///////////////////////////////////////////////////////////////////////////// 
    /**
     * 创建密匙组,并将公匙,私匙放入到指定文件中
     * 
     * 默认放入mykeys.bat文件中
     */ 
    public void createPairKey() { 
        try { 
            // 根据特定的算法一个密钥对生成器 
            KeyPairGenerator keygen = KeyPairGenerator.getInstance("DSA"); 
            // 加密随机数生成器 (RNG) 
            SecureRandom random = new SecureRandom(); 
            // 重新设置此随机对象的种子 
            random.setSeed(1000); 
            // 使用给定的随机源(和默认的参数集合)初始化确定密钥大小的密钥对生成器 
            keygen.initialize(512, random);// keygen.initialize(512); 
            // 生成密钥组 
            KeyPair keys = keygen.generateKeyPair(); 
            // 得到公匙 
            PublicKey pubkey = keys.getPublic(); 
            // 得到私匙 
            PrivateKey prikey = keys.getPrivate(); 
            // 将公匙私匙写入到文件当中 
            doObjToFile("mykeys.bat", new Object[] { prikey, pubkey }); 
        } catch (NoSuchAlgorithmException e) { 
            e.printStackTrace(); 
        } 
    } 
    /**
     * 利用私匙对信息进行签名 把签名后的信息放入到指定的文件中
     * 
     * @param info
     *            要签名的信息
     * @param signfile
     *            存入的文件
     */ 
    public void signToInfo(String info, String signfile) { 
        // 从文件当中读取私匙 
        PrivateKey myprikey = (PrivateKey) getObjFromFile("mykeys.bat", 1); 
        // 从文件中读取公匙 
        PublicKey mypubkey = (PublicKey) getObjFromFile("mykeys.bat", 2); 
        try { 
            // Signature 对象可用来生成和验证数字签名 
            Signature signet = Signature.getInstance("DSA"); 
            // 初始化签署签名的私钥 
            signet.initSign(myprikey); 
            // 更新要由字节签名或验证的数据 
            signet.update(info.getBytes()); 
            // 签署或验证所有更新字节的签名,返回签名 
            byte[] signed = signet.sign(); 
            // 将数字签名,公匙,信息放入文件中 
            doObjToFile(signfile, new Object[] { signed, mypubkey, info }); 
        } catch (Exception e) { 
            e.printStackTrace(); 
        } 
    } 
    /**
     * 读取数字签名文件 根据公匙,签名,信息验证信息的合法性
     * 
     * @return true 验证成功 false 验证失败
     */ 
    public boolean validateSign(String signfile) { 
        // 读取公匙 
        PublicKey mypubkey = (PublicKey) getObjFromFile(signfile, 2); 
        // 读取签名 
        byte[] signed = (byte[]) getObjFromFile(signfile, 1); 
        // 读取信息 
        String info = (String) getObjFromFile(signfile, 3); 
        try { 
            // 初始一个Signature对象,并用公钥和签名进行验证 
            Signature signetcheck = Signature.getInstance("DSA"); 
            // 初始化验证签名的公钥 
            signetcheck.initVerify(mypubkey); 
            // 使用指定的 byte 数组更新要签名或验证的数据 
            signetcheck.update(info.getBytes()); 
            System.out.println(info); 
            // 验证传入的签名 
            return signetcheck.verify(signed); 
        } catch (Exception e) { 
            e.printStackTrace(); 
            return false; 
        } 
    } 
    /**
     * 将二进制转化为16进制字符串
     * 
     * @param b
     *            二进制字节数组
     * @return String
     */ 
    public String byte2hex(byte[] b) { 
        String hs = ""; 
        String stmp = ""; 
        for (int n = 0; n  0xEF
     * 
     * @param src0
     *            byte
     * @param src1
     *            byte
     * @return byte
     */ 
    public static byte uniteBytes(byte src0, byte src1) { 
        byte _b0 = Byte.decode("0x" + new String(new byte[] { src0 })) 
                .byteValue(); 
        _b0 = (byte) (_b0
分享到:
评论

相关推荐

    java实现md5 加密解密

    java实现md5 加密解密(在网络中MD5是著名的不可逆算法,但是如果知道MD5的加密的字符串 则可以通过自己的加密算法对明文进行加密,对加密后的密文与字符串匹配; 匹配成功,表示找到明文;但是此程序的时间耗费较高!仅...

    java实现MD5加密解密算法

    java实现MD5加密解密算法,java源代码~

    基于JAVA的MD5加密解密实现

    纯JAVA的MD5加密,利用MD5单向函数产生密钥,方便测试

    java md5加密 解密

    2. **Java中的MD5加密**:在Java中,可以使用`java.security.MessageDigest`类来实现MD5加密。首先,需要创建一个MD5实例,然后更新要加密的字节数组,最后获取并转换成十六进制字符串。 ```java import java....

    java常用类-MD5加密与DES加密解密

    java中常用的工具类,用于MD5的加密,里面还有切割了MD5加密的长度,有DES加密与解密,并且配有main函数可测试,可以根据自己的实际情况使用main函数测试使用

    Java实现MD5加密解密

    Java实现MD5加密以及解密,附带测试类,具体见代码。 Java实现MD5加密以及解密,附带测试类,具体见代码。 Java实现MD5加密以及解密,附带测试类,具体见代码。 Java实现MD5加密以及解密,附带测试类,具体见代码。

    MD5编码、MD5加密解密demo

    在描述中提到的"MD5加密解密demo",实际上MD5并不具备可逆的加密特性。MD5是一个单向函数,即给定任意输入,可以很容易地计算出固定的输出(摘要),但无法根据输出反推出原始输入。因此,我们通常不会说"MD5解密",...

    java的md5加密解密

    ### Java中的MD5加密与“解密”技术详解 #### 一、MD5算法简介 MD5(Message-Digest Algorithm 5)是一种广泛使用的密码散列函数,可以产生一个128位(16字节)的散列值,通常用于确保数据的完整性和一致性。在...

    MD5 加密解密例子

    以下是一个简单的MD5加密的Java代码示例: ```java import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class MD5Util { public static String encrypt(String plain...

    java_加密解密简单实现

    标题和描述均提到了“Java加密解密简单实现”,这主要涵盖了消息摘要、单匙密码体制(DES)、数字签名(RSA)以及非对称密匙密码体制(公匙体系)等核心概念及其在Java中的应用。 ### 消息摘要 消息摘要是一种用于...

    java MD5加密解密

    在Java中,可以使用`java.security.MessageDigest`类来实现MD5加密。以下是一个简单的MD5加密示例: ```java import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class ...

    android用MD5加密解密demo

    在Android中,我们可以使用Java内置的`java.security.MessageDigest`类来实现MD5加密。以下是一个简单的MD5加密步骤: 1. 创建`MessageDigest`实例,指定算法为MD5。 ```java MessageDigest md = MessageDigest....

    MD5加密解密Java源码

    MD5字符加密解密源程序 MD5字符加密解密源程序 MD5字符加密解密源程序 MD5字符加密解密源程序 MD5字符加密解密源程序

    java后台及前端js使用AES互相加解密及前端md5加密

    本主题涉及的是在Java后台与前端JavaScript之间利用AES(Advanced Encryption Standard)进行加解密,以及前端的MD5(Message-Digest Algorithm 5)加密技术。以下是关于这些知识点的详细解释: 1. **AES加密**:...

    Java Md5加密工具类

    Java Md5加密工具类

    java实现文件加密解密

    "java实现文件加密解密" Java 实现文件的加密与解密是指利用 Java 语言将资源文件(包括图片、动画等类型)进行简单的加密和解密。这种策略的原因和好处是将准备好的资源存储在云上,使用时通过网络进行读取即可,...

    MD5加密解密

    java 采用MD5 进行加密和解密完整代码,导入就可以直接使用,有完整的注释,轻松上手。

    java实现Md5加盐加密算法

    对接接口时用到的一种常用加密算法,常用于验证签名,使用shiro-all-1.4.1.jar,可自行下载

    md5加密java写法轻松实现md5让你学会加密,会的可以给点建议,不会的可以借鉴,大家讨论加密!很方便的使用!

    md5加密java写法轻松实现md5让你学会加密,会的可以给点建议,不会的可以借鉴,大家讨论加密!很方便的使用!

    JAVA_对文件MD5加密

    下面我们将详细介绍如何使用Java语言实现对文件进行MD5加密的过程。 #### MD5加密原理 MD5算法通过一系列复杂的数学运算,将输入的信息转换为一个固定的128位输出值。该输出值通常被表示为一个32位的十六进制数,...

Global site tag (gtag.js) - Google Analytics