Solidity 合约权限控制模板

文章目录

  • 前言
    • [Solidity 合约权限控制模板](#Solidity 合约权限控制模板)
      • [1. 作用](#1. 作用)
      • [2. demo](#2. demo)
      • [3. 测试](#3. 测试)

前言

如果您觉得有用的话,记得给博主点个赞,评论,收藏一键三连啊,写作不易啊^ _ ^。

而且听说点赞的人每天的运气都不会太差,实在白嫖的话,那欢迎常来啊!!!


Solidity 合约权限控制模板

1. 作用

保证有些函数任何人都可以调用,而有些函数只有owner可以调用。

2. demo

bash 复制代码
// SPDX-License-Identifier: MIT
pragma solidity 0.8.7;


/**
* @title Ownable
* @author 自定义作者名(可修改)
* @notice 基础权限控制合约,实现「仅所有者可操作」的核心逻辑
* @dev 该合约通常作为基类被其他业务合约继承,复用权限控制逻辑
*/
contract Ownable {
    // 公开状态变量:存储当前合约所有者的以太坊地址
    // public 修饰会自动生成 getter 函数:owner(),外部可读取该值
    address public owner;

    /**
     * @dev 构造函数:合约部署时执行,仅执行一次
     * 将部署合约的钱包地址(msg.sender)赋值给 owner,作为初始所有者
     */
    constructor() {
        owner = msg.sender;
    }

    /**
     * @dev 核心权限修饰器:限制函数仅所有者可调用
     * 调用被该修饰器标记的函数时,会先执行此处的校验逻辑
     * 校验规则:调用者地址(msg.sender)必须等于 owner,否则抛出异常并提示 "not owner"
     * _; 是修饰器占位符,代表被修饰函数的核心逻辑会在此处执行
     */
    modifier onlyOwner() {
        require(msg.sender == owner, "not owner");
        _;
    }


    /**
     * @notice 安全转移合约所有权的函数
     * @dev 仅当前所有者可调用,且校验新地址非零地址,防止权限锁死
     * @param _newOwner 新的合约所有者地址
     * @dev 校验规则:_newOwner 不能是零地址(address(0)),否则抛出 "invalid address" 异常
     */
    function setOwner(address _newOwner) external onlyOwner {
        // 校验新地址有效性:防止将所有者设置为无效的零地址
        require(_newOwner != address(0), "invalid address");
        // 更新所有者地址为新地址
        owner = _newOwner;
    }


    /**
     * @notice 示例函数:仅所有者可调用的敏感操作
     * @dev 演示 onlyOwner 修饰器的使用,可替换为实际业务逻辑(如参数配置、权限管理)
     */
    function onlyOwnerCanCallThisFunc() external onlyOwner {
        // code:此处编写仅所有者可执行的逻辑(如修改合约核心参数、暂停合约等)
    }


    /**
     * @notice 示例函数:任何人可调用的公开操作
     * @dev 演示无权限限制的函数,可替换为实际公开业务逻辑(如查询数据、普通交易)
     */
    function anyOneCanCall() external {
        // code:此处编写任何人可执行的公开逻辑(如读取合约状态、发起普通交易等)
    }
}

3. 测试

1、在当前地址下,调用只能owner调用的函数成功。

2、切换地址后,在调用只能owner调用的函数时失败。

切换地址。

调用报错。

3、切换为原来的地址,调用setOwner函数,将之前的地址作为参数,让owner变为新地址,
注意的是这里切换原地址的原因是如果不是原地址,没有办法调用setOwner函数。

可以看到地址已经切换到原来的地址了,然后账户换到

0x617F2E2fD72FD9D5503197092aC168c91465E7f2

在调用onlyOwnerCanCallThisFun函数成功。

相关推荐
许强0xq8 分钟前
订单流战争:AI、区块链与市场透明度的终极博弈
web3·区块链·智能合约·solidity·dapp
BlockChain88810 分钟前
以太坊交易全流程详解
区块链
weixin_4138385611 分钟前
基于区块链的校园二手书交易系统
vue.js·spring·区块链·fabric
f164225413 分钟前
区块链入门知识
区块链
迷藏49419 小时前
**发散创新:基于Solid协议的Web3.0去中心化身份认证系统实战解析**在Web3.
java·python·web3·去中心化·区块链
CIO_Alliance1 天前
区块链技术在iPaaS系统集成中的应用
区块链·ipaas·系统集成·制造业·企业数智化转型·零售电商
The_Ticker2 天前
印度股票实时行情API(低成本方案)
python·websocket·算法·金融·区块链
苏慕白的博客2 天前
精度套利:藏在盘口缝隙里的稳定机会
区块链·量化·高频量化·套利
Tattoo_Welkin3 天前
【RWA 机制,ERC-4626,ERC-3643,ERC-7540,ERC-7575,LayerZero】
区块链
魑魅魍魎13 天前
基于全同态加密的逻辑回归心脏病预测示例详解
区块链·逻辑回归·同态加密