Android常見加密演算法(MD5加密)
阿新 • • 發佈:2019-01-21
MD5加密是不可逆的,加密後字串可取16位或32位。一定注意,MD5加密區分大小寫,加密出來的結果不同。
public class MD5Util {
private static char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7',
'8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };
public static String getBytesMD5(byte[] bytes) {
try {
// 獲得MD5摘要演算法的 MessageDigest 物件
MessageDigest mdInst = MessageDigest.getInstance("MD5");
// 使用指定的位元組更新摘要
mdInst.update(bytes);
// 獲得密文
byte[] md = mdInst.digest();
// 把密文轉換成十六進位制的字串形式
int j = md.length;
char str[] = new char[j * 2];
int k = 0;
for (int i = 0; i < j; i++) {
byte byte0 = md[i];
str[k++] = hexDigits[byte0 >>> 4 & 0xf];
str[k++] = hexDigits[byte0 & 0xf];
}
return new String(str);
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
/**
* 返回字串的32位MD5值
*
* @param s
* 字串
* @return str MD5值
*/
public final static String getStringMD5(String s) {
return getBytesMD5(s.getBytes());
}
/**
* 返回字串的16位MD5值
*
* @param s
* 字串
* @return str MD5值
*/
public final static String getStringMD5_16(String s) {
return getStringMD5(s).substring(8, 24);
}
public final static String getBitmapMD5(Bitmap bm) {
return getBytesMD5(bitmapToBytes(bm));
}
public final static String getBitmapMD5_16(Bitmap bm) {
return getBytesMD5(bitmapToBytes(bm)).substring(8, 24);
}
public static byte[] bitmapToBytes(Bitmap bm) {
ByteArrayOutputStream baos = new ByteArrayOutputStream();
bm.compress(Bitmap.CompressFormat.PNG, 100, baos);
return baos.toByteArray();
}
}
我來展示一下,如何呼叫MD5Util進行加密,相當簡單:
/**
*@param sign 原始資料
*@param secretSign 32位MD5值
*@param secretSign_16 16位MD5值
*/
String sign = "sbW5vcHFyc3R1dnd4"
String secretSign = MD5Util.getStringMD5(sign);
String secretSign_16 = MD5Util.getStringMD5_16(sign);