codeigniter笔记

文件结构:

执行流程:

<?php
//约定:变量后圆括号内为变量的含义,方括号为变量的值
1.index.php.
    (1),初始化一些系统变量,包括:
                $system_folder(系统文件夹[system]),
                $application_folder(应用程序文件夹[application])
    (2).定义一些常量,包括:
                EXT(文件扩展名[pathinfo(__FILE__, PATHINFO_EXTENSION)]),
                FCPATH(文件在服务器中的完整路径名[__FILE__]),
                SELF(包含扩展名的文件名[pathinfo(__FILE__, PATHINFO_BASENAME)]),
                BASEPATH(系统文件夹的路径[$system_folder.'/']),
                APPPATH(程序所在文件夹[$application_folder.'/']),
     (3).定向至
                BASEPATH.'codeigniter/CodeIgniter'.EXT;
     (4).结束
?>
<?php
2.CodeIgniter.php(系统前台控制器,加载基本类和处理请求)
    (1),加载全局函数,这些全局函数在后面的加载类和获取配置项方面发挥作用,
                 require(BASEPATH.'codeigniter/Common'.EXT);
                 Common.php中拥有如下函数:
                        is_really_writable($file);//判断文件是否可写
                        &load_class($class, $instantiate = TRUE)//这个函数利用单件模式,当请求的class不存在时就加载这个类,然后将其设置成一个静态变量,如果已经加载了这个类,则返回这个类的安装变量
                                                                                      //第二个参数指示,是否实例化此类,如果设置为false,则只是包含此类的文件而不进行实例化,返回的值为true/false只是是否加载成功
                                                                                      //从libraries中加载类库
                        &get_config()//返回config.php文件中的配置数组
                        config_item($item) //获取某个配置项
                        show_error($message)//显示错误
                        show_404($page = '')//显示404错误
                        log_message($level = 'error', $message, $php_error = FALSE)//将信息写入日志
                        _exception_handler($severity, $message, $filepath, $line)//错误处理函数,可以拦截错误并写入到指定的文件中
     (2),兼容性函数 ,处理一些在某些版本中不存在的函数
                 require(BASEPATH.'codeigniter/Compat'.EXT);
                 Compat.php中存在下列内容:
                        定义了错误显示级别:define('E_STRICT', 2048);
                        定义了函数:ctype_digit($str)//字符串中只包含数字,否则返回false
                        定义了函数:ctype_alnum($str);//字符串中只包含数字或者字母,否则返回false
     (3).加载框架常量
                require(APPPATH.'config/constants'.EXT);
                此文件中定义的常量具体见文件中,此处省略
     (4).设置错误处理,禁用magic_quotes_runtime
     (5).导入benchmark类,设置断点并调试断点,这个类使你可以设置断点来计算运行时间和消耗的内存
                $BM =& load_class('Benchmark');
                Benchmark类中有下列属性和方法:
                        var $marker = array();//断点的数组
                        function mark($name)//设置一个断点,将现在的时间以微秒标识赋值给此变量
                        function elapsed_time($point1 = '', $point2 = '', $decimals = 4)//计算两个断点的间隔时间,如果第一个断点的值为空,则返回一个标签{elapsed_time},在output类中将处理这个标签
                        function memory_usage()//返回一个{memory_usage}标签,在output类中将处理这个标签,因为显示整个脚本的消耗内存量才是有意义的
     (6).加载钩子类,提供了一种机制来扩展基本系统的运行方式,即在某些点插入你自己要运行的脚本,包括诸多可选点
                $EXT =& load_class('Hooks');
                 此类包含如下的属性和方法:
                        var $enabled 		= FALSE;//是否启用钩子
                        var $hooks   		= array();//钩子数组
                        var $in_progress	= FALSE;//标识是否正在运行钩子
                        function _initialize()//判断是否启用hooks,如果启用的话就在config/hooks.php中加载hooks,并赋给$hooks属性
                        function _call_hook($which = '')//调用钩子,可以设置的钩子是有限的,见此文件中的类库说明
                        function _run_hook($data)//运行钩子,根据钩子的设置数组来包含文件,实例化类,运行其方法,以及附加属性
     (7).加载并实例化Config类,从config文件夹加载配置文件,也就是允许你在config文件夹中建立自己的配置文件,但是在此文件中必须以$config[""]数组的形式定义配置项
                $CFG =& load_class('Config');
                此类包含如下属性和方法:
                        var $config = array();//config数组
                        var $is_loaded = array();//已经加载的配置文件
                        function CI_Config()//构造函数,获取config.php中的基本config项并赋值给$config属性
                        function load($file = '', $use_sections = FALSE, $fail_gracefully = FALSE)//从config文件夹中加载配置文件(加载成功添加至$is_loaded属性),并加载配置项至$config属性
                        function item($item, $index = '')//返回某个配置项,$index允许配置以二维数组的形式出现,当配置为二维数组的时候,则用$config[$index][$item]
                        function slash_item($item)//获取一个配置项,并在其后加上一个"/"符号
                        function site_url($uri = '')//根据config设置将uri转化成完整的url形式
                        function system_url()//返回系统文件夹的完整路径
                        function set_item($item, $value)//设置某个设置项的值,只是设置在属性里,不会更改文件的设置
     (8).加载并实例化URI类,此类将截取当前url的参数部分,并分解成控制器以及方法以及参数,供主函数调用
                $URI =& load_class('URI');
                此类包含如下属性和方法:
                        var	$keyval	= array();
                        var $uri_string;//index.php后面的字符串
                        var $segments		= array();
                        var $rsegments		= array();
                        function _fetch_uri_string()//得到index.php后面的字符串并赋值给属性 $uri_string.
                        function _parse_request_uri()//处理uri中的骚扰字符,使其能正常工作
                        function _filter_uri($str)//过滤字符串,对特殊字符进行转义
                        function _remove_url_suffix()//如果在配置中设置了伪后缀名,则去掉这个后缀
                        function _explode_segments()//将字符串按"/"分解到$segments中
                        function _reindex_segments()//利用巧妙的方法改变$segments数组的索引,使其索引从1开始,这样更符合直观感受
                        function segment($n, $no_result = FALSE)//返回指定索引的参数,即$segments[$n]的值
                        function rsegment($n, $no_result = FALSE)//这个函数和上面的函数基本功能一样,不同点在于它允许你在开启CodeIgniter的URI路由功能时进行详细分割并重新分发URI信息
                        function uri_to_assoc($n = 3, $default = array())//将第三个参数之后的参数以关联数组的方式返回 其中第三个参数是第一个返回数组的key,第四个参数是第一个返回数组的value
                                                                                                    //以此类推
                        function ruri_to_assoc($n = 3, $default = array())//同上,只是应用于路由功能
                        function _uri_to_assoc($n = 3, $default = array(), $which = 'segment')//同上
                        function assoc_to_uri($array)//与上述方法的功能相反
                        function _slash_segment($n, $where = 'trailing', $which = 'segment')//添加斜线,当$where="trailing"时在末尾添加,="leading"时在开头添加
                        function segment_array()//返回$segments
                        function total_segments()//$segments的总数
    (9).加载并实例化Router类,这个类处理uri来加载控制器和控制器方法
                $RTR =& load_class('Router');
                 此类包含如下属性和方法:
                        var $config;
                        var $routes 		= array();//路由规则,在routes.php中定义
                        var $error_routes	= array();
                        var $class			= '';
                        var $method			= 'index';
                        var $directory		= '';
                        var $uri_protocol 	= 'auto';
                        var $default_controller;//默认的控制器
                        var $scaffolding_request = FALSE; // Must be set to FALSE
                        function _set_routing()//设置默认的路由信息,如果不存在控制器信息,则根据routes.php的设置来加载默认的控制器,
                        function _set_request($segments = array())//这个方法以一个数组输入来调用set_class和set_method来发送请求
                        function _validate_request($segments)//检查是否在uri中包含了文件夹信息,如果包含,则将其值赋给属性$directory
                        function _parse_routes()//处理路由,根据路由设置来
                        function set_class($class)//设置控制器类
                        function fetch_class()
                        function set_method($method)//设置控制器方法
                        function fetch_method()
                        function set_directory($dir)//设置文件夹
     (10).加载并实例化Output类
                $OUT =& load_class('Output');
                此类包含如下的方法和属性:
                        var $final_output;
                        var $cache_expiration	= 0;
                        var $headers 			= array();
                        var $enable_profiler 	= FALSE;
                        function enable_profiler($val = TRUE)//允许你开启或禁用评测器,评测器将在页的底部显示测试基准点或调试、优化需要的其他数据
                        function get_output()
                        function set_output($output)
                        function append_output($output)//附加输出的内容
                        function set_header($header, $replace = TRUE)//设置要发送的header到数组属性 $headers
                        function set_status_header($code = '200', $text = '')//设置状态码
                        function cache($time)//设置缓存以及缓存时间 ,以分钟为单位
                        function _display($output = '')//这个方法将生成并输出至客户端,如果开启了profiler则在页尾添加性能分析结果,如果设置了缓存,则调用缓存文件
                        function _write_cache($output)//根据设置的缓存时间写缓存文件
                        function _display_cache(&$CFG, &$URI)//显示缓存文件,根据url寻找文件(md5加密形式的文件名),如果存在则显示,如果过期,则删除
     (11).判断是否存在缓存文件,如果存在则显示,并退出
     (12).加载input类,这个类用来处理过滤用户的输入,防止产生各种攻击
     			$IN		=& load_class('Input');
     			        var $use_xss_clean		= FALSE;
						var $xss_hash			= '';
						var $ip_address			= FALSE;
						var $user_agent			= FALSE;
						var $allow_get_array	= FALSE;
     			        var $never_allowed_str = array()//过滤的字符串,详细见类文件定义
     			        var $never_allowed_regex =array()//用正则过滤,详细见类文件定义
     			        function CI_Input()//构造函数,从配置文件判断是否开启安全功能,然后调用下面的方法
     			        function _sanitize_globals()//清除globals变量,在开启了globals_register的情况下,相当于关闭了此配置项
     			        function _clean_input_data($str)//过滤输入的数据
     			        function _clean_input_keys($str)//过滤键值
     			        function _fetch_from_array(&$array, $index = '', $xss_clean = FALSE)//从$array获取值,如果设置了xss_clean则过滤之
     			        function get($index = '', $xss_clean = FALSE)//获取过滤后的get数组
     			        function post($index = '', $xss_clean = FALSE)//获取过滤后的post数组
     			        function get_post($index = '', $xss_clean = FALSE)//获取post数组,如果没有则从get数组获取
     			        function cookie($index = '', $xss_clean = FALSE)//获取cookie数组
     			        function server($index = '', $xss_clean = FALSE)//获取服务器变量数组
     			        function ip_address()//获取ip地址
     			        function valid_ip($ip)//验证ip地址
     			        function filename_security($str)//过滤文件名中的隐患
     			        function xss_clean($str, $is_image = FALSE)//执行各种xss过滤
     			        function _remove_invisible_characters($str)//移除不可见的符号
     			        省略了一系列xss_clean中的回调函数,对输入执行各种安全过滤
     (13).加载language类
     			$LANG	=& load_class('Language');
     			省略此类的描述
     (14).加载controller类
     			load_class('Controller', FALSE);
     			只包含此文件而不实例化此类
     			如果php版本小于5则加载loader类
     (15).根据uri来在controller文件夹中寻找控制器类和方法,如果找不到则退出,找到则包含文件
     			$class  = $RTR->fetch_class();//获取请求的类
				$method = $RTR->fetch_method();//获取请求的方法
	 (16).
	 (17).$CI = new $class();//加载超类,超类是以控制器中的类为基础创建的
	 		判断是否是附带脚手架的请求
	 (18)Controller类的结构:此类继承自CI_Base类
	 					var $_ci_scaffolding	= FALSE;
						var $_ci_scaff_table	= FALSE;
						function Controller()//构造函数,执行parent::CI_Base();$this->_ci_initialize();
						function _ci_initialize()//在此将所有的基本类都加在为这个类的变量,使本类成为一个超级类,并且加载load类来加载视图和模型等
						function _ci_scaffolding()//执行脚手架
	 (19).如果使用了数据库 则关闭数据库






