Not redirected to specific URL in Codeigniter 4

一世执手 提交于 2021-01-27 13:50:49

问题


Why is it that whenever I redirect something through the constructor of my Codeigniter 4 controller is not working?

<?php namespace App\Controllers\Web\Auth;

class Register extends \App\Controllers\BaseController
{
    function __construct()
    {
        if(session('username')){
            return redirect()->to('/dashboard');
        }
    }
    public function index()
    {
        // return view('welcome_message');
    }
}

But if I put it inside index it's working as expected.

public function index()
{
        if(session('username')){
            return redirect()->to('/dashboard');
        }
}

The thing is, I do not want to use it directly inside index because I it need on the other method of the same file.


回答1:


As per the Codeigniter forum, you can no longer use the redirect method in the constructor to redirect to any of the controllers.

Please refer the below link for more information

https://forum.codeigniter.com/thread-74537.html

It clearly states that redirect() will return a class instance instead of setting a header and you cannot return an instance of another class while instantiating a different class in PHP.

So that's why you can't use redirect method in constructor.

Instead, what I can suggest to you is that use the header method and redirect to your desired controller.

<?php namespace App\Controllers\Web\Auth;

class Register extends \App\Controllers\BaseController
{
    function __construct()
    {
        if(session('username')){
            header('Location: /dashboard');
        }
    }
}

If that's not feasible or difficult to achieve you can follow the below code

<?php namespace App\Controllers\Web\Auth;

class Register extends \App\Controllers\BaseController
{
    function __construct()
    {
        //call to session exists method
        $this->is_session_available();
    }

    private function is_session_available(){
        if(session('username')){
            return redirect()->to('/dashboard');
        }else{
            return redirect()->to('/login');
        }
    }
}

The 2nd solution will be more interactive than the first one. And make sure the method is private. So that it should not be called from other class instances.

The community team has also given a solution to look into the controller filter.

https://codeigniter4.github.io/CodeIgniter4/incoming/filters.html

Please refer to the thread. I hope it may help you in finding a better solution.




回答2:


In this case you shouldn't even be doing this kind of logic in your controllers. This should be done in a filter and not your controllers.

So you have your controller Register.

You should create a filter in your app/filters folder something like checkLogin.php

That filter should have the following structure:

<?php

namespace App\Filters;

use CodeIgniter\Filters\FilterInterface;
use CodeIgniter\HTTP\RequestInterface;
use CodeIgniter\HTTP\ResponseInterface;

class CheckLogin implements FilterInterface
{

    /**
     * Check loggedIn to redirect page
     */
    public function before(RequestInterface $request, $arguments = null)
    {
        $session = \Config\Services::session();
        if (session('username')) {
            return redirect()->to('/dashboard');
        }
    }

    public function after(RequestInterface $request, ResponseInterface $response, $arguments = null)
    {
        // Do something here
    }
}

Then in your app/config/Filters.php your should add the filter to the desired controller.

public $aliases = [
    'csrf' => \CodeIgniter\Filters\CSRF::class,
    'toolbar' => \CodeIgniter\Filters\DebugToolbar::class,
    'honeypot' => \CodeIgniter\Filters\Honeypot::class,
    'checkLogin' => \App\Filters\CheckLogin::class,
];

// List filter aliases and any before/after uri patterns
public $filters = [
    'checkLogin' => ['before' => ['Register']],
];

For more information on filters and how to use then please check the documentation.

https://codeigniter.com/user_guide/incoming/filters.html?highlight=filters

You can then even create filters to your other controllers that would redirect to this one in case the user is not logged in.




回答3:


Codeigniter 4 using initController() to create constructor.

You can't use redirect() inside __construct() or initController() function.

But you can use $response parameter or $this->response to call redirect in initController() before call another function in controller;

<?php namespace App\Controllers\Web\Auth;

class Register extends \App\Controllers\BaseController
{
    public function initController(\CodeIgniter\HTTP\RequestInterface $request, \CodeIgniter\HTTP\ResponseInterface $response, \Psr\Log\LoggerInterface $logger)
    {
        // Do Not Edit This Line
        parent::initController($request, $response, $logger);
        
        
        if(session('username')){
            $response->redirect(base_url('dashboard')); // or use $this->response->redirect(base_url('dashboard'));
        }
    }
    
    public function index()
    {
        // return view('welcome_message');
    }
}



回答4:


Codeigniter 4 do not has any return on Constructor, but you can use like this

public function __construct()
{
    if (!session()->has('user_id')) {
        header('location:/home');
        exit();
    }
}

Don't forget to use exit()

But, you better use Filters



来源:https://stackoverflow.com/questions/60476570/not-redirected-to-specific-url-in-codeigniter-4

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!