javascript - 将一个大整数编码为 base62

标签 javascript node.js

我需要创建唯一的推荐代码。为了使每个推荐代码都独一无二,我尝试执行如下操作。

const stringVal = `${currentTimestamp}${someVal}${someKey}`

这里 someVal 本身是 BigInt mysql 数据类型,而 someKey 将始终是两位数。

为了编码,我使用 base62包裹。

每当我通过 someVal 超过 99 时,我就会开始得到意想不到的结果。

function generateReferralCode(someVal) {
   const currentTimestamp = Date.now()
   let someKey = getSomeKey(someVal)
   const val = `${currentTimestamp}${someVal}${someKey}`
   console.log(`number to string : ${val}`)
   console.log(`longed value from string : ${Long.fromString(val)}`)
   const encodedVal = await base62.encode(Long.fromString(val))
   return encodedVal
}
function parseReferralCode(referralCode) {
    const decodedVal = base62.decode(referralCode)
    console.log(`decoded number : ${decodedVal}`)
    //extract someValue
    let  somevalue = parseInt(decodedVal / 100) % ( Math.pow(10, (decodedVal % 100)))
    return someValue
}

async function test() {
    const encoded = await generateReferralCode(100)
    console.log(`encoded val: ${encoded}`)
    const decoded = await parseReferralCode(encoded)
    console.log(`decoded val: ${decoded}`)
}
test()

Output:

number to  string : '158632196111710003'
longed value from string : 158632196111710003
encoded val: 'bIxiLMdWrm'
decoded number : 158632196111710000 //this should be as encoded string or longed val
decoded val: 1586321961117100 //this should be 100

以上不适用于 someValue > 99 的值。我知道这是因为 JavaScript 中的整数长度。

我还尝试使用 long ,但它也不起作用。

我认为 base62 包也不支持大整数。

有人可以帮助我如何 base62 编码这种大数字吗?

最佳答案

FWIW,以下是将 BigInt 转换为所需基数的两个辅助函数,反之亦然...

var digits = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';

function bigint2base( x, baseDigits ) {

  let base = BigInt( baseDigits.length );
  let result = '';
  
  while ( 0 < x ) {
    result = baseDigits.charAt( Number( x % base ) ) + result;
    x = x / base;
  }
    
  return result || '0';
  
}


function base2bigint( x, baseDigits ) {

  let base = BigInt( baseDigits.length ); 
  let result = 0n;
  
  for ( let i = 0; i < x.length; i++ ) {
    result = result * base + BigInt( baseDigits.indexOf( x.charAt( i ) ) );
  }
  
  return result;
}

console.log( `BigInt 158632196111710003n to base62 ( '${digits}' )...`);
base62val = bigint2base( 158632196111710003n, digits );
console.log( base62val );

console.log( `Converted back to BigInt is...` );
console.log( base2bigint( base62val, digits ).toString() );

console.log('');
console.log( `BigInt 31957108571341948394931814703184314387417471347093174n to base62 ( '${digits}' )...`);
base62val = bigint2base( 31957108571341948394931814703184314387417471347093174n, digits );
console.log( base62val );

console.log( `Converted back to BigInt is...` );
console.log( base2bigint( base62val, digits ).toString() );

希望这有帮助...

关于javascript - 将一个大整数编码为 base62,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61093432/

相关文章:

node.js - nodeJs - 使用 Unirest 发布带有表单数据的请求

javascript - 如果我多次需要一个文件,它会被多次解析吗?

javascript - Express 和 ejs 中出现错误,用于在屏幕上显示数据库中的数据

javascript - 刷新并填充动态添加的行

javascript - console.log(document.head) 结果随每次刷新而交替

javascript - d3 无法在 safari 中绘制日期轴,解析错误

javascript - AJAX:列出目录的内容。无法解析网址

javascript - readFileSync 不是函数

node.js - 在 Sails.JS 中持久化之前添加缺少的请求参数

javascript - 无法使用 jQuery(Chrome 扩展)选择某些 Facebook 类