当前位置: 首页 > article >正文

Solidity09 Solidity构造函数和修饰器

文章目录

  • 一、构造函数
  • 二、修饰器
  • 三、OpenZeppelin的Ownable标准实现
  • 四、Remix 演示示例
  • 五、代码示例

这一讲,我们将用合约权限控制( Ownable)的例子介绍 Solidity语言中构造函数( constructor)和独有的修饰器( modifier)。

一、构造函数

构造函数(constructor)是一种特殊的函数,每个合约可以定义一个,并在部署合约的时候自动运行一次。它可以用来初始化合约的一些参数,例如初始化合约的owner地址:

address owner; // 定义owner变量

// 构造函数
constructor(address initialOwner) {
    owner = initialOwner; // 在部署合约的时候,将owner设置为传入的initialOwner地址
}

注意:构造函数在不同的Solidity版本中的语法并不一致,在Solidity 0.4.22之前,构造函数不使用 constructor 而是使用与合约名同名的函数作为构造函数而使用,由于这种旧写法容易使开发者在书写时发生疏漏(例如合约名叫 Parents,构造函数名写成 parents),使得构造函数变成普通函数,引发漏洞,所以0.4.22版本及之后,采用了全新的 constructor 写法。

构造函数的旧写法代码示例:

pragma solidity =0.4.21;
contract Parents {
    // 与合约名Parents同名的函数就是构造函数
    function Parents () public {
    }
}

二、修饰器

修饰器(modifier)是Solidity特有的语法,类似于面向对象编程中的装饰器(decorator),声明函数拥有的特性,并减少代码冗余。它就像钢铁侠的智能盔甲,穿上它的函数会带有某些特定的行为。modifier的主要使用场景是运行函数前的检查,例如地址,变量,余额等。

我们来定义一个叫做onlyOwner的modifier:

// 定义modifier
modifier onlyOwner {
   require(msg.sender == owner); // 检查调用者是否为owner地址
   _; // 如果是的话,继续运行函数主体;否则报错并revert交易
}

带有onlyOwner修饰符的函数只能被owner地址调用,比如下面这个例子:

function changeOwner(address _newOwner) external onlyOwner{
   owner = _newOwner; // 只有owner地址运行这个函数,并改变owner
}

我们定义了一个changeOwner函数,运行它可以改变合约的owner,但是由于onlyOwner修饰符的存在,只有原先的owner可以调用,别人调用就会报错。这也是最常用的控制智能合约权限的方法。

三、OpenZeppelin的Ownable标准实现

OpenZeppelin是一个维护Solidity标准化代码库的组织,他的Ownable标准实现如下: https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/access/Ownable.sol

四、Remix 演示示例

Owner.sol 为例。

  1. 在 Remix 上编译并部署代码,在合约部署时传入 initialOwner 变量。

在这里插入图片描述

  1. 点击 owner 按钮查看当前 owner 变量。
    在这里插入图片描述

  2. 以 owner 地址的用户身份,调用 changeOwner 函数,交易成功。

在这里插入图片描述

  1. 以非 owner 地址的用户身份,调用 changeOwner 函数,交易失败,因为modifier onlyOwner 的检查语句不满足。

在这里插入图片描述

五、代码示例

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

contract Owner {
   address public owner; // 定义owner变量

   // 构造函数
   constructor(address initialOwner) {
      owner = initialOwner; // 在部署合约的时候,将owner设置为传入的initialOwner地址
   }

   // 定义modifier
   modifier onlyOwner {
      require(msg.sender == owner); // 检查调用者是否为owner地址
      _; // 如果是的话,继续运行函数主体;否则报错并revert交易
   }

   // 定义一个带onlyOwner修饰符的函数
   function changeOwner(address _newOwner) external onlyOwner{
      owner = _newOwner; // 只有owner地址运行这个函数,并改变owner
   }
}

这一讲,我们介绍了Solidity中的构造函数和修饰符,并写了一个控制合约权限的Ownable合约。


http://www.kler.cn/a/541169.html

相关文章:

  • Visual Studio Code (VSCode) 的基本设置指南,帮助你优化开发环境
  • [2025年最新]2024.3版本idea无法安装插件问题解决
  • 性能优化中的系统架构优化
  • 手写一个C++ Android Binder服务及源码分析
  • 防火墙术语大全( Firewalld Glossary of Terms)
  • C++ decltype 规则推导
  • Kickstart自动化安装过程中自动选择较小的磁盘安装操作系统
  • Kafka 的消费offset原来是使用ZK管理,现在新版本是怎么管理的?
  • STM32调试工具OLED
  • 从家庭IP到全球网络资源的无缝连接:Cliproxy的专业解决方案
  • 【苍穹外卖】修改前端代码解决修改Nginx端口后websocket连接失败的问题
  • [网络]url解码,从网址转化为ip
  • 线程池里面的execute 和 submit 方法有什么区别?
  • Docker 部署 MongoDB | 国内阿里镜像
  • 汽车与AI深度融合:CES Asia 2025前瞻
  • 问卷数据分析|SPSS实操之信度效度检验
  • 老游戏回顾:TR9
  • Spring Boot 项目中使用腾讯云对象存储(COS)
  • 20爬虫:使用playwright与图鉴破解豆瓣滑动验证码
  • 软考高级《系统架构设计师》知识点(一)
  • Vue 响应式渲染 - Vue3 Class和style
  • Flink 内存模型各部分大小计算公式
  • 金砖国家技能大赛云计算赛项(容器云部分题解)
  • uniapp使用路由名称跳转
  • 分享升级spotbugs-maven-plugin 4.8.6.0遇到的坑(内附稳定运行的jdk和maven版本)
  • excel高级求和SUMIFS函数,类似数据库group by操作