1.MD5: 全称为message digest algorithm 5(信息摘要算法), 可以进行加密, 但是不能解密, 属于单向加密, 通常用于文件校验
Base64: 把任意序列的8为字节描述为一种不易为人识别的形式, 通常用于邮件、http加密. 登陆的用户名和密码字段通过它加密, 可以进行加密和解密.
2.base64
Base64编码是把每3个8位字节(3*8=24)转成4个6位字节(4*6=24),且在每个6位字节前补两个0,重新形成8位一个字节的形式,这样总的长度还是相同的,并且保证最高位不是1(即不是负数)。
如果最后剩下的字符不足3个字符,则用0填充高位,输出字符使用“=”。因此编码后的字符串末尾可能会出现一个或两个“=”。
根据上述原理,最高两位均为0,那么剩下6位全为1二进制对应的十进制为63,所以最大数不会超过63,根据这64个数进行一个码值与字符的对应,就成了base64编码,对应编码表如下图所示:
3.代码
md5.java
package test;
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import sun.misc.BASE64Encoder;
public class md5 {
/**利用MD5进行加密*/
public String EncoderByMd5(String str) throws NoSuchAlgorithmException, UnsupportedEncodingException{
//确定计算方法
MessageDigest md5=MessageDigest.getInstance("MD5");//MD5加密
BASE64Encoder base64en = new BASE64Encoder();//初始化BASE64Encoder对象
//加密后的字符串
String newstr=base64en.encode(md5.digest(str.getBytes("utf-8")));//将MD5加密后进行BASE64加密
return newstr;//返回结果
}
/**判断用户密码是否正确
*newpasswd 用户输入的密码
*oldpasswd 正确密码*/
public boolean checkpassword(String newpasswd,String oldpasswd) throws NoSuchAlgorithmException, UnsupportedEncodingException{
if(EncoderByMd5(newpasswd).equals(oldpasswd))//比较输入的密码和正确的密码是否一致
return true;
else
return false;
}
}
mytest.java
package test;
import java.io.UnsupportedEncodingException;
import java.security.NoSuchAlgorithmException;
public class mytest {
//主程序入口
public static void main(String[] args) throws NoSuchAlgorithmException, UnsupportedEncodingException {
md5 md5 = new md5();//初始化md5对象
String str = "s1";//定义字符串变量并赋值
try {
String newString = md5.EncoderByMd5(str);//base64加密
System.out.println(newString);//输出输入密码的加密结果
} catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(md5.EncoderByMd5("s1").equals("jd+HgDm3B2fEpbz08MT2Xg=="));//输出匹配结果
}
}
4.运行结果