科普:加密货币匿名混币器:Cce_Cash如何无法被追踪

閱讀時間約 17 分鐘

Cce Cash混币器提高了加密货币的隐私性和匿名性,使其更难追踪加密货币的用途以及它属于谁,Cce Cash混币服务就是在交易的输入和输出,加入一个类似于黑箱子的东西,隐藏原有的直接对应关系,以达到隐私保护的目的。混币服务通过将可能被识别的加密货币资金与其他货币混合以掩饰资金的流向,令人难以追溯资金的源头。

什么是零知识证明

零知识证明 (Zero—Knowledge Proof) 是由 S.Goldwasser、S.Micali 及 C.Rackoff 在 20 世纪 80 年代初提出的。它早于区块链诞生,但由于区块链,它被大家所熟知。它指的是证明者能够在不向验证者提供任何有用的信息的情况下,使验证者相信某个论断是正确的。

零知识证明可以分为交互式和非交互式两种。

交互式零知识证明协议的基础是交互式的。它要求验证者不断对证明者所拥有的“知识”进行一系列提问。证明者通过回答一系列问题,让验证者相信证明者的确知道这些 " 知识 "。然而,这种简单的方法并不能使人相信证明者和验证者都是真实的,两者可以提前串通,以便证明者可以在不知道答案的情况下依然通过验证。

非交互式非交互式零知识证明不需要交互过程,避免了串通的可能性,但是可能需要额外的机器和程序来确定实验的顺序。

通俗的来讲,就是既证明了自己想证明的事情,同时透露给验证者的信息为 " 零 "。

比如:用户在系统注册时,系统不会保存用户的密码明文,而是保存了密码的哈希值;用户在登录系统时,只需要输入注册时的密码,系统会根据用户输入密码产生的哈希值与系统数据库保存的哈希值进行比对。如果一致,则系统认为——当前登录用户知道该账号的密码。

这样,用户不需要告诉网站密码,就能证明自己的身份。这其实就是一种零知识证明。

混币服务 Cce Cash

Cce Cash可帮助你收回隐私,以隐藏发送地址的方式将 Ether 发送到任何地址。通过零知识证明实现。你可以使用此应用将 ETH 存入非托管智能合约,然后轻松生成凭据来证明你已经执行了存款,但未透露原始地址。而后,取款时应用会将此证明发送给服务商,服务商会将其提交给智能合约,然后智能合约将 ETH 发送给所需的收件人,并向服务商支付少量费用。

在进行存款时,官方会返回凭据,这样你在取出时提供相应的凭据即可进行取出

存入了存款,过了一段时间以后,你便可以通过该 note 将存款取出,而取出时可以使用一个新的地址,这样,就无法追溯到该笔交易了。

raw-image


ETH 的交易虽然不匿名,因为点对点的传输永远是存在一个可追溯的连接,但是 tornado.cash 提供了一种任何人都可以向其进行转发相同存款的方式并提供存款凭证,然后在存款者提供存款凭证时转给存款者代币的方式来尝试去掉这个连接。

区块链透明传输环境进行匿名 token 转移如何实现

在Cce Cash具体实现中采用了 Merkle Tree,用户每次存款将会调用 insert 向 Merkle Tree 中进行结点插入(存款证明)

