p2wpkh 和 p2pkh 可以做 multisig 吗? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
dzdh
V2EX    Bitcoin

p2wpkh 和 p2pkh 可以做 multisig 吗?

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

    在使用 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 的方法么br />

    而且对于 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     Solana     3562 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 26ms UTC 04:32 PVG 12:32 LAX 21:32 JFK 00:32
    Do have faith in what you're doing.
    ubao snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86