您当前的位置: 首页 >  以太坊

StevenX5

暂无认证

  • 14浏览

    0关注

    22博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

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

StevenX5 发布时间:2022-07-10 12:12:57 ,浏览量:14

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

在这里插入图片描述

关注
打赏
1651313693
查看更多评论
立即登录/注册

微信扫码登录

0.0997s