มาสร้าง Blockchain ของเราเองกันเถอะ ( 2 ) , Mining

Mining ( ขุด ) คือกระบวนการสร้าง block. ใหม่ แล้วเพิ่มเข้าไปใน blockchain
มีขั้นตอนการทำงานดังต่อไปนี้
const nonce = bitcoin.proofOfWork(previousBlockHash, currentBlockData);
const blockHash = bitcoin.hashBlock(previousBlockHash, currentBlockData, nonce);
const newBlock = bitcoin.createNewBlock(nonce, previousBlockHash, blockHash);
เรามาดู code ของ function เหล่านี้กันดีกว่า
Blockchain.prototype.createNewBlock = function(nonce, previousBlockHash, hash) {
const newBlock = {
index: this.chain.length + 1,
timestamp: Date.now(),
transactions: this.pendingTransactions,
nonce: nonce,
hash: hash,
previousBlockHash: previousBlockHash
};
this.pendingTransactions = [];
this.chain.push(newBlock);
return newBlock;
};
Blockchain.prototype.hashBlock = function(previousBlockHash, currentBlockData, nonce) {
const dataAsString = previousBlockHash + nonce.toString() + JSON.stringify(currentBlockData);
const hash = sha256(dataAsString);
return hash;
};
Blockchain.prototype.proofOfWork = function(previousBlockHash, currentBlockData) {
let nonce = 0;
let hash = this.hashBlock(previousBlockHash, currentBlockData, nonce);
while (hash.substring(0, 4) !== '0000') {
nonce++;
hash = this.hashBlock(previousBlockHash, currentBlockData, nonce);
}
return nonce;
};
เราควรจะเริ่มดูที่ hashBlock function ซึ่งถูกเรียกใช้บ่อย function นี้ไม่มีอะไรซับซ้อนมาก แค่ทำการ hash ค่าของ previousBlockHash + nonce + currentBlockData ด้วย sha256
proofOfWork function คือการหา hash ที่ขึ้นต้นด้วย 0000 ให้เจอ เราจะเห็นว่า nonce คือตัวแปรที่เพิ่มค่าไปเรื่อยๆ ใน while loop เมื่อเราเจอ nonce ที่ถูกต้องแล้ว function ก็จะ return
const nonce = bitcoin.proofOfWork(previousBlockHash, currentBlockData);
const blockHash = bitcoin.hashBlock(previousBlockHash, currentBlockData, nonce);
const newBlock = bitcoin.createNewBlock(nonce, previousBlockHash, blockHash);
กลับมาดู code ที่พูดในตอนแรกจะเห็นได้ว่า createNewBlock เพียงแค่รับ parameter ที่ได้จาก output ของ proofOfWork และ hashBlock
Articles
- วิธีฝึก YOLO ด้วยชุดข้อมูลที่กำหนดเอง: คำแนะนำทีละขั้นตอน
- カスタムデータセットでYOLOをトレーニングする方法:ステップバイステップガイド
- Training YOLO with a Custom Dataset: A Step-by-Step Guide
- WazuhとAIの統合による高度な脅威検出
- การผสานรวม AI กับ Wazuh เพื่อการตรวจจับภัยคุกคามขั้นสูง
- Integrating AI with Wazuh for Advanced Threat Detection
- AIはどのようにして偽造された高級品を検出するのか?
- AI ช่วยตรวจจับสินค้าหรูปลอมได้อย่างไร?
- How AI Helps in Detecting Counterfeit Luxury Products
- The Cold Start Problem の概念を活用して eCommerce ビジネスを成長させる方法
- 🚀วิธีนำแนวคิดจาก The Cold Start Problem มาใช้เพื่อขยายธุรกิจ eCommerce ของคุณ
- 🚀 How to Apply The Cold Start Problem Concepts to Grow Your eCommerce Business
- YOLOの理解: 仕組みとサンプルコード
- การทำความเข้าใจ YOLO: วิธีการทำงานและตัวอย่างโค้ด
- Understanding YOLO: How It Works & Sample Code
- PythonでAIを活用した広告最適化システムを構築する方法
- วิธีสร้างระบบเพิ่มประสิทธิภาพโฆษณาด้วย AI ใน Python
- How to Build an AI-Powered Ad Optimization System in Python
- SMEがオープンソースAIモデルを活用してビジネスを拡大する方法
- วิธีที่ SMEs สามารถใช้โมเดล AI โอเพ่นซอร์สเพื่อขยายธุรกิจของตน
Our Products
Articles
- วิธีฝึก YOLO ด้วยชุดข้อมูลที่กำหนดเอง: คำแนะนำทีละขั้นตอน
- カスタムデータセットでYOLOをトレーニングする方法:ステップバイステップガイド
- Training YOLO with a Custom Dataset: A Step-by-Step Guide
- WazuhとAIの統合による高度な脅威検出
- การผสานรวม AI กับ Wazuh เพื่อการตรวจจับภัยคุกคามขั้นสูง
- Integrating AI with Wazuh for Advanced Threat Detection
- AIはどのようにして偽造された高級品を検出するのか?
- AI ช่วยตรวจจับสินค้าหรูปลอมได้อย่างไร?
- How AI Helps in Detecting Counterfeit Luxury Products
- The Cold Start Problem の概念を活用して eCommerce ビジネスを成長させる方法
- 🚀วิธีนำแนวคิดจาก The Cold Start Problem มาใช้เพื่อขยายธุรกิจ eCommerce ของคุณ
- 🚀 How to Apply The Cold Start Problem Concepts to Grow Your eCommerce Business
- YOLOの理解: 仕組みとサンプルコード
- การทำความเข้าใจ YOLO: วิธีการทำงานและตัวอย่างโค้ด
- Understanding YOLO: How It Works & Sample Code
- PythonでAIを活用した広告最適化システムを構築する方法
- วิธีสร้างระบบเพิ่มประสิทธิภาพโฆษณาด้วย AI ใน Python
- How to Build an AI-Powered Ad Optimization System in Python
- SMEがオープンソースAIモデルを活用してビジネスを拡大する方法
- วิธีที่ SMEs สามารถใช้โมเดล AI โอเพ่นซอร์สเพื่อขยายธุรกิจของตน