首页 > 其他分享 > Solidity极简入门#11. 构造函数和修饰器

Solidity极简入门#11. 构造函数和修饰器

时间:2023-02-09 22:32:42浏览次数:61  
标签:11 极简 函数 onlyOwner solidity owner 合约 构造函数

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

构造函数

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

address owner; // 定义owner变量

// 构造函数
constructor() {
owner = msg.sender; // 在部署合约的时候,将owner设置为部署者的地址
}

注意⚠️:构造函数在不同的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可以调用,别人调用就会报错。这也是最常用的控制智能合约权限的方法。

OppenZepplin的Ownable标准实现:

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

Remix 演示示例

以 Owner.sol 为例。

  1. 在 Remix 上编译部署代码。
  2. 点击owner按钮查看当前 owner 变量。
  3. 以 owner 地址的用户身份,调用changeOwner函数,交易成功。
  4. 以非 owner 地址的用户身份,调用changeOwner函数,交易失败,因为modifier onlyOwner 的检查语句不满足。

总结

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

标签:11,极简,函数,onlyOwner,solidity,owner,合约,构造函数
From: https://blog.51cto.com/sleep666/6047348

相关文章

  • 问题解决:由于找不到msvcr110.dll,无法继续执行代码
    报错解决下载地址:https://www.microsoft.com/zh-cn/download/details.aspx?id=30679......
  • Educational Codeforces Round 118 (Rated for Div. 2)(D,E)
    EducationalCodeforcesRound118(RatedforDiv.2)(D,E)DD这个题大意给我们一个长度为\(n\)的序列,然后我们需要知道有多少个满足一下条件的子序列对于这一个序列,长度......
  • [CF1190C] Tokitsukaze and Duel
    题目描述"Duel!"BettingonthelovelyprincessClaris,theduelbetweenTokitsukazeandQuailtyhasstarted.Thereare$n$cardsinarow.Eachcardhastwo......
  • C++11新特性
    C++语法movesemantics(移动语义)参考资料:这个网站的大部分资料对初学者都极其友好stanfordCS106Lmovesemanticshttps://www.youtube.com/watch?v=St0MNEU5b0o&......
  • js构造函数详解
    1.构造函数介绍构造函数是专门用来生成对象的函数,它提供模板,描述对象的基本结构。一个构造函数,可以生成多个对象,这些对象都有相同的结构。构造函数的写法就是一个普通的函......
  • loj2511
    引言思维题。这个做法跑得飞快,还不用dp,也不是爆搜!复杂度(可能)为\(O(s^2t)\)或\(O(s^2)\),实际效率也是飞快。不过这题我直接提交答案了。思路考虑\(A=mn,B=m+n\)......
  • [dp 记录] CF1152F2 Sonya and Informatics
    trick:从值域考虑。好题。但是感觉和CF1151F差不多难。两题都是*3000但是一紫一黑。题意:对长度为\(k\),值域\(n\)的序列计数:\(a_i\leqa_{i-1}+m\)\(\fora......
  • 各地级市数字普惠金融指数数据(2011-2022)
    ​各地级市数字普惠金融指数数据(2011-2022)各地级市数字普惠金融指数数据(2011-2022)各地级市数字普惠金融指数数据(2011-2022) 最新版数据已整理为Excel格式,数据的时间区间为20......
  • 【代码源 Div1 - 107】#452. 序列操作(思维)CF1198B
    problemsolution注意到操作2是全局的,而且所有操作是离线的,所以可以记录操作2修改后的最大值,再开个vis数组记录当前的数是否被操作1修改过,然后反向暴力一遍。#include<......
  • 11 方法重写
    方法重写packagecom.zhan.base05Oop.base05Oop03;publicclassTest11{//方法重写//重写都是方法的重写,和属性无关//alt+insert(Fn):快捷键生成......