首页 > 解决方案 > 从 javascript 中的缓冲区创建 bigInteger

问题描述

我在 gatsby 中使用 bigInt 库,就像这样

import BigInteger from 'bigi';

const signature = ecdsa.sign(shaMsg, BigInteger.fromBuffer(privateKey));

生产版本中似乎存在一些我无法修复的 polyfill 问题。在 localhost 中运行时没有问题。

所以我想我会尝试一个不同的 bigInt 库来看看这是否能解决它

import bigInt from "big-integer";

问题是这个库没有fromBuffer函数,signature在上面的代码中是缓冲区类型。

除了使用“bigi”库中的函数之外,我如何转换它?

谢谢(这个问题是否有意义,因为我不知道我在做什么)

编辑:为澄清起见,控制台登录BigInteger.fromBuffer(privateKey)开发版本(有效的版本)结果:

BigInteger {0: 5218218, 1: 6291014, 2: 34656281, 3: 1776116, 4: 53518743, 5: 10808093, 6: 62725491, 7: 63913863, 8: 50275223, 9: 1979384, t: 10, s: 0}

在生产环境中,它不起作用,上面的相同日志

n {0: 5218218, 1: 6291014, 2: 34656281, 3: 1776116, 4: 53518743, 5: 10808093, 6: 62725491, 7: 63913863, 8: 50275223, 9: 1979384, t: 10, s: 0}

我不明白会发生什么,也许问题出在ecdsa库中,正如下面的评论员所建议的那样

我在生产中遇到的错误是

Expected property "1" of type BigInteger, got n

编辑:我解决了这个问题,我在其他地方得到了帮助,使用椭圆而不是 ecdsa 进行签名,如下所示,这是一个 ecsda 问题。由于赏金,我无法关闭,也无法发布答案,所以我不知道该怎么办

标签: reactjscryptographybiginteger

解决方案


ecdsa库已弃用(来源

如果您需要其他曲线,请使用secp256k1椭圆。


推荐阅读