首页 >后端开发 >php教程 >关于CI框架扩展系统核心类的方法分析

关于CI框架扩展系统核心类的方法分析

不言
不言原创
2018-06-14 13:43:081325浏览

这篇文章主要介绍了CI框架扩展系统核心类的方法,结合实例形式分析了CI框架实现扩展系统核心类的步骤与相关操作技巧,需要的朋友可以参考下

本文实例讲述了CI框架扩展系统核心类的方法。分享给大家供大家参考,具体如下:

首先你系统扩展类是放在application/core下面的,本来系统核心类是CI_Controller,所以你不能以CI_开头了,你需要打开 application/config/config.php 修改:

$config['subclass_prefix'] = 'MY_';

为你的前缀!

一些公共的模块就可以卸载自己的核心类里面了!

这几天读了Dilicms(轻量级的后台架构),比如说他的后台扩展类是这样的:

<?php if ( ! defined(&#39;BASEPATH&#39;)) exit(&#39;No direct script access allowed&#39;);
abstract class Admin_Controller extends CI_Controller
{
  /**
  * _admin
  * 保存当前登录用户的信息
  *
  * @var object
  * @access public
  **/
  public $_admin = NULL;
  /**
  * 构造函数
  *
  * @access public
  * @return void
  */
  public function __construct()
  {
    parent::__construct();
    $this->load->library(&#39;session&#39;);
    $this->settings->load(&#39;backend&#39;);
    $this->load->switch_theme(setting(&#39;backend_theme&#39;));
    $this->_check_login();
    $this->load->library(&#39;acl&#39;);
    $this->load->library(&#39;plugin_manager&#39;);
  }
 /**
  * 检查用户是否登录
  *
  * @access protected
  * @return void
  */
  protected function _check_login()
  {
    if ( ! $this->session->userdata(&#39;uid&#39;))
    { 
      redirect(setting(&#39;backend_access_point&#39;) . &#39;/login&#39;);
    }
    else
    {
      $this->_admin = $this->user_mdl->get_full_user_by_username($this->session->userdata(&#39;uid&#39;), &#39;uid&#39;);
      if ($this->_admin->status != 1)
      {
        $this->session->set_flashdata(&#39;error&#39;, "此帐号已被冻结,请联系管理员!");
        redirect(setting(&#39;backend_access_point&#39;) . &#39;/login&#39;);
      }
    }
  }
 /**
  * 加载视图
  *
  * @access protected
  * @param string
  * @param array
  * @return void
  */
  protected function _template($template, $data = array())
  {
    $data[&#39;tpl&#39;] = $template;
    $this->load->view(&#39;sys_entry&#39;, $data);
  }
 /**
  * 检查权限
  *
  * @access protected
  * @param string
  * @return void
  */
  protected function _check_permit($action = &#39;&#39;, $folder = &#39;&#39;)
  {
    if ( ! $this->acl->permit($action, $folder))
    {
      $this->_message(&#39;对不起,你没有访问这里的权限!&#39;, &#39;&#39;, FALSE);
    }
  }
 /**
  * 信息提示
  *
  * @access public
  * @param string
  * @param string
  * @param bool
  * @param string
  * @return void
  */
  public function _message($msg, $goto = &#39;&#39;, $auto = TRUE, $fix = &#39;&#39;)
  {
    if($goto == &#39;&#39;)
    {
      $goto = isset($_SERVER[&#39;HTTP_REFERER&#39;]) ? $_SERVER[&#39;HTTP_REFERER&#39;] : site_url();
    }
    else
    {
      $goto = strpos($goto, &#39;http&#39;) !== false ? $goto : backend_url($goto);  
    }
    $goto .= $fix;
    $this->_template(&#39;sys_message&#39;, array(&#39;msg&#39; => $msg, &#39;goto&#39; => $goto, &#39;auto&#39; => $auto));
    echo $this->output->get_output();
    exit();
  }
}

它就把一些公共信息入验证,登陆,跳转放在Admin_Controller里面,于是我在写前台的时候也是这样操作,扩展了Font_Controller:

abstract class Font_Controller extends CI_Controller{
 public function __construct() {
  parent::__construct();
 }
 //前台加载视图方法
 public function _template($template, $data = array()){
  $data[&#39;nav&#39;] = $this->get_nav();
  $data[&#39;tpl&#39;] = $template;
  $this->load->view(&#39;default&#39;,$data);
 }
 //公共导航信息
 public function get_nav(){
 }
 //公共友情链接信息
 public function get_friendlink(){
 }
}

提示,一些经常用到得工具和函数可以放在helper中!

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

关于CI框架视图中加载视图的方法

CI框架中MVC的简单分析

以上是关于CI框架扩展系统核心类的方法分析的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn