Java中使用MessageDigest实现哈希需先通过getInstance获取实例,update分步输入或digest一步计算,结果byte[]须转为补零十六进制字符串;实例非线程安全,应避免共享,推荐每次新建或用ThreadLocal隔离。
Java 中使用 MessageDigest 实现哈希,核心是获取指定算法的摘要实例、传入数据、完成计算并输出字节数组——再转为十六进制字符串才是常见用法。
通过 MessageDigest.getInstance("算法名") 获取,如 "SHA-256"、"MD5"、"SHA-1"。注意大小写不敏感,但推荐大写标准写法。
Security.getAlgorithms("MessageDigest") 查看)NoSuchAlgorithmException,建议捕获处理digest() 后继续 update(),需重新 reset()
适合处理大文件或流式数据:先 update(byte[]) 输入一部分,多次调用后最终 digest() 得结果。
update() 可多次调用,内部累积状态digest() 会自动调用 reset(),之后该实例不可再用于后续计算digest(byte[] input) 一步到位MessageDigest.digest() 返回的是原始 byte[],需手动转成 0-9a-f 的 16 进制字符串才便于存储或比对。
new String(byte[], "UTF-8") 直接转——会乱码String.for
mat("%02x", b & 0xFF) 或 BigInteger(1, bytes).toString(16)
-1 对应 0xff,不是 ff;需保证每位都是两位十六进制MessageDigest 实例**不是线程安全的**,多个线程共用同一实例会导致结果错误。
ThreadLocal 隔离基本上就这些。封装时把算法名、输入 byte[] 和转 hex 的逻辑包好,就能稳定产出一致哈希值。