V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
dzdh
V2EX  ›  Bitcoin

p2wpkh 和 p2pkh 可以做 multisig 吗?

  •  
  •   dzdh · 203 天前 · 531 次点击
    这是一个创建于 203 天前的主题,其中的信息可能已经有所发展或是发生改变。

    在使用 https://github.com/btcsuite/btcd

    生成 MultisigScript 只要有公钥就行。HD 钱包 xpub 和 zpub 可以混合做 multisig 吗?

    24 条回复    2023-10-10 17:48:20 +08:00
    acess
        1
    acess  
       202 天前
    p2wpkh 和 p2pkh 从定义上他就不是(传统的,靠脚本实现的)多重签名……这俩本来就是锁定脚本的名字,锁定脚本都那么写了,明摆着他就不是 multisig 啊……

    不过话题扯开点,我记得也有不依靠脚本系统实现一样的多重签名功能,我记得好像叫 2p-ecdsa 。

    再有 p2tr 也可以不靠脚本支持多签,但 key path 很遗憾不支持 2of3 这种多数同意投票多签,只支持全体同意或者少数同意这两种情况。
    acess
        2
    acess  
       202 天前
    啊我好像理解错楼主的意思了……尴尬

    p2wpkh 和 p2pkh 组合成混合的多签,楼主好像说的是这个意思?

    zpub 这个其实 achow101 吐槽过的,他属于分层破坏,因为本来 xpub 只负责管公钥,公钥具体被拿到什么脚本里使用是另一个层面的事情了,然后 zpub 就是通过改前缀版本号,管了“用什么脚本”这个本来他不该管的事情。

    然后 bitcoin core 开发者其实是推出 output descriptor 作为替代方案,这样 xpub 就只负责公钥了,descriptor 负责描述具体用什么脚本。

    zpub 用 base58check 解码然后修改版本号即可重新编码成 xpub ,但——

    不推荐这样中途改变密钥用途。

    一个密钥身兼多职会造成混乱,这是非常不好的事情,比如 X 密钥既用于用途 A 、又同时用于用途 B ,你以为用途 A 这边没余额了,所以把 X 密钥删了,但其实忘记了用途 B ,于是用途 B 这边就永久丢币了……

    再有就是,如果用途 A 这边钱包出 bug 或者被黑泄露了密钥,也会牵连到用途 B 。
    dzdh
        3
    dzdh  
    OP
       202 天前
    @acess #2 electrum 默认是基于 zpub 。找了一圈只有一些在线脑钱包支持生成 xpub 。有什么钱包能生成 xpub 么而且像 electrum 那么好用的,或者 electrum 有 GUI 形式的导出 xpub 的方法么


    而且对于 multisig 交易签名来说,electrum 钱包必须生成对应的 multisig 钱包才能进行签名,即便原始交易 hexcode 的 redeemscript 中能解出当前钱包的 pubkey 也不行。
    acess
        4
    acess  
       202 天前
    @dzdh 不太明白……你就按照 electrum 的用法,新创建一个多签的钱包不就好了?听起来好像你还是在琢磨着怎么让一个密钥同时用于多种用途,不知道我有没有理解错,这个做法我反正是不推荐的。
    dzdh
        5
    dzdh  
    OP
       201 天前
    @acess #4 不考虑不同类型密钥,只用 electrum 钱包,创建多签钱包,要求输入 xpub ,那么这个 xpub 从哪来呢?
    acess
        6
    acess  
       201 天前
    @dzdh 这里的 xpub 就只是泛指,默认的 Zpub 直接粘贴进去就可以了。
    acess
        7
    acess  
       201 天前
    为了确认我刚刚还新创建了一个钱包,新建两个 Electrum 种子(这个和 BIP39 用的单词表一样,但不兼容,不是一回事)走了一遍流程
    dzdh
        8
    dzdh  
    OP
       201 天前
    @acess #7 zpub 不行哦.




    zpubcf9.......
    dzdh
        9
    dzdh  
    OP
       201 天前
    用种子不是拥有私钥了吗? 多人共管钱包不是只能发送公钥给别人么
    acess
        10
    acess  
       201 天前
    @dzdh 我是专门为了多重签名新创建了种子,是大写 Zpub 。
    小写的 zpub 是 BIP84 标准里写的,大写的 Zpub 我查了,根据 Ian Coleman 的回复,是 Electrum 自己这么做


    https://github.com/spesmilo/electrum/blob/2f8325ca091ea1a9e29fc8803d813c680fe6e3dc/RELEASE-NOTES#L1174
    https://github.com/iancoleman/bip39/issues/301#issuecomment-466818554
    acess
        11
    acess  
       201 天前
    自己创建种子当然还是只有自己拿在手里,然后发给别人的只有公钥。
    acess
        12
    acess  
       201 天前
    小写 zpub 根据 BIP84 是用于 P2WPKH 。大写 Zpub 不是根据哪个标准,而是 Electrum 自己的做法,用于 P2WSH 多重签名。
    dzdh
        13
    dzdh  
    OP
       200 天前
    @acess #12 electrum 新建标准钱包 -> 打开钱包 -> 信息,公钥就是这个小写 z 开头的 zpub....。

    新创建多重签名,提示需要 xpub ,而整个钱包又没任何地方能获取到 xpub
    acess
        14
    acess  
       200 天前 via Android
    @dzdh 新建多重签名啊,不是新建标准
    dzdh
        15
    dzdh  
    OP
       200 天前
    @acess #14

    新建多重签名钱包,提示需要 xpub ,而 electrum 翻烂了只能看到 zpub (小写)。所以只能输入种子助记词,但是有助记词不就有了私钥?

    1. electrum

    2. multisig

    3. 多人共管钱包(我只有一个我自己的种子,和两个别人的 zpub (小写)公钥)

    4. 创建多签只能使用 xpub (选择:我有主公钥或私钥),electrum 只有 zpub (菜单栏 钱包->信息)
    acess
        16
    acess  
       200 天前 via Android
    @dzdh 天……
    新建 2of2 多重签名,两边都选种子,然后把各自的 Zpub 输给对方,完
    dzdh
        17
    dzdh  
    OP
       200 天前
    @acess #16 一定要 2of3 呢. electrum 创建多签只接受 xpub 开头公钥。 我的种子+额外两方公钥,一定要这种形式呢?
    acess
        18
    acess  
       200 天前
    另外两方也用 electrum 新建钱包啊,他们新建好了,然后把 Zpub 交给你,就像你把你的 Zpub 交给他们一样。
    dzdh
        19
    dzdh  
    OP
       200 天前
    @acess #18

    然后我点击新建钱包,选择 Multisig ,选择我有主公钥对吧?然后输入 Zpub 是吧? ok ,失败,提示只支持`xpub 开头的` 公钥,`Zpub/zpub/Ypub/ypub` 都不行,必须是`xpub`。这个 xpub ,通过 electrum 钱包,在哪能获取到?这里 xpub 的 x 不是指代任意字符就是字面意义的`xpub`,electrum 要求必须是`xpub` 开头。
    dzdh
        20
    dzdh  
    OP
       200 天前
    @acess #18

    a.gif
    acess
        21
    acess  
       200 天前
    行吧,我的锅,我没说清楚。
    https://i.postimg.cc/6pwsFvnD/2of3-4.png
    第四步,添加联署人 1 ,这一步,你得新建一个种子自己用。
    dzdh
        22
    dzdh  
    OP
       200 天前
    @acess #21 第二部 2 of 3 的时候,选 [输入联属人的密钥] ,此时仍然提示只接受`xpub`开头的主公钥。
    dzdh
        23
    dzdh  
    OP
       200 天前
    @acess #21

    我把另一个钱包的 zpub 转成 Zpub 后 2of3 算是过去了。那么问题来了,假设有 3 个人想生成一个 2of3 的 multisig 钱包,则每个人都必须先经过 multisg 第一步输入一下自己的密语种子得到一个 Zpub 么?
    acess
        24
    acess  
       200 天前 via Android
    @dzdh
    最好各自新建种子专门用于多重签名(虽然我查了 electrum seed versioning system 文档,里面不区分 P2WPKH 和 P2WSH )
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1869 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 16:17 · PVG 00:17 · LAX 09:17 · JFK 12:17
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.