密码学入门:区块链中的密码学原理

密码学入门:区块链中的密码学原理

大家好,我是欧阳瑞(Rich Own)。今天想和大家聊聊密码学这个重要话题。作为一个Web3探索者,密码学是区块链的基础。今天就来分享一下区块链中常用的密码学原理。

为什么密码学很重要?

场景 说明
身份认证 验证用户身份
数据加密 保护敏感数据
数字签名 验证数据完整性
零知识证明 无需泄露信息证明

哈希函数

什么是哈希函数?

哈希函数将任意长度的数据转换为固定长度的哈希值。

特性

特性 说明
确定性 相同输入产生相同输出
单向性 无法从哈希值还原输入
抗碰撞 难以找到两个不同输入产生相同哈希

常用哈希函数

python 复制代码
import hashlib

# SHA-256
hash = hashlib.sha256(b"Hello World").hexdigest()
print(hash)

# Keccak-256 (以太坊使用)
from Crypto.Hash import keccak
k = keccak.new(digest_bits=256)
k.update(b"Hello World")
print(k.hexdigest())

数字签名

ECDSA签名

python 复制代码
from ecdsa import SigningKey, VerifyingKey, NIST256p

# 生成密钥对
sk = SigningKey.generate(curve=NIST256p)
vk = sk.get_verifying_key()

# 签名
message = b"Hello World"
signature = sk.sign(message)

# 验证
assert vk.verify(signature, message)

EdDSA签名

python 复制代码
from cryptography.hazmat.primitives.asymmetric.ed25519 import Ed25519PrivateKey

# 生成密钥对
private_key = Ed25519PrivateKey.generate()
public_key = private_key.public_key()

# 签名
message = b"Hello World"
signature = private_key.sign(message)

# 验证
public_key.verify(signature, message)

非对称加密

python 复制代码
from cryptography.hazmat.primitives.asymmetric import rsa, padding
from cryptography.hazmat.primitives import serialization, hashes

# 生成密钥对
private_key = rsa.generate_private_key(public_exponent=65537, key_size=2048)
public_key = private_key.public_key()

# 加密
message = b"Secret message"
ciphertext = public_key.encrypt(
    message,
    padding.OAEP(
        mgf=padding.MGF1(algorithm=hashes.SHA256()),
        algorithm=hashes.SHA256(),
        label=None
    )
)

# 解密
plaintext = private_key.decrypt(
    ciphertext,
    padding.OAEP(
        mgf=padding.MGF1(algorithm=hashes.SHA256()),
        algorithm=hashes.SHA256(),
        label=None
    )
)

零知识证明

zk-SNARKs

python 复制代码
# 简化示例
class ZKProof:
    def __init__(self, secret):
        self.secret = secret
    
    def prove(self):
        # 生成证明
        commitment = hash(self.secret)
        challenge = hash(commitment)
        response = self.secret + challenge
        return (commitment, response)
    
    def verify(commitment, response):
        challenge = hash(commitment)
        return hash(response - challenge) == commitment

实战案例:区块链交易签名

python 复制代码
from ecdsa import SigningKey, NIST256p
import hashlib

class Transaction:
    def __init__(self, sender, receiver, amount):
        self.sender = sender
        self.receiver = receiver
        self.amount = amount
    
    def sign(self, private_key):
        data = f"{self.sender}{self.receiver}{self.amount}"
        hash_data = hashlib.sha256(data.encode()).digest()
        return private_key.sign(hash_data)
    
    def verify_signature(self, public_key, signature):
        data = f"{self.sender}{self.receiver}{self.amount}"
        hash_data = hashlib.sha256(data.encode()).digest()
        return public_key.verify(signature, hash_data)

总结

密码学是区块链的基石。从哈希函数到零知识证明,密码学保证了区块链的安全性和可靠性。

我的鬃狮蜥Hash对密码学也有自己的理解------它总是用独特的方式标记自己的领地,这也许就是自然界的"数字签名"吧!

如果你对密码学感兴趣,欢迎留言交流!我是欧阳瑞,极客之路,永无止境!


技术栈:密码学 · 哈希函数 · 数字签名 · 区块链

相关推荐
m0_380167146 小时前
面向开发者的Top10加密货币数据API(2026年最新)
大数据·人工智能·区块链
2601_9594801510 小时前
Moneta Markets亿汇:“比特币高位修复风险偏好”
区块链
m0_380167141 天前
加密货币价格 API、市场数据 API 与 分析 API 有什么区别?
人工智能·ai·区块链
LedgerNinja1 天前
AEGET:提升决策效率,助力交易者建立清晰的交易体系
区块链
2601_961963381 天前
Spring Boot集成电子签章的7个典型问题与解决方案:从入门到生产级实践
大数据·人工智能·spring boot·python·区块链·智能合约
zhuhai_xigedian1 天前
物联网技术在源网荷储系统中的创新应用
大数据·运维·人工智能·区块链·能源
2601_959480151 天前
Moneta Markets亿汇:“比特币长期预期继续升温”
区块链
2601_961963381 天前
数据室里的“第一道锁”:电子保密协议(NDA)签署与防泄漏机制全解析
网络·人工智能·安全·金融·区块链·政务
HavenlonLabs2 天前
重塑链上未来的隐形基石:长期主义下的生态演进
大数据·人工智能·安全·区块链
尽兴-2 天前
4.1 智能体核心:Agent、Sub-Agent、ReAct、规划执行
前端·javascript·react.js·agent·react·subagent