适配md5老算法

新平台开发的系统和老系统混合使用,遇到个烦人问题。老系统对字符串md5和新系统算的不一样。老系统是很近以前开发的,开发商早没影了,只好反编译,得到算法如下:

复制代码
public static String Md5(String input){
    MessageDigest md = MessageDigest.getInstance("MD5");
    byte[] digest = md.digest(input.getBytes());
    BigInteger bi = new BigInteger(digest);
    return bi.toString(16);
}

这段代码的缺陷:

  1. new BigInteger(digest) 会把 MD5 字节数组转成有符号整数 ,结果可能带负号
  2. 不会自动补全前导零,导致长度不固定(不是标准 32 位)

新系统是前端做md5发往后端验证,代码如下:

import md5 from 'js-md5';

md5(data)

这种写法会导致两端计算结果不一样。修正如下:

javascript 复制代码
function eHRMd5(str) {
  // 1. 用js-md5拿到标准字节数组
  const bytes = md5.digest(str);
  // 2. 转Java风格有符号BigInteger
  const bi = bytesToJavaSignedHex(bytes);
  // 3. 输出和后端一致的结果
  return bi.toString(16);
}

// 【纯数字实现】无 8n、无 0n、无任何 BigInt 语法!
function bytesToJavaSignedHex(bytes) {
  let hex = '';
  const negative = (bytes[0] & 0x80) !== 0;

  if (negative) {
    // 负数:补码计算
    let temp = [];
    let carry = 1;
    for (let i = bytes.length - 1; i >= 0; i--) {
      let val = 255 - bytes[i] + carry;
      carry = val > 255 ? 1 : 0;
      temp[i] = val & 255;
    }
    hex = bytesToHex(temp);
    hex = '-' + hex.replace(/^0+/, ''); // 去前导零 + 负号
  } else {
    // 正数
    hex = bytesToHex(bytes).replace(/^0+/, '');
  }

  return hex || '0';
}

// 字节数组转十六进制
function bytesToHex(bytes) {
  return Array.from(bytes, b => 
    (b & 0xff).toString(16).padStart(2, '0')
  ).join('');
}
相关推荐
Jack2018 小时前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树20 小时前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2121 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2121 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050732 天前
(一)小红的数组操作
算法·编程语言
怕浪猫2 天前
Electron 系列文章封面图
算法·架构·前端框架
徐小夕2 天前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法