失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > php判断有没有登录 请问thinkphp 怎么在每个方法里面判断是否登录?

php判断有没有登录 请问thinkphp 怎么在每个方法里面判断是否登录?

时间:2018-09-06 01:10:46

相关推荐

php判断有没有登录 请问thinkphp 怎么在每个方法里面判断是否登录?

[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();,这样做合理吗?还是说这样做本来就是合理的?

如果觉得《php判断有没有登录 请问thinkphp 怎么在每个方法里面判断是否登录?》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。