一、应用程序流程图
	index.php 作为前端控制器,初始化运行 CodeIgniter 所需要的基本资源。 
	Router 检查 HTTP 请求,以确定谁来处理请求。 
	如果缓存(Cache)文件存在,它将绕过通常的系统执行顺序,被直接发送给浏览器。 
	安全(Security)。应用程序控制器(Application Controller)装载之前,HTTP 请求和任何用户提交的数据将被过滤。 
	控制器(Controller)装载模型、核心库、辅助函数,以及任何处理特定请求所需的其它资源。 
	最终视图(View)渲染发送到 Web 浏览器中的内容。如果开启缓存(Caching),视图首先被缓存,所以将可用于以后的请求。 
二、配置
	config.php 
		 $config['base_url']    = "http://www.example.com/";

	database.php。
		$db['default']['hostname'] = "localhost";
		$db['default']['username'] = "root";
		$db['default']['password'] = "root";
		$db['default']['database'] = "test";
		$db['default']['dbdriver'] = "mysql";

三


四、创建数据库模型
  在 system/application/models 文件夹内,创建一个 mtest.php 的文件,如下:
PHP
<?php
class Mtest extends Model{
    function Mtest(){
        parent::Model();
    }
    function adduser(){
        $data=array(
         'name'=> $this->input->xss_clean($this->input->post('name')),
         'age'=> $this->input->xss_clean($this->input->post('age')),
         'sex'=> $this->input->xss_clean($this->input->post('sex'))
        );
         $this->db->insert('users', $data);
    }
    
}
?>

