gpt4 book ai didi

bitcoin - 取消比特币交易

转载 作者:行者123 更新时间:2023-12-04 10:00:38 31 4
gpt4 key购买 nike

我正在编写一个比特币应用程序并希望实现“取消”功能。 Reddit 上的所有引用资料都表明,如果发生了 3 次以下的确认,从技术上讲,可以停止付款。也许只有一两分钟可用,但仍然如此。
我在比特币 api 文档中找不到任何引用资料来演示如何做到这一点。
我知道出于这个原因,一个山寨币故意使用 60 分钟的间隔来确认。

有谁知道这是怎么做到的?

最佳答案

是否可以取消比特币交易...

... 这是 还没有播出?

是的,显然这是可能的。我建议你在你的比特币应用程序中选择这种方法,向用户显示一个确认屏幕几秒钟,其中包含有关交易的信息和一些按钮,上面写着 cancelconfirm . @nahtnam 提出了 60 分钟的延迟,考虑到您可能无法访问互联网或希望交易尽快出现在区块链中,这太过分了。

... 这是 已经播出了?

也许... 要取消此类交易,您需要自己创建一个区块,将原始交易的输入移动到您自己的地址之一。 (有效地使原始交易无效。)但是,截至目前,创建一个区块需要花费数千美元,并且不能保证找到一个区块。

另一种可能性是广播另一笔交易,采用与原始交易相同的输入,并将输出定位在您自己的地址/钱包之一。为了激励矿工加入此交易而不是原始交易,您增加了交易费用。然而,一些客户可能不会将这种双花交易转发给矿工,而一些矿工可能会拒绝双花交易并包含原始交易(他们首先收到的交易)。 (参见 Bitpay encountered zero double spent in the first 10000 transactions.Cancelling an unconfirmed transaction by @theymos (bitcoin.stackexchange))

有一些技巧可以通过创建所谓的“非标准”交易来向矿工隐藏您的初始交易。或者,交易可能包括非常低的费用,以使矿工出于经济原因拒绝它。 (c.f. Significant losses by double-spending unconfirmed transactions (bitcoin-dev mailing list)Double-spending by @petertodd (Reddit) )但是,如果接收者仔细查看,这会使您的交易看起来很可疑,并且他们很可能会要求您等到它有一个或多个确认。

最后,如果您在原始交易上设置一个标志来指示可替换性,也是可能的。然后,您可以通过在替换交易中包含相同(一个或多个)输入来将原始交易替换为另一个交易。此外,您必须支付更高的费用。但是,并非所有矿工都遵守此标志,有些矿工可能仍包含您的初始交易。 (参见引用 BIP 125: Opt-in Full Replace-by-Fee Signaling)

... 这是 包含在一个或多个块中?

不,非常不可能甚至不可能。 您需要控制大量的散列能力来创建 fork ,方法是重建从原始交易发生之前的区块开始并以 height = (current public blockchain height) + 1 结束的区块的区块链。 .因此,“你拥有的确认越多,像这样的攻击就越困难、昂贵和不可靠。”
Source: @DannyHamilton (Bitcointalk)
Satoshi Nakamoto 的比特币论文解释说,当你控制超过 50% 的散列能力时,这总是可能的,如果你控制不到 50% 的散列能力,则概率小于 1,但大于 0。见 Bitcoin: A Peer-to-Peer Electronic Cash System .
但是,如果你控制了大量的散列能力,你很可能不会通过撤销交易和间接损害你的挖矿收入流来破坏对比特币的信任。

关于bitcoin - 取消比特币交易,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20929564/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com