以太坊智能合约开发: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环境中编译、部署和运行,输出结果如下图:

在这里插入图片描述

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

StevenX5

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值