`
GoodWell
  • 浏览: 29547 次
  • 性别: Icon_minigender_1
  • 来自: 河北邢台
社区版块
存档分类

三中常见的加密算法

阅读更多
实现类:
package jm;

import java.security.MessageDigest;   
  
import javax.crypto.KeyGenerator;   
import javax.crypto.Mac;   
import javax.crypto.SecretKey;   
import javax.crypto.spec.SecretKeySpec;
  
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);   
  
    }   
}  

 测试类:

package jm;

import java.math.BigInteger;

import org.junit.Test;

public class csCoder{

	@Test
	public void test() throws Exception{
		
		String name="陈少";
		byte[] st=name.getBytes();
		
		 BigInteger md5 = new BigInteger(Coder.encryptMD5(st));   
		 System.err.println("MD5:\n" + md5.toString(16));   
		 BigInteger sha = new BigInteger(Coder.encryptSHA(st));   
		 System.err.println("SHA:\n" + sha.toString(32));   
		 BigInteger mac = new BigInteger(Coder.encryptHMAC(st, name));   
		 System.err.println("HMAC:\n" + mac.toString(16));   

	}
}

 

分享到:
评论

相关推荐

    现代密码学考试题参考.pdf

    AES 加密算法是一种对称加密算法,试题四中,考虑一个数据块长度为 256 且密钥长度为 128 位的 AES 加密算法。需要计算 Nb、Nk 和 Nr 的值,并描述子密钥的生成过程。AES 算法的子密钥生成过程可以分为主密钥扩展和...

    PHP实现的简单对称加密与解密方法实例小结

    需要注意的是,对称加密技术是网络安全的重要组成部分,选择和使用这些技术时,应考虑加密算法的强度、密钥的管理和存储,以及加密数据的完整性保护等因素。同时,对于涉及敏感信息的场景,应当优先考虑使用经过验证...

    最新的《H3C内部3G资料》

    6. **网络安全**:3G引入了更高级别的安全机制,如加密算法、鉴权和完整性保护,以保障用户信息的安全。 7. **3G到4G演进**:资料可能还会涵盖3G向4G(LTE)的平滑演进,包括网络架构的简化、数据传输速率的提升和...

    福州大学MATLAB基础实验指导书 (2).pdf

    2. 简单程序编写:可以使用循环、条件语句等结构编写程序,解决实际问题,如实验二中的加密算法和工资计算。 三、图形绘制 1. 二维、三维绘图:MATLAB提供了plot、plot3、mesh、surf等函数绘制各种图形,如实验三中...

    编码理论实验程序模板

    DES是一种对称加密算法,广泛应用于早期的数据保护。它使用56位的密钥对64位的数据块进行加密,通过16轮的替换和置换操作实现数据的混淆和扩散。在实验三中,你将深入了解DES的工作原理,包括其初始置换、S盒、扩展...

    密码学第5章答案1

    问题三中,使用ElGamal算法加密,给出素数p、生成元a、公钥b、随机数k和明文m,计算密文的过程。对于问题(1),我们首先计算k的幂,然后乘以明文和公钥的幂,对p取模,得到密文(c1, c2)。在问题(2)中,已知解密后的...

    福州大学MATLAB基础实验指导书.docx

    例如,实验中的加密算法可以通过循环和算术运算实现。 三、图形绘制 1. 二维图形:MATLAB提供了`plot`函数绘制线图,`plot3`绘制三维线图,`mesh`和`surf`用于绘制网格和曲面图。图形可进行颜色、线型、标记等...

    DATMatrix数码新空三V1.0系统用户手册

    - **提取区域设置**:将影像划分为M行N列的形式进行自动转点,常见的默认设置有3×5、5×3、5×7、7×5等。 - **区域内保留点**:每个标准点位上保留的转点数量。 - **测区**:具体指代的是进行空三加密的实际...

    论文2__通过三维数据插值进行电阻率的拟合及估计.doc

    在问题三中,论文通过颜色图直观地展示了插值加密后的数据效果。通过对比不同切片的色彩分布,可以观察到原数据、IDW加密和克里金加密的插值效果。这种方法有助于评估插值后的数据在视觉上的连续性和一致性。 最后...

    C语言实验实训 答案

    选做题则是对学生编程能力的挑战,要求学生编写复杂的C语言程序,以实现特定的功能,例如实现排序算法或实现数据加密。 实验三:改错题、基本题和选做题 在实验三中,我们将继续对C语言的高级语法和数据结构进行...

    易语言程序免安装版下载

    易语言5.1 相对于易语言5.0更新说明:  支持静态链接其它编程语言(如C/C++、汇编等)编译生成的静态库(.LIB或.OBJ),但仅限于COFF格式,支持cdecl和stdcall两种函数调用约定。  使用说明如下:函数声明和调用...

Global site tag (gtag.js) - Google Analytics