JAVA的加密问题

1.http://javaalmanac.com/egs/javax.crypto/GenMac.html
2.转载CU的ii
再次改人家的程序,来简化处理.

//    程序名为MMM.java
package md5;
import java.security.*;

public class MMM {

public String calcMD5(String str) {
try {
MessageDigest alga=MessageDigest.getInstance("MD5");
// MessageDigest alga=MessageDigest.getInstance("SHA-1");
alga.update(str.getBytes());
byte[] digesta=alga.digest();
return byte2hex(digesta);
}
catch (NoSuchAlgorithmException ex)
        { System.out.println("大哥,出错了!!"); }
return "NULL";

}

public String byte2hex(byte[] b) {             //二行制转字符串

        String hs="";
        String stmp="";
        for (int n=0;n<b.length;n++) {
                stmp=(Integer.toHexString(b[n] & 0XFF));
                if (stmp.length()==1) hs=hs+"0"+stmp;
                else hs=hs+stmp;
                if (n<b.length-1) hs=hs+"";
                }
        // return hs.toUpperCase();
        return hs;
        }

}
3.MD5是一个加密算法,严格的说不是一个加密算法,是一个单向散列算法,是不可逆的,也就是
说无法解密的,既无法还原原来的明文的。它常用在报文鉴别和数字签名中。
所以当用户登录验证时应该把用户输入的密码加密一次再和数据库里面的密码比较。
 

你可能感兴趣的:(JAVA的加密问题)