在使用 https://github.com/btcsuite/btcd
生成 MultisigScript 只要有公钥就行。HD 钱包 xpub 和 zpub 可以混合做 multisig 吗?
1
acess 2023-10-08 21:06:12 +08:00
p2wpkh 和 p2pkh 从定义上他就不是(传统的,靠脚本实现的)多重签名……这俩本来就是锁定脚本的名字,锁定脚本都那么写了,明摆着他就不是 multisig 啊……
不过话题扯开点,我记得也有不依靠脚本系统实现一样的多重签名功能,我记得好像叫 2p-ecdsa 。 再有 p2tr 也可以不靠脚本支持多签,但 key path 很遗憾不支持 2of3 这种多数同意投票多签,只支持全体同意或者少数同意这两种情况。 |
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 。 |
3
dzdh OP @acess #2 electrum 默认是基于 zpub 。找了一圈只有一些在线脑钱包支持生成 xpub 。有什么钱包能生成 xpub 么而且像 electrum 那么好用的,或者 electrum 有 GUI 形式的导出 xpub 的方法么
而且对于 multisig 交易签名来说,electrum 钱包必须生成对应的 multisig 钱包才能进行签名,即便原始交易 hexcode 的 redeemscript 中能解出当前钱包的 pubkey 也不行。 |
4
acess 2023-10-08 23:23:55 +08:00
@dzdh 不太明白……你就按照 electrum 的用法,新创建一个多签的钱包不就好了?听起来好像你还是在琢磨着怎么让一个密钥同时用于多种用途,不知道我有没有理解错,这个做法我反正是不推荐的。
|
5
dzdh OP @acess #4 不考虑不同类型密钥,只用 electrum 钱包,创建多签钱包,要求输入 xpub ,那么这个 xpub 从哪来呢?
|
7
acess 2023-10-09 19:21:11 +08:00
为了确认我刚刚还新创建了一个钱包,新建两个 Electrum 种子(这个和 BIP39 用的单词表一样,但不兼容,不是一回事)走了一遍流程
|
9
dzdh OP 用种子不是拥有私钥了吗? 多人共管钱包不是只能发送公钥给别人么
|
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 |
11
acess 2023-10-09 22:10:23 +08:00
自己创建种子当然还是只有自己拿在手里,然后发给别人的只有公钥。
|
12
acess 2023-10-09 22:11:56 +08:00
小写 zpub 根据 BIP84 是用于 P2WPKH 。大写 Zpub 不是根据哪个标准,而是 Electrum 自己的做法,用于 P2WSH 多重签名。
|
13
dzdh OP @acess #12 electrum 新建标准钱包 -> 打开钱包 -> 信息,公钥就是这个小写 z 开头的 zpub....。
新创建多重签名,提示需要 xpub ,而整个钱包又没任何地方能获取到 xpub |
15
dzdh OP @acess #14
新建多重签名钱包,提示需要 xpub ,而 electrum 翻烂了只能看到 zpub (小写)。所以只能输入种子助记词,但是有助记词不就有了私钥? 1. electrum 2. multisig 3. 多人共管钱包(我只有一个我自己的种子,和两个别人的 zpub (小写)公钥) 4. 创建多签只能使用 xpub (选择:我有主公钥或私钥),electrum 只有 zpub (菜单栏 钱包->信息) |
17
dzdh OP @acess #16 一定要 2of3 呢. electrum 创建多签只接受 xpub 开头公钥。 我的种子+额外两方公钥,一定要这种形式呢?
|
18
acess 2023-10-10 16:01:16 +08:00
另外两方也用 electrum 新建钱包啊,他们新建好了,然后把 Zpub 交给你,就像你把你的 Zpub 交给他们一样。
|
19
dzdh OP @acess #18
然后我点击新建钱包,选择 Multisig ,选择我有主公钥对吧?然后输入 Zpub 是吧? ok ,失败,提示只支持`xpub 开头的` 公钥,`Zpub/zpub/Ypub/ypub` 都不行,必须是`xpub`。这个 xpub ,通过 electrum 钱包,在哪能获取到?这里 xpub 的 x 不是指代任意字符就是字面意义的`xpub`,electrum 要求必须是`xpub` 开头。 |
21
acess 2023-10-10 16:54:16 +08:00
|
22
dzdh OP @acess #21 第二部 2 of 3 的时候,选 [输入联属人的密钥] ,此时仍然提示只接受`xpub`开头的主公钥。
|