看一下加密的方式是什么
HexBin.encode(result);用这个
public class KkltHmac {
public static final String src = "hmac test";
public static void main(String[] args) {
jdkHmacMD5();
bcHmacMD5();
}
public static void jdkHmacMD5(){
KeyGenerator hmacMD5 = null;
try
{
// 初始化KeyGenerator
KeyGenerator keyGenerator = KeyGenerator.getInstance("HmacMD5");
// 产生密钥
SecretKey secretKey = keyGenerator.generateKey();
// 获取密钥
// byte[] key = secretKey.getEncoded();
byte[] key = Hex.decodeHex(new char[]{'1','2','3','4','5','6','7','8','9','a','b','c','d','e' });
// 还原密钥
SecretKey restoreSecretKey = new SecretKeySpec(key, "HmacMD5");
// 实例化MAC
Mac mac = Mac.getInstance(restoreSecretKey.getAlgorithm());
// 初始化MAC
mac.init(restoreSecretKey);
// 执行摘要
byte[] hmacMD5Bytes = mac.doFinal(src.getBytes());
System.out.println("jdk hmacMD5:" + Hex.encodeHexString(hmacMD5Bytes));
} catch (Exception e) {
e.printStackTrace();
}
}
// 用bouncy castle实现:
public static void bcHmacMD5()
{
HMac hmac = new HMac(new MD5Digest());
// 必须是16进制的字符,长度必须是2的倍数
hmac.init(new KeyParameter(org.bouncycastle.util.encoders.Hex.decode("123456789abcde")));
hmac.update(src.getBytes(), 0, src.getBytes().length);
// 执行摘要
byte[] hmacMD5Bytes = new byte[hmac.getMacSize()];
hmac.doFinal(hmacMD5Bytes, 0);
System.out.println("bc hmacMD5:" + org.bouncycastle.util.encoders.Hex.toHexString(hmacMD5Bytes));
}
}
把src改成你的名字即可
HexUtils.toHexString(result) 使用这个也是可以的
你想问的是C语言的实现吧,我觉得只要C语言有java中实现这些加密的jar包,应该就可以吧,我也不知道C有没有这些jar包
应该是没导入cc或者是bc的包吧
写错了DES/ECB/PKCSSPadding 应该是DES/ECB/PKCS5Padding CS5 写成了css
BC环境
加密完成后,成为byte数据,通过io流进行传输,再根据相应加解密方式进行解密
可以简单的这样实现:
import java.security.Key; import java.util.Scanner; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESKeySpec; import org.apache.commons.codec.binary.Hex; public class TestDES { public static void main(String[] args) { Scanner input = new Scanner(System.in); System.out.println("请输入需要加密的内容:"); String src = input.nextLine(); jdkDES(src); input.close(); } public static void jdkDES(String src) { try { //生成key KeyGenerator keyGenerator = KeyGenerator.getInstance("DES"); SecretKey secretKey = keyGenerator.generateKey(); byte[] byteKey = secretKey.getEncoded(); //转换Key DESKeySpec desKeySpec = new DESKeySpec(byteKey); SecretKeyFactory factory = SecretKeyFactory.getInstance("DES"); Key convertSecretKey = factory.generateSecret(desKeySpec); //加密 Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding"); cipher.init(Cipher.ENCRYPT_MODE, convertSecretKey); byte[] result = cipher.doFinal(src.getBytes()); System.out.println("jdk des encrypt: " + Hex.encodeHexString(result)); //解密 cipher.init(Cipher.DECRYPT_MODE, convertSecretKey); result = cipher.doFinal(result); System.out.println("jdk des decrypt: " + new String(result)); } catch (Exception e) { e.printStackTrace(); } } }
我也是这个问题,怎么办
不好意思,懂了!原来是bytKey每次运行时不一样的原因!
byte [] bytKey = secretKey.getEncoded();
算法是固定的,他们两个都实现了这个算法接口,不一样是因为你的程勋运行一次重新生成了一次key所以加密后的密文是不一样的.
Hex在commons-codec那个jar里面,有的,再找找看
简单的说,一个byte数组定义的密钥,一个是采用加密算法加密后的密钥
稍后上传哈