在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 retu