以太坊智能合约开发:Solidity语言中的哈希(hash)函数

在Solidity语言中,用于加密的哈希函数是一种算法,它将任意大小的数据作为输入,并生成固定大小(32个字节)的加密文本。即使输入的微小变化也会产生完全不同的输出。

加密函数

Solidity提供以下几种加密函数:

函数 特性
keccak256(bytes memory) returns (bytes32) 计算输入的kecak -256哈希值
sha256(bytes memory) returns (bytes32) 计算输入的SHA-256哈希值
ripemd160(bytes memory) returns (bytes20) 计算输入的RIPEMD-160哈希值
ecrecover(bytes32 hash, uint8 v, bytes32 r, bytes32 s) returns (address) 利用椭圆曲线签名算法恢复与公钥相关联的地址,出错时返回零。函数参数对应 ECDSA 签名的值。

以太坊使用keccak进行哈希计算,这与SHA_256类似但不相同。

合约示例

在下面的示例中,创建了一个智能合约,以一个字符串作为输入,并输出一个32字节的哈希值。

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.13;

contract KeccakTest {
    // 生成hash值的函数
    function generateHash(string memory str) public pure returns(bytes32) {
        bytes32 hash = keccak256(abi.encodePacked(str));
        return hash;
    }
}

**输出:**我们把上面这个合约示例在Remix环境中编译、部署和运行,输出结果如下图:

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/zyq55917/article/details/125704259