phpjavamd5
那位大神能把我这个java的md5的加密方法写个php版本哦,感激噢,java代码如下!
写这个的人 描述的思路如下
1.将秘钥、源串分别转换byte数组
2.声明2个64位数组 将key的byte数组分别做异或运算填充进去 并分别补充 54、92 补满64长度
3.获得md5摘要算法的messagedigest 对象
4.使用其中一个数组及源串的数组更新messagedigest 摘要 完成哈希计算
5.重置摘要
6.使用另一个数组更新摘要 使用4中结果 从0到16开始更新摘要 完成哈希计算
7.转换字符串
public string cryptmd5(string source, string key) {
byte[] k_ipad = new byte[64];
byte[] k_opad = new byte[64];
byte[] keyb;
byte[] value;
try { byte[] keyb = key.getbytes("utf-8");
value = source.getbytes("utf-8");
}
catch (unsupportedencodingexception e)
{
byte[] value;
keyb = key.getbytes();
value = source.getbytes();
}
arrays.fill(k_ipad, keyb.length, 64, 54);
arrays.fill(k_opad, keyb.length, 64, 92);
for (int i = 0; i {
k_ipad[i] = (byte)(keyb[i] ^ 0x36);
k_opad[i] = (byte)(keyb[i] ^ 0x5c);
}
messagedigest md = null;
try
{
md = messagedigest.getinstance("md5");
}
catch (nosuchalgorithmexception e)
{
return null;
}
md.update(k_ipad);
md.update(value);
byte[] dg = md.digest();
md.reset();
md.update(k_opad);
md.update(dg, 0, 16);
dg = md.digest();
return tohex(dg); }
public static String toHex(byte[] input)
{
if (input == null) {
return null;
}
StringBuffer output = new StringBuffer(input.length * 2);
for (int i = 0; i {
int current = input[i] & 0xFF;
if (current output.append("0");
output.append(Integer.toString(current, 16));
}
return output.toString();
}
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号