主頁 > 知識庫 > yii2.0框架使用 beforeAction 防非法登陸的方法分析

yii2.0框架使用 beforeAction 防非法登陸的方法分析

熱門標(biāo)簽:怎么向銷售公司推銷外呼系統(tǒng) 長春人工外呼系統(tǒng)服務(wù)商 高德地圖標(biāo)注家 江西手機(jī)自動(dòng)外呼防封系統(tǒng)是什么 哪里辦理400電話 廣東地市地圖標(biāo)注 廣州防封卡外呼系統(tǒng)多少錢一個(gè)月 仁和怎么申請400開頭的電話 外呼系統(tǒng)撥打暫時(shí)無法接通

本文實(shí)例講述了yii2.0框架使用 beforeAction 防非法登陸的方法。分享給大家供大家參考,具體如下:

beforeAction基本原理:

對比

1、執(zhí)行順序

init > beforeAction

2、調(diào)用子函數(shù)時(shí),兩個(gè)函數(shù)都不會再次執(zhí)行

3、返回值

init返回false繼續(xù)執(zhí)行,beforeAction停止執(zhí)行

4、執(zhí)行EXIT,全部停止

從框架的示例代碼來看,init用于初始化數(shù)據(jù),beforeAction用戶事件的處理

代碼

// 登錄統(tǒng)一驗(yàn)證
public function beforeAction( $action ){
//  驗(yàn)證是否登錄
   $is_login = $this->checkLoginStatus();
    if (in_array($action->getUniqueId(), $this->allowAllAction ) ) {
      return true;
    }
// 是否已經(jīng)登錄了 沒有登錄的話 判斷登錄方式
    if(!$is_login) {
//  如果是ajax方式進(jìn)行請求
      if ( \Yii::$app->request->isAjax) {
        $this->renderJSON([], "未登錄,請返回用戶中心", -302);
      } else {
        $this->redirect( UrlService::buildWebUrl("/user/login") );
      }
      return false;
    }
}

其他的控制器使用的時(shí)候進(jìn)行繼承一下就可以了!

class UserController extends BaseWebController

防非法登陸的方法:

首先寫一個(gè)公共控制器 讓其他所以需要防止非法登陸的頁面繼承一下這個(gè)公共控制器

?php
namespace frontend\controllers;
use Yii;
use yii\web\Controller;
class PublicController extends Controller{
 public function beforeAction($action){
  $cookie = \Yii::$app->request->cookies;
  //取出存入的cookie值 括號里寫自己定義的cookie名字
  $user_cookie = $cookie->get('user_id');
  //判斷是否有cookie
  if(!isset($user_cookie)){
   echo "script>alert('請先登錄');location.href='?r=login/login'/script>";
  }
  return parent::beforeAction($action);
 }
}

然后在任意一個(gè)控制器中加入一段代碼 不需要所有控制器都寫 只寫一個(gè)控制器里面就行

public function beforeAction($action)
{
  if(!parent::beforeAction($action))
  {
   return false;
  }
}

更多關(guān)于Yii相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Yii框架入門及常用技巧總結(jié)》、《php優(yōu)秀開發(fā)框架總結(jié)》、《smarty模板入門基礎(chǔ)教程》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》

希望本文所述對大家基于Yii框架的PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • Yii2使用$this->context獲取當(dāng)前的Module、Controller(控制器)、Action等
  • Yii框架獲取當(dāng)前controlle和action對應(yīng)id的方法
  • yii框架配置默認(rèn)controller和action示例
  • YII2框架中驗(yàn)證碼的簡單使用方法示例
  • YII2框架中分頁組件的使用方法示例
  • YII2框架中自定義用戶認(rèn)證模型,完成登陸和注冊操作示例
  • YII2框架實(shí)現(xiàn)表單中上傳單個(gè)文件的方法示例
  • YII2框架中操作數(shù)據(jù)庫的方式實(shí)例分析
  • YII2框架自定義全局函數(shù)的實(shí)現(xiàn)方法小結(jié)
  • yii2.0框架場景的簡單使用示例
  • YII2框架中actions的作用與使用方法示例

標(biāo)簽:湘西 梅河口 廈門 黔東 濮陽 海北 文山 惠州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《yii2.0框架使用 beforeAction 防非法登陸的方法分析》,本文關(guān)鍵詞  yii2.0,框架,使用,beforeAction,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《yii2.0框架使用 beforeAction 防非法登陸的方法分析》相關(guān)的同類信息!
  • 本頁收集關(guān)于yii2.0框架使用 beforeAction 防非法登陸的方法分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章