Solidity的Function Modifiers(P.S. 0.4.17版本)

开门见山


1. modifiers后面定义的是带有条件的一种状态

先做一个提示代码示例中有throw之类都是老版本的智能合约文章,需要使用require代替


2. 用的时候写在符合要求就需要执行的代码集前面,如果不满住后面(这个后面基本上是这个function的域)的程序将不会被执行


解释与说明,官话带感

Modifiers可以被用来轻松的改变函数的行为。

举一个例子,我们可以自动检查(合约自己检查)一个优先条件来执行程序。

Modifiers是可以被继承的合约属性,同时可以被派生合约重写(overridden)。


pragma solidity ^0.4.11;

contract owned {
    function owned() { owner = msg.sender; }
    address owner;

    modifier onlyOwner {
        require(msg.sender == owner);
        _;
    }
}


contract mortal is owned {
    function close() onlyOwner {
        selfdestruct(owner);
    }
}


contract priced {
    modifier costs(uint price) {
        if (msg.value >= price) {
            _;
        }
    }
}


contract Register is priced, owned {
    mapping (address => bool) registeredAddresses;
    uint price;

    function Register(uint initialPrice) { price = initialPrice; }

    function register() payable costs(price) {
        registeredAddresses[msg.sender] = true;
    }

    function changePrice(uint _price) onlyOwner {
        price = _price;
    }
}

contract Mutex {
    bool locked;
    modifier noReentrancy() {
        require(!locked);
        locked = true;
        _;
        locked = false;
    }

    function f() noReentrancy returns (uint) {
        require(msg.sender.call());
        return 7;
    }
}

如果同一个函数有多个修改器,他们之间以空格隔开,修饰器会依次检查执行。

需要注意的是,在Solidity的早期版本中,有修改器的函数,它的return语句的行为有些不同。


在修改器中和函数体内的显式的return语句,仅仅跳出当前的修改器和函数体。返回的变量会被赋值,但整个执行逻辑会在前一个修改器后面定义的"_"后继续执行。

修改器的参数可以是任意表达式。在对应的上下文中,所有的函数中引入的符号,在修改器中均可见。但修改器中引入的符号在函数中不可见,因为它们有可能被重写。



  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用 Solidity 和 Web3.js 实现登录、注册和权限管理的示例代码: Solidity 代码: ``` pragma solidity ^0.8.0; contract Auth { mapping(address => bool) public isAdmin; mapping(address => bool) public isUser; mapping(address => string) public username; mapping(string => address) public usernameToAddress; event NewAdmin(address admin); event NewUser(address user, string username); constructor() { isAdmin[msg.sender] = true; emit NewAdmin(msg.sender); } function register(string memory _username) public { require(usernameToAddress[_username] == address(0), "Username already exists"); require(!isUser[msg.sender], "Already registered"); isUser[msg.sender] = true; username[msg.sender] = _username; usernameToAddress[_username] = msg.sender; emit NewUser(msg.sender, _username); } function grantAdmin(address _admin) public { require(isAdmin[msg.sender], "Not authorized"); isAdmin[_admin] = true; emit NewAdmin(_admin); } function revokeAdmin(address _admin) public { require(isAdmin[msg.sender], "Not authorized"); isAdmin[_admin] = false; } } ``` 该合约维护了三个映射表: - `isAdmin`:存储管理员地址和其是否为管理员的状态。 - `isUser`:存储用户地址和其是否为用户的状态。 - `username`:存储用户地址和其用户名的映射关系。 合约提供了以下功能: - `constructor`:在合约部署时将合约创建者设为管理员。 - `register`:用户注册函数,将用户地址和用户名存储到映射表中。 - `grantAdmin`:授予管理员权限函数,只有管理员可以调用该函数。 - `revokeAdmin`:撤销管理员权限函数,只有管理员可以调用该函数。 Web3.js 代码: ``` const Web3 = require('web3'); const contractABI = require('path/to/contract-abi.json'); const web3 = new Web3('http://localhost:8545'); const contractAddress = '0x123456789abcdef'; const contractInstance = new web3.eth.Contract(contractABI, contractAddress); async function register(username) { const accounts = await web3.eth.getAccounts(); await contractInstance.methods.register(username).send({ from: accounts[0] }); } async function grantAdmin(address) { const accounts = await web3.eth.getAccounts(); await contractInstance.methods.grantAdmin(address).send({ from: accounts[0] }); } async function revokeAdmin(address) { const accounts = await web3.eth.getAccounts(); await contractInstance.methods.revokeAdmin(address).send({ from: accounts[0] }); } async function getUsername(address) { return await contractInstance.methods.username(address).call(); } async function getAddress(username) { return await contractInstance.methods.usernameToAddress(username).call(); } module.exports = { register, grantAdmin, revokeAdmin, getUsername, getAddress }; ``` 该代码包括以下功能: - `register`:调用合约的 `register` 函数,将用户名注册到合约中。 - `grantAdmin`:授权管理员权限。 - `revokeAdmin`:撤销管理员权限。 - `getUsername`:根据地址获取用户名。 - `getAddress`:根据用户名获取地址。 这些函数可以用于网站的登录和注册功能,以及管理员权限管理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值