p2wpkh 和 p2pkh 可以做 multisig 吗?

2023-10-07 10:08:56 +08:00
 dzdh

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

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

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

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

再有 p2tr 也可以不靠脚本支持多签,但 key path 很遗憾不支持 2of3 这种多数同意投票多签,只支持全体同意或者少数同意这两种情况。
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
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
2023-10-08 23:23:55 +08:00
@dzdh 不太明白……你就按照 electrum 的用法,新创建一个多签的钱包不就好了?听起来好像你还是在琢磨着怎么让一个密钥同时用于多种用途,不知道我有没有理解错,这个做法我反正是不推荐的。
dzdh
2023-10-09 01:58:25 +08:00
@acess #4 不考虑不同类型密钥,只用 electrum 钱包,创建多签钱包,要求输入 xpub ,那么这个 xpub 从哪来呢?
acess
2023-10-09 19:20:14 +08:00
@dzdh 这里的 xpub 就只是泛指,默认的 Zpub 直接粘贴进去就可以了。
acess
2023-10-09 19:21:11 +08:00
为了确认我刚刚还新创建了一个钱包,新建两个 Electrum 种子(这个和 BIP39 用的单词表一样,但不兼容,不是一回事)走了一遍流程
dzdh
2023-10-09 20:43:19 +08:00
@acess #7 zpub 不行哦.




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

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

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

1. electrum

2. multisig

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

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

a.gif

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/979383

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX