在 codeigniter 4 中有一个类名过滤器,您可以创建用于身份验证的类,您可以阅读文档以获取更多详细信息。
这是您问题的解决方案
- 在App/Filters文件夹中创建文件Auth.php
<?php
namespace App\Filters;
use CodeIgniter\HTTP\RequestInterface;
use CodeIgniter\HTTP\ResponseInterface;
use CodeIgniter\Filters\FilterInterface;
class Auth implements FilterInterface
{
public function before(RequestInterface $request)
{
if(session()->get('logged_in') !== true)
{
return redirect()->to('login');
}
}
//--------------------------------------------------------------------
public function after(RequestInterface $request, ResponseInterface $response)
{
// Do something here
}
}
- 在过滤器App/Config/Filters.php类中添加您的新过滤器以使其工作
public $aliases = [
'csrf' => \CodeIgniter\Filters\CSRF::class,
'toolbar' => \CodeIgniter\Filters\DebugToolbar::class,
'honeypot' => \CodeIgniter\Filters\Honeypot::class,
'auth' => \App\Filters\Auth::class,
];
- 在您的Routes.php中,您可以使用该过滤器来指定使用哪个路由运行该过滤器,然后再转到您想要的路线。
对于单路
$routes->get('examplefunction', 'ControllerName::examplefunction', ['filter' => 'auth']);
对于路线组
$routes->group('', ['filter' => 'auth'], function ($routes) {
$routes->get('/', 'ControllerName::examplefunction');
$routes->get('examplefunction2', 'ControllerName::examplefunction2');
};
这样过滤器将在组内的所有单个路由运行之前执行。
我希望这对你有帮助