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函数成功。

相关推荐
Web3_Daisy20 小时前
Token 分红机制详解:实现逻辑、激励结构与风险分析
大数据·人工智能·物联网·web3·区块链
软件工程小施同学1 天前
区块链论文速读 CCF A--CCS 2025 (1) 附pdf下载
pdf·区块链
程序员cxuan2 天前
token 与比特币
区块链
MicroTech20252 天前
微算法科技(NASDAQ :MLGO)抗量子区块链技术:筑牢量子时代的数字安全防线
科技·算法·区块链
TechubNews2 天前
春寒未散,巨头收帆:Kraken 按停 IPO,蓄力待时
区块链
CryptoPP3 天前
使用API对接BSE交易所数据:完整技术实现指南
区块链
Black_mario3 天前
Plutus:Berachain 上的「Pendle + Convex」?
区块链
Web3VentureView3 天前
倒计时 12 小时,SYNBO 主网即将上线!
大数据·人工智能·金融·web3·区块链
搞IT的锋3 天前
区块链BaaS是什么
区块链
财迅通Ai3 天前
莎普爱思高溢价收购上海勤礼100%股权:转型关键落子与多重风险交织
大数据·人工智能·区块链·莎普爱思