在做机锋的充值回调平台,但是只提供java和php的代码,我这边是用C#写的,其中有一个加密算法看着不是很懂,麻烦大家给解释下。。
public final class Md5Util { public static String getMD5(byte[] source, boolean isUpperCase) {
String s = null;
char hexDigits[] = { // 用来将字节转换成 16 进制表示的字符
'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd',
'e', 'f' };
try {
java.security.MessageDigest md = java.security.MessageDigest
.getInstance("MD5");
md.update(source);
byte tmp[] = md.digest(); // MD5 的计算结果是一个 128 位的长整数,
// 用字节表示就是 16 个字节
char str[] = new char[16 * 2]; // 每个字节用 16 进制表示的话,使用两个字符,
// 所以表示成 16 进制需要 32 个字符
int k = 0; // 表示转换结果中对应的字符位置
for (int i = 0; i < 16; i++) { // 从第一个字节开始,对 MD5 的每一个字节
// 转换成 16 进制字符的转换
byte byte0 = tmp[i]; // 取第 i 个字节
str[k++] = hexDigits[byte0 >>> 4 & 0xf]; // 取字节中高 4 位的数字转换,
// >>> 为逻辑右移,将符号位一起右移
str[k++] = hexDigits[byte0 & 0xf]; // 取字节中低 4 位的数字转换
}
s = new String(str); // 换后的结果转换为字符串 } catch (Exception e) {
e.printStackTrace();
}
if (isUpperCase)
return s.toUpperCase();
else
return s;
}

public static void main(String[] args) {
System.out.println(getMD5("123456".getBytes(), false));
}
}

解决方案 »

  1.   


    java.security.MessageDigest md = java.security.MessageDigest
    .getInstance("MD5");
    md.update(source);
    byte tmp[] = md.digest(); // MD5 的计算结果是一个 128 位的长整数,
    这三行什么意思呢?第一行是创建md5对象?
    第二行的 update()方法呢?
    第三行的digest()方法呢??
      

  2.   

    简单的说就是进行一次md5加密。。C#应该也有对应的md5加密代码吧你用C#写一个然后对照一下加密结果对不对就是了。。
      

  3.   


    得先一步步的把java代码按照功能翻译到c#代码,总不能随便写写就对结果吧又不是赌运气 。
      

  4.   

    第一行是创建md5对象?创建一个加密器,设置加密方式为md5(应该叫摘要)
    第二行的 update()方法呢?把要计算的源数据放进去
    第三行的digest()方法呢??获取加密后结果(获取摘要)应该不需要重写,直接找一个c#的md5算法,获取 32位md5加密值
      

  5.   

    第一行是创建md5对象?创建一个加密器,设置加密方式为md5(应该叫摘要)
    第二行的 update()方法呢?把要计算的源数据放进去
    第三行的digest()方法呢??获取加密后结果(获取摘要)应该不需要重写,直接找一个c#的md5算法,获取 32位md5加密值谢谢,我去试试。。第二个“计算”需要知道计算方式。。呵呵。