慕码人1102305
Szyrt
lcczz
这个其实要看你是怎么处理,最后在后台接收就处理
慕粉1341322
看一下加密的方式是什么
OneCreator
洛卿殇
HNing
Hush_soul
Serena_Cecilia
qq_花泽香菜_0
慕粉4197587
慕粉140931377
开开心心就好
密钥一般都是字节数组,直接base64后转成字符串保存就好了
qq_珍惜时光_1
Base64的包导入没问题吗
qq_珍惜时光_1
这个需要单独添加一个jar包,是apache下面的commons jar包,你可以下载老师上传的jar包,其实我觉得没有必要,可以用HexBin.encode(result)也能达到效果。
慕仙951674
HexBin.encode(result);用这个
锅小
看错了。。。
qq_勹惢好_0
包是commons-codec-1.10.jar
在程序里导入包的时候要正确导入 import org.apache.commons.codec.binary.Base64;
失败又能怎样
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改成你的名字即可
i_AM_YOU7
不是太安全 但可以学习下他它的思想,然后混合加密
慕粉3914370
一个byte数组定义的密钥,一个是采用加密算法加密后的密钥
SupreMan
HexUtils.toHexString(result) 使用这个也是可以的
jfhdibrbfjd
你想问的是C语言的实现吧,我觉得只要C语言有java中实现这些加密的jar包,应该就可以吧,我也不知道C有没有这些jar包
lv初心未曾变
找到问题了
//实例化DES的相关内容
DESedeKeySpec desKeySpec = new DESedeKeySpec(byteskey);
是这个没改对
苦心高木不论资
org.apache.commons.codec.binary.Hex
慕粉3203831
应该是没导入cc或者是bc的包吧
bigggge
从工藤新一到江户川柯南
写错了DES/ECB/PKCSSPadding 应该是DES/ECB/PKCS5Padding CS5 写成了css
Auroras
BC环境
桃李不言O_0
加密完成后,成为byte数据,通过io流进行传输,再根据相应加解密方式进行解密