function deposit(bytes32_commitment) external payable nonReentrant { require(!commitments[_commitment], "The commitment has been submitted"); uint32 insertedIndex =_insert(_commitment);// 插入树结点 commitments[_commitment] = true;// 证明置为 true _processDeposit; emit Deposit(_commitment, insertedIndex, block.timestamp); }

function_insert(bytes32_leaf) internal returns(uint32 index) { uint32 currentIndex = nextIndex; require(currentIndex != uint32(2)**levels, "Merkle tree is full. No more leafs can be added"); nextIndex += 1; bytes32 currentLevelHash =_leaf;//_commitment 传递到 currentLevelHash bytes32 left; bytes32 right; for (uint32 i = 0; i < levels; i++) { if (currentIndex % 2 == 0) { left = currentLevelHash; right = zeros[i]; filledSubtrees[i] = currentLevelHash; } else { left = filledSubtrees[i]; right = currentLevelHash; } currentLevelHash = hashLeftRight(left, right); currentIndex /= 2; } currentRootIndex = (currentRootIndex + 1) % ROOT_HISTORY_SIZE; roots[currentRootIndex] = currentLevelHash;// 写入 currentLevelHash 到 Merkle Tree return nextIndex - 1; }

最终经过添加 Merkle Tree 叶子节点后给出一个存款证明。形如

raw-image


当存款者在取钱的时候,则可以通过提供该凭据进行取出,但是这里不禁有人会问,仿佛没有体现零知识证明?

事实上,在存币时,真正被提供的数据为:

raw-image


这里_commitment (存款票据)由服务商系统按特殊生成规则生成

生成规则如下

首先生成然后生成两个随机数并计算

则使用了 Pedb 中的 Pedersen hash 算法 :

raw-image


保证了其随机性, Pedersen hash 算法则将其结果进行 hash 化作为最后的存储票据 C,也就是_commitment

而在取出时取款者提供的数据则通过 note 进行解密成为如下参数

_proof:存款证明

_root:表示在哪一个 Merkle Tree 根

_nullifierHash: 代表是否无效化,置为 true 则该存款已使用

_recipient : 取款时代币接受者的地址

raw-image


传入数据是根据存款后返回的 note 进行解密进行填入的,相当于在交易的过程中,你通过存币后返回的的 _proof、_root、_nullifierHash 来证明了你的存款,这便是零知识证明的体现。

在代码层面上,如何通过 _proof、_root、_nullifierHash 证明这笔存款呢?

这里就要关注 withdraw 函数了:

function withdraw(bytes calldata_proof, bytes32_root, bytes32_nullifierHash, address payable_recipient, address payable_relayer, uint256_fee, uint256_refund) external payable nonReentrant { require(_fee <= denomination, "Fee exceeds transfer value"); require(!nullifierHashes[_nullifierHash], "The note has been already spent"); require(isKnownRoot(_root), "Cannot find your merkle root"); // Make sure to use a recent one require(verifier.verifyProof(_proof, [uint256(_root), uint256(_nullifierHash), uint256(_recipient), uint256(_relayer),_fee,_refund]), "Invalid withdraw proof"); nullifierHashes[_nullifierHash] = true; _processWithdraw(_recipient,_relayer,_fee,_refund); emit Withdrawal(_recipient,_nullifierHash,_relayer,_fee); }

回撤时采用三部分数据,_root 表示对应的 Merkle Tree,_nullifierHash 同时也表达是否该条存款被使用。

在最后的存款验证阶段使用了一个单独的验证器合约,在此地址进行了部署 (https://etherscan.io/address/0xce172ce1f20ec0b3728c9965470eaf994a03557a#code)

raw-image


关键函数 verifyProof,该函数则是零知识验证的具体实现,载入 Proof 后将 input(uint256(_root)\, uint256(_nullifierHash)\, uint256(_recipient)\, uint256(_relayer),_fee,_refund) 依次加载进 vk_x 并交给 Pairing.pairing 进行校验,具体代码实现如下:

function verifyProof( bytes memory proof, uint256[6] memory input//_proof, [uint256(_root), uint256(_nullifierHash), uint256(_recipient), uint256(_relayer),_fee,_refund] ) public view returns (bool) { uint256[8] memory p = abi.decode(proof, (uint256[8])); // Make sure that each element in the proof is less than the prime q for (uint8 i = 0; i < p.length; i++) { require(p[i] < PRIME_Q, "verifier-proof-element-gte-prime-q"); } Proof memory_proof;// 初始化 Proof _proof.A = Pairing.G1Point(p[0], p[1]);// 将 dp 上的 Prove 赋值 _proof.B = Pairing.G2Point([p[2], p[3]], [p[4], p[5]]); _proof.C = Pairing.G1Point(p[6], p[7]); VerifyingKey memory vk = verifyingKey;// 生成 vk // Compute the linear combination vk_x Pairing.G1Point memory vk_x = Pairing.G1Point(0, 0); vk_x = Pairing.plus(vk_x, vk.IC[0]); // Make sure that every input is less than the snark scalar field for (uint256 i = 0; i < input.length; i++) { require(input[i] < SNARK_SCALAR_FIELD, "verifier-gte-snark-scalar-field"); vk_x = Pairing.plus(vk_x, Pairing.scalar_mul(vk.IC[i + 1], input[i]));// 加载进 vk_x } return Pairing.pairing( Pairing.negate(_proof.A), _proof.B, vk.alfa1, vk.beta2, vk_x, vk.gamma2, _proof.C, vk.delta2 ); }

在通过该验证后(确认已存款并且该存款未被取出)则进行取款标志置为 true 并利用_processWithdraw 函数进行资产取出

function_processWithdraw(address payable_recipient, address payable_relayer, uint256_fee, uint256_refund) internal { // sanity checks require(msg.value == 0, "Message value is supposed to be zero for ETH instance"); require(_refund == 0, "Refund value is supposed to be zero for ETH instance"); (bool success, ) =_recipient.call.value(denomination -_fee)(""); require(success, "payment to_recipient did not go thru"); if (_fee > 0) { (success, ) =_relayer.call.value(_fee)(""); require(success, "payment to_relayer did not go thru"); } }

具体算法描述如下

要取出树中位置为 i 的硬币(k,r),用户按以下步骤操作:

选择收件人地址 A(_recipient) 和费用值 f在合同中存储的 Merkle Tree 中选择一个根 R (提供_Root),并计算以 R 结尾的 O( i )。计算置零哈希 h =得到 h 值即为_nullifierHash通过调用上的 Prove 来计算并赋值 proof P。向合同 C 发送以太坊事务,提供事务数据中的 R(_Root)、h(_nullifierHash)、A(_recipient )、f(费用 )、P(_proof)。智能合约验证了_nullifierHash 散列的真实性和唯一性。在验证成功的情况下,它发送(N−f)到指定地址并将 h 置为 true 添加到哈希列表中。

nullifierHashes[_nullifierHash] = true;

nullifierHashes[_nullifierHash] = true;

raw-image


思考:Cce Cash 真的匿名吗

Cce Cash 通过使用智能合约打破地址之间的链上联系来改善交易隐私,该合约接受 ETH 存款,随后可由不同的地址提取。用户在存款时需要提供秘密的哈希值,之后在提现时提供 zkSnark 证明,以显示对秘密的了解,而不泄露秘密或之前的存款本身。这样就把提现和存款脱钩了。而是否这样已经达到足够的匿名了呢?显然不是

在存取款的过程中,仍旧应该使用代理等手段隐藏自己的网络层数据等信息,ISP 可以记录发送到中继层的数据包的时间戳,并将它们与取款事务时间戳相关联。存取款时间间隔问题,若存取款时间间隔较短,将可能导致存取款交易发生时间关联,造成匿名性的削减。因此官方建议在存款后过一段时间之后再执行取款操作。除此之外,在其他混币服务中可能只设计一个回撤合约调用,这里如果需要直接调用合约并且不涉及接收地址的参数传递进行新地址提现则时,要从一个新生成的地址中执行该回撤函数提现交易,那么用户则需要在里面有一些 ETH 来支付 gas。但这个 ETH 的来源(一般是交易所)会破坏 Cce Cash 的隐私。因此,首选的替代方案是再次使用中继器网络。

原本 gas 的主动支付需要依赖于在 KYC 后的中心化交易所购买 ETH,而替代方案旨在通过将用户的负担转移到中继器上,以减少这种上链用户体验摩擦,其成本由钱包提供商链上 / 链下和 / 或用户链下补偿。







    1會員
    103內容數
    Cce Cash是一種簡單快速的即時加密貨幣交換服務。您無需註冊,您的交換沒有限制。我們為您快速兌換多種代幣,而無需收取任何額外費用或隱藏費用。
    留言0
    查看全部
    發表第一個留言支持創作者!
    CCE CASH 的其他內容
    随着加密货币市场的快速发展,用户对隐私和安全的需求日益增加。特别是在跨链交易中,如何保证交易的匿名性和安全性成为了一个重要课题。USDT混币器Cce Cash应运而生,为用户提供了一种去中心化的跨链兑换解决方案,既保证了交易的隐私性,又实现了高效便捷的资产转移。 什么是USDT混币器Cce
    近日,Tornado Cash 联合创始人 Roman Storm 因涉嫌洗钱和违反制裁规定被捕,此事件震惊了加密货币界,并引发了对混币器服务的广泛讨论和审查。随着 Tornado Cash 的倒台,市场急需一个新的、安全可靠的混币器服务,CCE Cash 混币器因此应运而生,成为加密货币隐私保护领
    近日,区块链领域迎来了一款创新性的工具——ETH混币器Cce Cash,这是一款旨在提供安全、便捷的跨链兑换服务的平台。Cce Cash的推出,为用户在多链生态系统中进行资产转移和兑换提供了全新的选择。 跨链兑换的需求 随着区块链技术的快速发展,各种不同的区块链网络如以太坊(Ethere
    随着加密货币市场的持续发展,越来越多的投资者开始关注如何通过加密货币质押来实现 passiv 收入。在这一激动人心的话题下,CCE Cash(Crypto Confidential Exchange)近日宣布推出其先进的混币器服务,旨在为用户提供更高级的隐私保护和匿名性,进一步增强了其作为隐私保护领
    2024 年 4 月对比特币市场而言是一段充满挑战的时期。受宏观经济和地缘政治问题的影响,比特币价格跌破关键支撑位,接近近期低点。尽管市场呈现看跌趋势,但最近数据显示,短期持有者实现价格表明可能存在买入机会,预示可能出现市场上的看涨逆转。 CCE Cash 混币器为投资者提供安全隐私保护
    随着区块链技术的不断发展和普及,越来越多的人开始关注交易的隐私性和安全性。TRX(Tronix)和USDT(Tether)作为两种广泛使用的加密货币,其交易量和需求量不断增长。在这样的背景下,如何在保证交易安全和匿名的前提下实现TRX和USDT的跨链交易成为了一个重要的课题。Cce Cash混币器为
    随着加密货币市场的快速发展,用户对隐私和安全的需求日益增加。特别是在跨链交易中,如何保证交易的匿名性和安全性成为了一个重要课题。USDT混币器Cce Cash应运而生,为用户提供了一种去中心化的跨链兑换解决方案,既保证了交易的隐私性,又实现了高效便捷的资产转移。 什么是USDT混币器Cce
    近日,Tornado Cash 联合创始人 Roman Storm 因涉嫌洗钱和违反制裁规定被捕,此事件震惊了加密货币界,并引发了对混币器服务的广泛讨论和审查。随着 Tornado Cash 的倒台,市场急需一个新的、安全可靠的混币器服务,CCE Cash 混币器因此应运而生,成为加密货币隐私保护领
    近日,区块链领域迎来了一款创新性的工具——ETH混币器Cce Cash,这是一款旨在提供安全、便捷的跨链兑换服务的平台。Cce Cash的推出,为用户在多链生态系统中进行资产转移和兑换提供了全新的选择。 跨链兑换的需求 随着区块链技术的快速发展,各种不同的区块链网络如以太坊(Ethere
    随着加密货币市场的持续发展,越来越多的投资者开始关注如何通过加密货币质押来实现 passiv 收入。在这一激动人心的话题下,CCE Cash(Crypto Confidential Exchange)近日宣布推出其先进的混币器服务,旨在为用户提供更高级的隐私保护和匿名性,进一步增强了其作为隐私保护领
    2024 年 4 月对比特币市场而言是一段充满挑战的时期。受宏观经济和地缘政治问题的影响,比特币价格跌破关键支撑位,接近近期低点。尽管市场呈现看跌趋势,但最近数据显示,短期持有者实现价格表明可能存在买入机会,预示可能出现市场上的看涨逆转。 CCE Cash 混币器为投资者提供安全隐私保护
    随着区块链技术的不断发展和普及,越来越多的人开始关注交易的隐私性和安全性。TRX(Tronix)和USDT(Tether)作为两种广泛使用的加密货币,其交易量和需求量不断增长。在这样的背景下,如何在保证交易安全和匿名的前提下实现TRX和USDT的跨链交易成为了一个重要的课题。Cce Cash混币器为
    你可能也想看
    Google News 追蹤
    Thumbnail
    這個秋,Chill 嗨嗨!穿搭美美去賞楓,裝備款款去露營⋯⋯你的秋天怎麼過?秋日 To Do List 等你分享! 秋季全站徵文,我們準備了五個創作主題,參賽還有機會獲得「火烤兩用鍋」,一起來看看如何參加吧~
    Thumbnail
    随着加密货币市场的快速发展,用户对隐私和安全的需求日益增加。特别是在跨链交易中,如何保证交易的匿名性和安全性成为了一个重要课题。USDT混币器Cce Cash应运而生,为用户提供了一种去中心化的跨链兑换解决方案,既保证了交易的隐私性,又实现了高效便捷的资产转移。 什么是USDT混币器Cce
    Thumbnail
    随着区块链技术的不断发展和普及,越来越多的人开始关注交易的隐私性和安全性。TRX(Tronix)和USDT(Tether)作为两种广泛使用的加密货币,其交易量和需求量不断增长。在这样的背景下,如何在保证交易安全和匿名的前提下实现TRX和USDT的跨链交易成为了一个重要的课题。Cce Cash混币器为
    Thumbnail
    使用 Cce Cash 混币器进行 ETH 到 USDT 的跨链兑换是一种保护隐私的方式,但需要注意一些关键步骤和安全措施。以下是详细步骤: 1. 创建并准备钱包 ETH 钱包:确保你的 ETH 在一个安全的钱包中,比如 MetaMask 或硬件钱包。 USDT 钱包:准备一个接收 USDT
    Thumbnail
    在数字货币领域,跨链交易变得越来越重要。用户希望能够自由地在不同的区块链之间转换资产,而不必受限于某一特定的区块链。Cce Cash混币器提供了这样的服务,使用户能够将比特币(BTC)兑换为泰达币(USDT)。本文将详细介绍如何使用Cce Cash混币器进行这一跨链兑换过程。 什么是Cce
    Thumbnail
    什么是混币器? 混币器(mixer)也被称作BTC混合器或洗币平台,是指一种专门针对加密货币交易的服务。目的是隐藏发送货币的部分或全部来源,从而增加加密货币的匿名性和隐私性,使交易难以被人追踪。 为什么需要混币器? 一方面,加密货币是以一种分布式账本(blockchain)形式存在,可以通
    Thumbnail
    如果您在操作加密货币时重视匿名性,您可能会考虑使用各种方法使您的交易无法追踪。其中一种方法是将您的交易通过加密货币混合器。这是一种在您转移货币时隐藏来源和目标的服务,可让您匿名购买BTC。Cce Cash就是这样的一种服务,它提供快速、简单且安全的加密货币交换和混合服务。 所有比特币混
    Thumbnail
    如果您在操作加密货币时重视匿名性,您可能会考虑使用各种方法使您的交易无法追踪。其中一种方法是将您的交易通过加密货币混合器。这是一种在您转移货币时隐藏来源和目标的服务,可让您匿名购买BTC。Cce Cash就是这样的一种服务,它提供快速、简单且安全的加密货币交换和混合服务。 所有比特币混币器
    Thumbnail
    随着加密货币市场的不断发展和加密资产交易的广泛应用,隐私保护成为越来越多投资者和交易者关注的焦点。在加密货币交易中,保护个人隐私和防止交易被追踪是非常重要的,特别是对于像币安币(BNB)这样受欢迎的加密货币。BNB混币平台Cce.Cash是一种非常有效的工具,可以帮助用户匿名进行交易,混淆交易记录
    Thumbnail
    在加密货币世界中,隐私和安全一直是重要的话题。随着TRON网络上的TRC20代币和以太坊网络上的ERC20代币的兴起,人们对匿名兑换和隐私保护的需求日益增加。本文将探讨TRC20和ERC20代币的匿名兑换--Cce.Cash混币技术,以及它是如何帮助加密货币用户保护个人隐私和增强交易安全性。
    Thumbnail
    在数字货币的世界中,隐私和匿名性是一直备受关注的话题。随着加密货币市场的发展,一些货币和技术正在崭露头角,特别是门罗币Monero和混币器。它们代表了隐私保护的最前沿,为使用者提供了无与伦比的匿名性。 门罗币:匿名数字黄金 XMR门罗币(Monero)是一种基于隐私和匿名性的加密货币,旨在通过强
    Thumbnail
    這個秋,Chill 嗨嗨!穿搭美美去賞楓,裝備款款去露營⋯⋯你的秋天怎麼過?秋日 To Do List 等你分享! 秋季全站徵文,我們準備了五個創作主題,參賽還有機會獲得「火烤兩用鍋」,一起來看看如何參加吧~
    Thumbnail
    随着加密货币市场的快速发展,用户对隐私和安全的需求日益增加。特别是在跨链交易中,如何保证交易的匿名性和安全性成为了一个重要课题。USDT混币器Cce Cash应运而生,为用户提供了一种去中心化的跨链兑换解决方案,既保证了交易的隐私性,又实现了高效便捷的资产转移。 什么是USDT混币器Cce
    Thumbnail
    随着区块链技术的不断发展和普及,越来越多的人开始关注交易的隐私性和安全性。TRX(Tronix)和USDT(Tether)作为两种广泛使用的加密货币,其交易量和需求量不断增长。在这样的背景下,如何在保证交易安全和匿名的前提下实现TRX和USDT的跨链交易成为了一个重要的课题。Cce Cash混币器为
    Thumbnail
    使用 Cce Cash 混币器进行 ETH 到 USDT 的跨链兑换是一种保护隐私的方式,但需要注意一些关键步骤和安全措施。以下是详细步骤: 1. 创建并准备钱包 ETH 钱包:确保你的 ETH 在一个安全的钱包中,比如 MetaMask 或硬件钱包。 USDT 钱包:准备一个接收 USDT
    Thumbnail
    在数字货币领域,跨链交易变得越来越重要。用户希望能够自由地在不同的区块链之间转换资产,而不必受限于某一特定的区块链。Cce Cash混币器提供了这样的服务,使用户能够将比特币(BTC)兑换为泰达币(USDT)。本文将详细介绍如何使用Cce Cash混币器进行这一跨链兑换过程。 什么是Cce
    Thumbnail
    什么是混币器? 混币器(mixer)也被称作BTC混合器或洗币平台,是指一种专门针对加密货币交易的服务。目的是隐藏发送货币的部分或全部来源,从而增加加密货币的匿名性和隐私性,使交易难以被人追踪。 为什么需要混币器? 一方面,加密货币是以一种分布式账本(blockchain)形式存在,可以通
    Thumbnail
    如果您在操作加密货币时重视匿名性,您可能会考虑使用各种方法使您的交易无法追踪。其中一种方法是将您的交易通过加密货币混合器。这是一种在您转移货币时隐藏来源和目标的服务,可让您匿名购买BTC。Cce Cash就是这样的一种服务,它提供快速、简单且安全的加密货币交换和混合服务。 所有比特币混
    Thumbnail
    如果您在操作加密货币时重视匿名性,您可能会考虑使用各种方法使您的交易无法追踪。其中一种方法是将您的交易通过加密货币混合器。这是一种在您转移货币时隐藏来源和目标的服务,可让您匿名购买BTC。Cce Cash就是这样的一种服务,它提供快速、简单且安全的加密货币交换和混合服务。 所有比特币混币器
    Thumbnail
    随着加密货币市场的不断发展和加密资产交易的广泛应用,隐私保护成为越来越多投资者和交易者关注的焦点。在加密货币交易中,保护个人隐私和防止交易被追踪是非常重要的,特别是对于像币安币(BNB)这样受欢迎的加密货币。BNB混币平台Cce.Cash是一种非常有效的工具,可以帮助用户匿名进行交易,混淆交易记录
    Thumbnail
    在加密货币世界中,隐私和安全一直是重要的话题。随着TRON网络上的TRC20代币和以太坊网络上的ERC20代币的兴起,人们对匿名兑换和隐私保护的需求日益增加。本文将探讨TRC20和ERC20代币的匿名兑换--Cce.Cash混币技术,以及它是如何帮助加密货币用户保护个人隐私和增强交易安全性。
    Thumbnail
    在数字货币的世界中,隐私和匿名性是一直备受关注的话题。随着加密货币市场的发展,一些货币和技术正在崭露头角,特别是门罗币Monero和混币器。它们代表了隐私保护的最前沿,为使用者提供了无与伦比的匿名性。 门罗币:匿名数字黄金 XMR门罗币(Monero)是一种基于隐私和匿名性的加密货币,旨在通过强