Apache提供的Commons-codec中对MessageDigest进行了封装,可以直接使用,如果想自己实现,MessageDigest位于java.security包下。
摘要算法同样不是加密算法,因为经过摘要计算之后,数据往往无法还原,通常用于保证数据传输的完整性。
在数据传输中,对所有的数据进行摘要计算,当另一台电脑获取数据之后,进行同样的摘要计算,如果结果相同,那么说明本次接收到完整的数据。
在一些个性化的设计中,也有使用摘要算法生成密钥的做法。
MD5算法生成字符串,结果分为16位和32位,需要用到的还有16进制编码工具,可以参考Commons-codec
import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class MD5 { public static byte[] digest(byte[] data) { try { MessageDigest md5 = MessageDigest.getInstance("MD5"); md5.update(data); return md5.digest(); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); return null; } } public static String hexBit32(String data) { return Hex.encodeToString(digest(data.getBytes())); } public static String hexBit16(String data) { return hexBit32(data).substring(8, 24); } public static void main(String[] args) { System.out.println(MD5.hexBit16("12121212")); } }
因为是按照接口标准实现的,直接修改MessageDigest.getInstance()的参数即可获取不同的加密方法。
public static final String MESSAGE_DEGEST_MD2 = "MD2"; public static final String MESSAGE_DEGEST_MD5 = "MD5"; public static final String MESSAGE_DEGEST_SHA = "SHA"; public static final String MESSAGE_DEGEST_SHA_224 = "SHA-224"; public static final String MESSAGE_DEGEST_SHA_256 = "SHA-256"; public static final String MESSAGE_DEGEST_SHA_384 = "SHA-384"; public static final String MESSAGE_DEGEST_SHA_512 = "SHA-512";
原文:https://www.cnblogs.com/chenss15060100790/p/9080018.html