网上找了好久,太费劲,所以干脆记录下。
package com.xinhua.util;
public class MD4 {
private static int A, B, C, D;
private static int X[] = new int[16];
private static int F(int X, int Y, int Z) {
return (X & Y) | ((~X) & Z);
}
private static int G(int X, int Y, int Z) {
return (X & Y) | (X & Z) | (Y & Z);
}
private static int H(int X, int Y, int Z) {
return X ^ Y ^ Z;
}
private static int lshift(int x, int s) {
if (s == 0) {
return x;
}
return (((x << s) & 0xFFFFFFFF) | ((x >> (32 - s)) & (0x7FFFFFFF >> (31 - s))));
}
private static int ROUND1(int a, int b, int c, int d, int k, int s) {
return (lshift(a + F(b, c, d) + X[k], s));
}
private static int ROUND2(int a, int b, int c, int d, int k, int s) {
return (lshift(a + G(b, c, d) + X[k] + (int) 0x5A827999, s));
}
private static int ROUND3(int a, int b, int c, int d, int k,