前言
由于安全性考虑,需要把sign中的key值以及其他的参数进行MD5方式签名加密,可以有效的保护应用程序的数据
简介
MD5即Message-Digest Algorithm 5(信息-摘要算法5),用于确保信息传输完整一致。是计算机广泛使用的杂凑算法之一(又译摘要算法、哈希算法),主流编程语言普遍已有MD5实现。将数据(如汉字)运算为另一固定长度值,是杂凑算法的基础原理,MD5的前身有MD2、MD3和MD4。
MD5算法具有以下特点:
1、压缩性:任意长度的数据,算出的MD5值长度都是固定的。
2、容易计算:从原数据计算出MD5值很容易。
3、抗修改性:对原数据进行任何改动,哪怕只修改1个字节,所得到的MD5值都有很大区别。
4、强抗碰撞:已知原数据和其MD5值,想找到一个具有相同MD5值的数据(即伪造数据)是非常困难的。
MD5的作用是让大容量信息在用数字签名软件签署私人密钥前被”压缩”成一种保密的格式(就是把一个任意长度的字节串变换成一定长的十六进制数字串)。
MD5常见用途
- 登陆密码保护时将密码进行MD5加密再上传到数据库,可以防止被密码被劫持破解。如密码是123456,如果明文上传,被人获取后能轻易盗取账号,如果用md5加密后,它变成”49ba59abbe56e057”,这样即使被劫持,也难以将这串字符反译成123456
- 检验文件完整性
网络传输文件时,受到网络环境的影响,有时会发生文件传输不完整的现象。这个时候常见的方法就是用md5校验码。如果两个文件的md5一样,那么文件就下载完整了,如果不一样说明下载不完成。
使用
MD5加密是不可逆的(现在已经可以被破解了,更多信息请自行上网搜索),加密后字符串可取16位或32位。一定注意,MD5加密要区分大小写,否则加密出来的结果不同。
/**
* Created by ${zk} on 2018/4/25 0025.
* 欢迎每一天
*/
public class MD5sign {
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();
}
/**
* 加密文件
* @param file
* @return 视频 音乐
*/
public static String md5ForFile(File file){
int buffersize = 1024;
FileInputStream fis = null;
DigestInputStream dis = null;
try {
//创建MD5转换器和文件流
MessageDigest messageDigest =MessageDigest.getInstance("MD5");
fis = new FileInputStream(file);
dis = new DigestInputStream(fis,messageDigest);
byte[] buffer = new byte[buffersize];
//DigestInputStream实际上在流处理文件时就在内部就进行了一定的处理
while (dis.read(buffer) > 0);
//通过DigestInputStream对象得到一个最终的MessageDigest对象。
messageDigest = dis.getMessageDigest();
// 通过messageDigest拿到结果,也是字节数组,包含16个元素
byte[] array = messageDigest.digest();
// 同样,把字节数组转换成字符串
StringBuilder hex = new StringBuilder(array.length * 2);
for (byte b : array) {
if ((b & 0xFF) < 0x10){
hex.append("0");
}
hex.append(Integer.toHexString(b & 0xFF));
}
return hex.toString();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return null;
}
}