实现类:
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));
}
}
分享到:
相关推荐
AES 加密算法是一种对称加密算法,试题四中,考虑一个数据块长度为 256 且密钥长度为 128 位的 AES 加密算法。需要计算 Nb、Nk 和 Nr 的值,并描述子密钥的生成过程。AES 算法的子密钥生成过程可以分为主密钥扩展和...
需要注意的是,对称加密技术是网络安全的重要组成部分,选择和使用这些技术时,应考虑加密算法的强度、密钥的管理和存储,以及加密数据的完整性保护等因素。同时,对于涉及敏感信息的场景,应当优先考虑使用经过验证...
6. **网络安全**:3G引入了更高级别的安全机制,如加密算法、鉴权和完整性保护,以保障用户信息的安全。 7. **3G到4G演进**:资料可能还会涵盖3G向4G(LTE)的平滑演进,包括网络架构的简化、数据传输速率的提升和...
2. 简单程序编写:可以使用循环、条件语句等结构编写程序,解决实际问题,如实验二中的加密算法和工资计算。 三、图形绘制 1. 二维、三维绘图:MATLAB提供了plot、plot3、mesh、surf等函数绘制各种图形,如实验三中...
DES是一种对称加密算法,广泛应用于早期的数据保护。它使用56位的密钥对64位的数据块进行加密,通过16轮的替换和置换操作实现数据的混淆和扩散。在实验三中,你将深入了解DES的工作原理,包括其初始置换、S盒、扩展...
问题三中,使用ElGamal算法加密,给出素数p、生成元a、公钥b、随机数k和明文m,计算密文的过程。对于问题(1),我们首先计算k的幂,然后乘以明文和公钥的幂,对p取模,得到密文(c1, c2)。在问题(2)中,已知解密后的...
例如,实验中的加密算法可以通过循环和算术运算实现。 三、图形绘制 1. 二维图形:MATLAB提供了`plot`函数绘制线图,`plot3`绘制三维线图,`mesh`和`surf`用于绘制网格和曲面图。图形可进行颜色、线型、标记等...
- **提取区域设置**:将影像划分为M行N列的形式进行自动转点,常见的默认设置有3×5、5×3、5×7、7×5等。 - **区域内保留点**:每个标准点位上保留的转点数量。 - **测区**:具体指代的是进行空三加密的实际...
在问题三中,论文通过颜色图直观地展示了插值加密后的数据效果。通过对比不同切片的色彩分布,可以观察到原数据、IDW加密和克里金加密的插值效果。这种方法有助于评估插值后的数据在视觉上的连续性和一致性。 最后...
选做题则是对学生编程能力的挑战,要求学生编写复杂的C语言程序,以实现特定的功能,例如实现排序算法或实现数据加密。 实验三:改错题、基本题和选做题 在实验三中,我们将继续对C语言的高级语法和数据结构进行...
易语言5.1 相对于易语言5.0更新说明: 支持静态链接其它编程语言(如C/C++、汇编等)编译生成的静态库(.LIB或.OBJ),但仅限于COFF格式,支持cdecl和stdcall两种函数调用约定。 使用说明如下:函数声明和调用...