php - Codeigniter4如何从派生类构造函数调用父控制器的构造函数
问题描述
在 Codeignter 4 中,我们不能在 BaseController 中使用构造函数。但是方法 initController() 会做到这一点。但是如何从派生控制器的构造函数中调用这个方法呢?
我的问题是,该BaseController::is_allowed()
方法将完成对所有派生控制器类通常有用的所有基本功能。但要工作BaseController::is_allowed()
,BaseController::__construct()
应该在此之前执行。但与 CI-4 中一样,构造函数不允许在BaseController
. 它可以有BaseController::initController()
. 但问题是这个方法只会在DerivedClass::__construct()
.
我需要BaseController::is_allowed()
在执行每个派生类方法之前执行。所以我 BaseController::is_allowed()
在派生控制器的构造函数中调用方法。但是派生类构造函数在执行之前执行BaseController::initController()
。所以BaseController::is_allowed()
不行。
基本控制器.php
<?php
namespace App\Controllers;
use CodeIgniter\Controller;
use CodeIgniter\HTTP\CLIRequest;
use CodeIgniter\HTTP\IncomingRequest;
use CodeIgniter\HTTP\RequestInterface;
use CodeIgniter\HTTP\ResponseInterface;
use Psr\Log\LoggerInterface;
class BaseController extends Controller
{
public $request;
public function initController(RequestInterface $request, ResponseInterface $response, LoggerInterface $logger)
{
parent::initController($request, $response, $logger);
// Doing all basic setups here that are needed to all other methods in this class.
// This method will be called only after derivedClass::__construct().
// But CI-4 not allows to use __construct() method in BaseController class.
// This causes my problem.
}
function is_allowed()
{
// Provides all basic features for all derived controller classes.
// But to work code in this method, initController() method should execute first.
}
}
派生类为
用户.php
<?php
namespace App\Controllers;
class Users extends BaseController
{
public function __construct()
{
// BaseController::is_allowed() will provide all basic features for this controller.
// To work this method, BaseController::initController() should execute.
// But this will execute only after this ( __construct()) constuctor.
// In Codeignier-3, BaseController::__construct() was possible.
// It will execute before derived class constructor.
$this->is_allowed();
}
}
解决方案
基本上您的用户控制器应该使用 iniController 而不是构造,如下所示:
<?php
namespace App\Controllers;
use CodeIgniter\HTTP\RequestInterface;
use CodeIgniter\HTTP\ResponseInterface;
use Psr\Log\LoggerInterface;
class Users extends BaseController
{
public function initController(RequestInterface $request, ResponseInterface $response, LoggerInterface $logger)
{
parent::initController($request, $response, $logger);
$this->is_allowed();
}
}
但是,在 BaseController 中创建 is_allowed 函数作为受保护函数是一种很好的做法,否则可以通过任何 url 访问它,例如 site.com/users/is_allowed
我什至可以补充一点,如果 is_allowed 函数的目的是检查用户是否有权执行某项操作,甚至是否在该控制器中,您应该查看Filters而不是这个
推荐阅读
- css - 知道为什么这个缓动功能不起作用吗?
- python - 传递给 API 时 Python 字符串被欺骗
- nearprotocol - 如何在 NEAR 协议中构建和部署多个合约
- maven - Maven Shade 插件:如何解决警告消息“定义 1 个重叠资源:[WARNING] - META-INF/MANIFEST.MF”
- php - 如何将文本输入中的表情符号保存为
- arrays - 以角度获取数据数组到对象
- ios - 从需要缺少 dsym 的 Crashlytics 中删除崩溃
- php - 在 Woocommerce 档案中为可变产品设置最大显示的可用库存数量
- php - 为什么 Laravel 在加载数据时有时会使用单数数据库表名?
- python - 当一个\ x中有一个以上字节时如何解释python字节类