五、控制器
 /application/controllers 文件夹中
 
 注意:在application中存在同名类就用这个类生成对象,即覆盖了systme的同名类
       如果是用MY_前缀继承的就都加载
 
 在 CodeIgniter 中,控制器用于组织项目。设想每个函数都是站点或应用程序的一个页面或者请求。
 如果使用主页,就需要一个 index() 函数。如果有一个aboutus页面,
 就需要aboutus()函数方法
 <?php
class Test extends Controller {
 
  function Test(){
    parent::Controller();
  }
 
  function index(){
    $this->load->helper('form');
    $data['title'] = "Users add.";
    $data['headline'] = "Welcome! to User System.";
    $this->load->vars($data);
    $this->load->view('users');
}
 
}
?>
六、创建视图
  在system/application/views 中的users.php,如下所示:

PHP
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
        "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<meta http-equiv="content-type" c />
<title><? echo $title;?></title>
</head>
<body>
</h2><?php echo $headline; ?></h2>
<?php
/**
 * 表单数据
*/
echo form_open('test/save');
/**
 * 输入用户名
 */
echo form_label('姓名','name');
echo "<br>";
$ndata = array('name' => 'name', 'id' => 'name', 'size' => '40');
echo form_input($ndata);
echo "<br>";
/**
 * 输入age
 */
echo form_label('岁数','age');
echo "<br>";
$adata = array('name' => 'age', 'id' => 'age', 'size' => '40');
echo form_input($adata);
echo "<br>";
/**
 * 输入sex
 */
echo form_label('性别','sex');
echo "<br>";
$sdata = array('name' => 'sex', 'id' => 'sex', 'size' => '40');
echo form_input($sdata);
echo "<br>";
 
echo form_submit('submit','提交保存');
echo form_close();
 
?>
 
</body>
</html>

 
1配置默认控制器:application/config/routes.php 设置  $route['default_controller'] = "main";
 注意控制器名最好不要用index,因为默认方法index会当做控制器构造函数,如果没有index方法,可以
2加载helper,比如helper("common")
 //如果存在自定义扩展的common helper,比如MY_common_helper.php,则先加载自定义helper,再加载系统同名helper
 否则,如果application/helper 里面有common_helper.php就加载这个,system/helper里面的就不加载了,会覆盖系统的,通过
 break;跳出了循环。
 所以要注意;
3
 
 

  
  

















?>

  

posted on 2012-01-06 11:45  天空尚兰  阅读(1003)  评论(0)    收藏  举报

导航