import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class md5 {
public String str;
public void md5s(String plainText) {
try {
MessageDigest md = MessageDigest.getInstance("MD5");
md.update(plainText.getBytes());
byte b[] = md.digest();
int i;
StringBuffer buf = new StringBuffer("");
for (int offset = 0; offset < b.length; offset++) {
i = b[offset];
if (i < 0)
i += 256;
if (i < 16)
buf.append("0");
buf.append(Integer.toHexString(i));
}
str = buf.toString();
System.out.println("result: " + buf.toString());// 32位的加密
System.out.println("result: " + buf.toString().substring(8, 24));// 16位的加密
} catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public static void main(String agrs[]) {
md5 md51 = new md5();
md51.md5s("4");//加密4
}
}
=============自己的:================
public class MD5 {
public static String getMD5(String source) {
String s = null;
char hexDigits[] = { // ��4���ֽ�ת���� 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.getBytes());
byte tmp[] = md.digest(); // MD5 �ļ�������һ�� 128 λ�ij�����
// ���ֽڱ�ʾ���� 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();
}
return s;
}
}