CI框架扩展系统核心类的方法分析,ci框架
CI框架扩展系统核心类的方法分析,ci框架
本文实例讲述了CI框架扩展系统核心类的方法。分享给大家供大家参考,具体如下:
首先你系统扩展类是放在application/core下面的,本来系统核心类是CI_Controller,所以你不能以CI_开头了,你需要打开 application/config/config.php 修改:
$config['subclass_prefix'] = 'MY_';
为你的前缀!
一些公共的模块就可以卸载自己的核心类里面了!
这几天读了Dilicms(轻量级的后台架构),比如说他的后台扩展类是这样的:
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed'); 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('session'); $this->settings->load('backend'); $this->load->switch_theme(setting('backend_theme')); $this->_check_login(); $this->load->library('acl'); $this->load->library('plugin_manager'); } /** * 检查用户是否登录 * * @access protected * @return void */ protected function _check_login() { if ( ! $this->session->userdata('uid')) { redirect(setting('backend_access_point') . '/login'); } else { $this->_admin = $this->user_mdl->get_full_user_by_username($this->session->userdata('uid'), 'uid'); if ($this->_admin->status != 1) { $this->session->set_flashdata('error', "此帐号已被冻结,请联系管理员!"); redirect(setting('backend_access_point') . '/login'); } } } /** * 加载视图 * * @access protected * @param string * @param array * @return void */ protected function _template($template, $data = array()) { $data['tpl'] = $template; $this->load->view('sys_entry', $data); } /** * 检查权限 * * @access protected * @param string * @return void */ protected function _check_permit($action = '', $folder = '') { if ( ! $this->acl->permit($action, $folder)) { $this->_message('对不起,你没有访问这里的权限!', '', FALSE); } } /** * 信息提示 * * @access public * @param string * @param string * @param bool * @param string * @return void */ public function _message($msg, $goto = '', $auto = TRUE, $fix = '') { if($goto == '') { $goto = isset($_SERVER['HTTP_REFERER']) ? $_SERVER['HTTP_REFERER'] : site_url(); } else { $goto = strpos($goto, 'http') !== false ? $goto : backend_url($goto); } $goto .= $fix; $this->_template('sys_message', array('msg' => $msg, 'goto' => $goto, 'auto' => $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['nav'] = $this->get_nav(); $data['tpl'] = $template; $this->load->view('default',$data); } //公共导航信息 public function get_nav(){ } //公共友情链接信息 public function get_friendlink(){ } }
提示,一些经常用到得工具和函数可以放在helper中!
更多关于CodeIgniter相关内容感兴趣的读者可查看本站专题:《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《php优秀开发框架总结》、《ThinkPHP入门教程》、《ThinkPHP常用方法总结》、《Zend FrameWork框架入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于CodeIgniter框架的PHP程序设计有所帮助。

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Go language is an efficient, concise and easy-to-learn programming language. It is favored by developers because of its advantages in concurrent programming and network programming. In actual development, database operations are an indispensable part. This article will introduce how to use Go language to implement database addition, deletion, modification and query operations. In Go language, we usually use third-party libraries to operate databases, such as commonly used sql packages, gorm, etc. Here we take the sql package as an example to introduce how to implement the addition, deletion, modification and query operations of the database. Assume we are using a MySQL database.

To extend PHP function functionality, you can use extensions and third-party modules. Extensions provide additional functions and classes that can be installed and enabled through the pecl package manager. Third-party modules provide specific functionality and can be installed through the Composer package manager. Practical examples include using extensions to parse complex JSON data and using modules to validate data.

Hibernate polymorphic mapping can map inherited classes to the database and provides the following mapping types: joined-subclass: Create a separate table for the subclass, including all columns of the parent class. table-per-class: Create a separate table for subclasses, containing only subclass-specific columns. union-subclass: similar to joined-subclass, but the parent class table unions all subclass columns.

Apple's latest releases of iOS18, iPadOS18 and macOS Sequoia systems have added an important feature to the Photos application, designed to help users easily recover photos and videos lost or damaged due to various reasons. The new feature introduces an album called "Recovered" in the Tools section of the Photos app that will automatically appear when a user has pictures or videos on their device that are not part of their photo library. The emergence of the "Recovered" album provides a solution for photos and videos lost due to database corruption, the camera application not saving to the photo library correctly, or a third-party application managing the photo library. Users only need a few simple steps

How to use MySQLi to establish a database connection in PHP: Include MySQLi extension (require_once) Create connection function (functionconnect_to_db) Call connection function ($conn=connect_to_db()) Execute query ($result=$conn->query()) Close connection ( $conn->close())

PHP function return value types can be expressed as type description syntax, which clearly specifies the return value type of each function. Understanding return value types is critical to creating extensions that are compatible with the PHP core engine, avoiding unexpected conversions, improving efficiency, and enhancing code readability. Specifically, extension functions can define a return value type so that the PHP engine can optimize code execution based on that type and allow developers to explicitly handle the return value. In practice, extension functions can return PHP objects, and PHP code can handle the returned results according to the return value type.

HTML cannot read the database directly, but it can be achieved through JavaScript and AJAX. The steps include establishing a database connection, sending a query, processing the response, and updating the page. This article provides a practical example of using JavaScript, AJAX and PHP to read data from a MySQL database, showing how to dynamically display query results in an HTML page. This example uses XMLHttpRequest to establish a database connection, send a query and process the response, thereby filling data into page elements and realizing the function of HTML reading the database.

Analysis of the basic principles of the MySQL database management system MySQL is a commonly used relational database management system that uses structured query language (SQL) for data storage and management. This article will introduce the basic principles of the MySQL database management system, including database creation, data table design, data addition, deletion, modification, and other operations, and provide specific code examples. 1. Database Creation In MySQL, you first need to create a database instance to store data. The following code can create a file named "my
