Yii2.0 游客访问限制(转)

Posted intinity

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Yii2.0 游客访问限制(转)相关的知识,希望对你有一定的参考价值。

最近在用Yii2.0做项目,其中需要实现一个功能:没有登录不能访问部分页面,即游客身份访问限制。查了半天资料,终于找到答案。解决方法如下:

      在access里,access即访问的意思,其中有个配置项 ‘only’=>[‘login‘,‘about‘]  这是什么意思呢,意思是仅仅在login、about两个action内起作用,即当action

      是login、about时,会进入rules里做下一步验证。

      但是 我们想除了登录、注册以外其他action均不允许访问怎么办呢?还有其他的配置,我们把only 改成 except,什么意思呢,是除去什么什么之外的意思,就是

      说对除了 login、signup以外的action起作用。接下来,在rules=>[[‘action‘=>[‘login‘,‘signup‘],‘allow‘=>true,‘roles‘=>[‘?‘]]]  里,rules就是规则,这里边可以写

      多条,actions是指规则针对哪个action,allow指是否允许访问,‘roles‘这个字段是关键的,这是允许访问的角色。其中?代表游客,@代表已登录的用户。

public function behaviors()
{
    return [
        ‘access‘ => [
            ‘class‘ => AccessControl::className(),
            ‘except‘ =>[‘login‘,‘signup‘],
            ‘rules‘ => [
                [
                    ‘actions‘ => [‘login‘,‘signup‘],
                    ‘allow‘ => true,
                    ‘roles‘ => [‘?‘],
                ],
            ],
        ],
        ‘verbs‘ => [
            ‘class‘ => VerbFilter::className(),
            ‘actions‘ => [
                ‘logout‘ => [‘post‘],
            ],
        ],
    ];
}

以上是关于Yii2.0 游客访问限制(转)的主要内容,如果未能解决你的问题,请参考以下文章

Yii2.0高级框架数据库增删改查的一些操作(转)

yii2.0配置以pathinfo的形式访问

在beforeAction里redirect无效,Yii2.0.8

如何使用yii2开发

[代码审计]yii2 反序列化漏洞分析

yii2.0 能够访问到文件中但是不能到方法里面