BSV 上的 Schnorr 签名

Posted sCrypt 智能合约

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了BSV 上的 Schnorr 签名相关的知识,希望对你有一定的参考价值。

我们已经在 BSV 上实现了 Schnorr 签名。这是第一个也是唯一一个已知的实现,没有对原始协议进行任何更改¹。

一笔交易一个签名

Schnorr 是一种可以用于替代比特币签名当前使用的 ECDSA 算法的替代算法。一个关键优势是,同一交易的一个输入或多个输入中的多个签名可以聚合为一个签名。关于 BTC 上的 Schnoor 签名有很多炒作,但是都需要像 BIP 340 细节一样进行巨大的更改。

我们将展示了如何通过原始的比特币协议来实现它。下面列出了验证 Schnorr 签名的完整代码,其中使用我们之前发布的椭圆曲线操作。


import "ec.scrypt";

// Schnorr signatures verification for secp256k1
contract Schnorr 
    public function verify(Sig sig, PubKey pubKey, bytes msg, int lambda,
        Point R, PointMulAux rAux,
        Point E, PointMulAux eAux,
        Point S, PointMulAux sAux) 

        int r = unpack(pubKey[ : 32]);
        int s = unpack(pubKey[32 : 64]);

        // R = r * G
        require(EC.isMul(EC.G, r, R, rAux));

        // e = Hash(r || P || msg)
        int e = unpack(sha256(pack(r) + pubKey + msg));

        // E = e * P
        Point P = pubKey2Point(pubKey);
        require(EC.isMul(P, e, E, eAux));

        // S = s * G
        require(EC.isMul(EC.G, s, S, sAux));

        // S == R + H?
        require(EC.isSum(R, E, lambda, S));
    

    // convert public key to a point, assuming it's uncompressed
    static function pubKey2Point(PubKey pubKey) : Point 
        require(pubKey[: 1] == b'04');
        return  unpack(pubKey[1 : 33]), unpack(pubKey[33 : 65]) ;
    


Schnorr签名合约

[1] 使用 Schnorr 签名的法律含义超出了本文的范围。

以上是关于BSV 上的 Schnorr 签名的主要内容,如果未能解决你的问题,请参考以下文章

BSV 上的环签名

Schnorr签名介绍

比特币的双线性配对- BLS 签名

BSV 上的私钥谜题

BSV 上的私钥谜题

BSV上的委托合约