在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环境中编译、部署和运行,输出结果如下图:
|