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

p2wpkh 和 p2pkh 可以做 multisig 吗?

  •  
  •   dzdh · 2023-10-07 10:08:56 +08:00 · 700 次点击
    这是一个创建于 422 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

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

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

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

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

    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
       2023-10-08 22:57:50 +08:00
    @acess #2 electrum 默认是基于 zpub 。找了一圈只有一些在线脑钱包支持生成 xpub 。有什么钱包能生成 xpub 么而且像 electrum 那么好用的,或者 electrum 有 GUI 形式的导出 xpub 的方法么


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




    zpubcf9.......
    dzdh
        9
    dzdh  
    OP
       2023-10-09 20:44:19 +08:00
    用种子不是拥有私钥了吗? 多人共管钱包不是只能发送公钥给别人么
    acess
        10
    acess  
       2023-10-09 22:09:46 +08:00
    @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  
       2023-10-09 22:10:23 +08:00
    自己创建种子当然还是只有自己拿在手里,然后发给别人的只有公钥。
    acess
        12
    acess  
       2023-10-09 22:11:56 +08:00
    小写 zpub 根据 BIP84 是用于 P2WPKH 。大写 Zpub 不是根据哪个标准,而是 Electrum 自己的做法,用于 P2WSH 多重签名。
    dzdh
        13
    dzdh  
    OP
       2023-10-10 09:04:12 +08:00
    @acess #12 electrum 新建标准钱包 -> 打开钱包 -> 信息,公钥就是这个小写 z 开头的 zpub....。

    新创建多重签名,提示需要 xpub ,而整个钱包又没任何地方能获取到 xpub
    acess
        14
    acess  
       2023-10-10 09:17:05 +08:00 via Android
    @dzdh 新建多重签名啊,不是新建标准
    dzdh
        15
    dzdh  
    OP
       2023-10-10 09:46:33 +08:00
    @acess #14

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

    1. electrum

    2. multisig

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

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

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

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

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