[tp版本3.2.3]
我在Controller里面写了一个公共类CommonController.class.php,写了一个构造方法来判断是否登录,没登录就重定向到登陆页:
namespace Admin\Controller;
use Think\Controller;
class CommonController extends Controller
{
public function __construct()
{
$isLogin = session('islogin');
if (!$isLogin) {
$this->redirect('Login/index');
return;
} else {
session('islogin', $isLogin); // 如果登录刷新一下?不知道是不是这样去刷新,因为可能出现登录了后过期的情况。
}
}
}
这样做有一个问题,就是没有登录的时候始终会重定向。报错127.0.0.1 将您重定向的次数过多。
于是我改成了
class CommonController extends Controller
{
public function isLogin()
{
$isLogin = session('islogin');
if (!$isLogin) {
$this->redirect('Login/index');
return;
} else {
session('islogin', $isLogin); // 如果登录刷新一下?不知道是不是这样去刷新
}
}
}
接着在其它继承CommonController的文件每一个都去加一个构造函数,如
ArticleController.class.php
namespace Admin\Controller;
use Think\Controller;
class ArticleController extends CommonController
{
function __construct()
{
parent::isLogin(); // 这样写会报错,不知道为什么,报错提示如下
}
public function dolist()
{
$this->show("hallo world");
}
}
报错提示:
Call to a member function display() on null
错误位置
FILE: X:\domainX\ThinkPHP\Library\Think\Controller.class.php LINE: 69
最后这样写才不报错:
namespace Admin\Controller;
use Think\Controller;
class ArticleController extends CommonController
{
public function dolist()
{
parent::isLogin(); // 这样写
$this->show("hallo world");
}
}
问题:
为什么继承CommonController.class.php的类也不能再__construct里面判断呢?
继承CommonController.class.php的类如果都要判断是否登录,就需要在每一个方法里面写parent::isLogin();,这样做合理吗?还是说这样做本来就是合理的?