MD5
首先,我们简单介绍一下MD5.
在正常的开发中,在登录的时候用到MD5消息摘要算法较为多.
MD5就像每一人的指纹一样是独一无二的,不同的数据加密后的结果是不一样的.
不过相同的数据加密后的结果是一样的.开发人员用它来进行密码加密存到数据库中,每次登陆将密码加密后与数据库中的密码进行比对.
MD5它是不可逆的,不过现在的技术讷讷够进行破解.
MD5:消息摘要算法第五版,之前还有MD2,MD4等.
用于一致性校验.就拿文件来说吧,如果文件被改动那么MD5也会随之改变.判断下载的文件是否被篡改.
还可用于数字签名,安全访问认证(数据库密码)等.
*算法原理:***MD5以512位分组来处理输入的信息,且每一分组又被划分为16个32位子分组,经过了一系列的处理后,算法的输出由四个32位分组组成,将这四个32位分组级联后将生成一个128位散列值.
MD5,SHA1:属于散列算法,不可逆.
MD5使用很简单:
public static void MD5Encrypt(String data) throws NoSuchAlgorithmException {
StringBuffer ensryptStr = new StringBuffer();
MessageDigest digest = MessageDigest.getInstance("MD5");
digest.update(data.getBytes());
byte[] cipher = digest.digest();
for (byte b : cipher) {
//转换为16进制
String hexStr = Integer.toHexString(b & 0xff);
ensryptStr.append(hexStr.length() == 1 ? "0" + hexStr : hexStr);
}
System.out.println(ensryptStr.toString());
System.out.println("c4ca4238a0b923820dcc509a6f75849b");
}
public static void main(String[] args) throws NoSuchAlgorithmException {
MD5Encrypt("1");
}
SHA1
SHA1:shA1也是散列加密.全名:安全哈希加密算法(Secure Hash Algorithm)主要用于数字签名.
public static void sha1Encrypt(String str) throws NoSuchAlgorithmException {
MessageDigest messageDigest = MessageDigest.getInstance("SHA1");
messageDigest.update(str.getBytes());
byte[] cipher = messageDigest.digest();
String a = "";
for (byte b : cipher) {
String hex = Integer.toHexString(b & 0xff);
a += (hex.length() == 1 ? "0" + hex : hex);
}
System.out.println(a);
}