CodeIgniter笔记
移除URL中的index.php
开启Apache的mod_rewrite模块,在项目目录中新建.htaccess 文件,添加如下内容
RewriteEngine On RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d RewriteRule ^(.*)$ index.php/$1 [L]
获取CI超级对象
$CI = & get_instance() $version_id = $CI->config->item("version_id");
使用辅助函数
一般情况下,辅助函数位于 system/helpers 或者 application/helpers 目录 目录下。
加载 URL 辅助函数 ,它的文件名为 xxx_helper.php
public function use_help() { //加载单个 $this->load->helper('url'); //加载辅助函数,单个或多个 // 路径:application\helpers\demo_helper.php 和 application\helpers\test_helper.php // $this->load->helper(['demo','test']); echo site_url(); echo base_url(); }
扩展辅助函数
要扩展原始的 数组辅助函数 ,首先你要创建一个文件 application/helpers/MY_array_helper.php,然后在文件中添加或重写函数。
https://codeigniter.org.cn/user_guide/general/helpers.html
设置自定义前缀
用于扩展辅助函数的文件名前缀和扩展类库和核心类是一样的。要自定义这个前缀,你可以打开 application/config/config.php 文件然后找到这项:
$config['subclass_prefix'] = 'MY_';
使用codeigniter类库
所有的系统类库都位于 system/libraries/ 目录下,大多数情况下,在使用之前, 你要先在 控制器 中初始化它,使用下面的方法
//加载类库 $this->load->library('encrypt'); //使用加载的类库 $tt = $this->encrypt->encode('123','132');
创建自己的类库
自定义的类库文件应该放置在 application/libraries 目录下,当你初始化类时,CodeIgniter 会在这个目录下寻找这些类。
备注:
文件名首字母必须大写,例如:Myclass.php 类名定义首字母必须大写,例如:class Myclass 类名和文件名必须一致
例如
<?php class Someclass { public function some_class($data) { return md5($data); } }
使用
public function use_custom_library() { //创建自定义类库 $this->load->library('someclass'); echo $this->someclass->some_class(x);//目录:libraries/service/emr.php,例如:$this->load->('service');调用$this->service->emr->some_fun(); }
扩展原生类库
要扩展原生的类库,只需要新建一个文件,以MY_开头
并继承原类库
即可,示例:要扩展原Email类库,只需命名为 application/libraries/MY_Email.php , 然后定义你的类
<?php class MY_Email extends CI_Email { // }
替换原生类库
要替换原类库文件,只需定义与原生的类库命名完全一样,例如, 要替换掉原生的 Email 类的话,你要新建一个 application/libraries/Email.php 文件, 然后定义定义你的类:
<?php class CI_Email { // }
更多参考
https://codeigniter.org.cn/user_guide/general/creating_libraries.html
控制器
控制器文件保存到 application/controllers/ 目录下。控制器命名规则
1.`文件名`必须是大写字母开头,如:'Demo.php' 。 2.`类名`必须以`大写`字母开头。
示例:
<?php defined('BASEPATH') OR exit('No direct script access allowed'); class Welcome extends CI_Controller { public function index() { $this->load->view('welcome_message'); } }
模型
模型类位于你的 application/models/ 目录下。
模型命名规则
1.类名的第一个字母 必须`大写`,其余部分小写。 2.文件名和类名应该一致。
例如,创建一个Demo_model.php,路径:applicationmodelsDemo_model.php
<?php class Demo_model extends CI_Model { //对应表中的字段 public $name; public $age; public $addr; /** * 返回最后两条记录 * @return mixed */ public function get_last_two_record() { $query = $this->db->get('demo', 2); return $query->result_array(); } /** * 插入记录 */ public function insert_record($data) { $this->name = $data['name']; $this->age = $data['age']; $this->addr = $data['addr']; $this->db->insert('demo', $this); } /** * 更新记录 */ public function update_record($data) { $this->name = $data['name']; $this->age = $data['age']; $this->addr = $data['addr']; $this->db->update('demo', $this, array('id' => $data['id'])); } }
在控制器调用
class demo extends CI_Controller { public function use_model() { $data = [ 'name' => 'Daiod', 'age' => 24, 'addr' => 'Chigo', // 'id' => 8 ]; //加载model $this->load->model('demo_model'); // $this->load->model('demo/test','demoModel'); //如果model下有子目录,则$this->load->model('xxx/xxx'); //给model定义别名 $this->load->model('demo_model','demoModel'); //调用model中的方法 $this->model_name->method(); // $res = $this->demo_model->get_last_two_record(); $res = $this->demoModel->get_last_two_record(); print_r($res); //插入记录 // $this->demo_model->insert_record($data); //使用demo_model的别名 // $this->demoModel->insert_record($data); //更新 // $this->demo_model->update_record($data); } }
打印日志
修改config.php文件
/* |-------------------------------------------------------------------------- | Error Logging Threshold |-------------------------------------------------------------------------- | | You can enable error logging by setting a threshold over zero. The | threshold determines what gets logged. Threshold options are: | | 0 = Disables logging, Error logging TURNED OFF | 1 = Error Messages (including PHP errors) | 2 = Debug Messages | 3 = Informational Messages | 4 = All Messages | */ $config['log_threshold'] = 1; //默认为0,这里修改错误级别 error,debug,info
使用
public function log_write() { //打印日志,与配置文件中设置错误级别对应 log_message('error', "this is error messages"); log_message('debug', "this is debug messages"); log_message('info', "this is debug messages"); echo "<br/>"; }
数据库操作
配置
配置文件路径:CodeIgniterapplicationconfigdatabase.php自动连接
,需要修改CodeIgniterapplicationconfigautoload.php文件,
$autoload['libraries'] = array(); //修改为 $autoload['libraries'] = array('database');
手动连接
$this->load->database();
操作
查询
public function select() { # 获取表中所有记录 $query = $this->db->get('demo'); //等价于 $query = $this->db->query("select * from demo"); //返回所有记录的的数组 $data = $query->result_array(); //返回所有记录的的数组对象 $data = $query->result(); //条件查询 $data = $this->db->select('name', 'addr') ->from('demo') ->where('name = \'xiaoli\'') // ->where('id >=', 1) ->limit(2) ->order_by('age') ->get() ->result_array();//返回数组 //where条件 //where(array('name'=>'mary', 'id >'=>'1')); 表示name字段值是mary并且id字段值是1 //where('name', 'mary')或where('name =', 'mary'); 表示查询条件是name字段值是mary //row() 只返回一行记录,返回的是一个对象 $data = $query->row(); #row_array() 只返回一行记录,返回的是一个数组 $data = $query->row_array(); //num_rows() 返回查询结果行数 $data = $query->num_rows(); //num_fields() 返回查询请求的字段个数 $data = $query->num_fields(); //free_result() 释放当前查询所占用的内存并删除关联资源标识 $data = $query->free_result(); print_r($data); #返回最后运行的查询Sql语句 echo $this->db->last_query(); //select * from demo #获取插入的自增Id echo $this->db->insert_id(); //写入和更新操作被影响的行数 echo $this->db->affected_rows(); //返回指定表的总行数 echo $this->db->count_all('demo'); //输出当前的数据库版本号 echo $this->db->version(); //输出当前的数据库平台 echo $this->db->platform(); //mysqli //查询语句 $this->db->select('column1','column2'); //选择查询的字段 $this->db->get('table_name'); //表示SELECT * FROM table_name $this->db->get('table_name', 10, 20); //参数2表示每页记录数(limit),参数3表示偏移(offset),SELECT * FROM table_name LIMIT 20, 10 $this->db->select_max();//可接受两个参数,参数2表示别名 $this->db->select_min();//同上 $this->db->select_avg();//同上 $this->db->select_sum();//同上 $this->db->from('table_name');//选择表名 $this->db->join('table2','table2.pid=table.id','left');//$this->db->from('table1'); $this->db->get_where(); //示例 $this->db->get_where('table_name', array('id' => $id), $limit, $offset); $this->db->where('字段','值');// where 字段 = '值';或者where('id >',2); $this->db->or_where();//子句OR 连接 $this->db->where_in('xx',['xx','xx']);// where_in('username',['Joe','Lucy','Lily']); $this->db->or_where_in('xx',['xx','xx']); $this->db->where_not_in(); $this->db->or_where_not_in(); $this->db->like('title','match');// where title like '%match%';参数3表示before(%match),after(match%),none(match)默认为both //示例 $array = array('title' => $match, 'page1' => $match, 'page2' => $match); $this->db->like($array); // WHERE title LIKE '%match%' AND page1 LIKE '%match%' AND page2 LIKE '%match%' $this->db->or_like(); //OR连接 $this->db->not_like(); $this->db->or_not_like(); $this->db->group_by(); $this->db->distinct(); $this->db->having(); $this->db->or_having(); $this->db->order_by(); $this->db->limit(); $this->db->count_all_results(); }
插入
public function add() { //插入数据,被插入的数据会被自动转换和过滤,例如: $data = array('name' => "xiaoming", 'age' => 23, 'addr' => 'chognqing'); $this->db->insert('demo', $data);//insert_batch()插入多条,$data为二维数组 }
更新
public function update() { // $data = array('name' => 'xiaoming', 'age' => 26, 'addr' => 'shanghai'); // $where = "name = 'xiaoming'"; // $this->db->update('demo', $data, $where);//demo为表名 //或者 // $this->db->where('id', 6); // $this->db->update('demo', $data); //或者 $this->db->set('key','value'); $data = ['name' => 'nihao']; $bool = $this->db->update('demo', $data, ['id' => 3]); //update_batch() //修改id为3的记录name修改为nihao var_dump($bool);//成功则返回TURE }
删除
public function del() { // $this->db->where('id', 6); // $this->db->delete('demo'); //等价于 $bool = $this->db->delete('demo',array('id'=>5));//返回布尔值 }
操作session
// 使用session $this->load->library('session'); // 设置session $data = array( 'username' => 'johndoe', 'email' => '[email protected]', 'logged_in' => TRUE ); // 设置时间, 也可在config.php中设置 $this->session->sess_expiration = '14400'; // 仅添加一个值 $this->session->set_userdata('info', $data); // 添加多个值 // $this->session->set_userdata($data); // 检查某个 session 值是否存在 $this->session->has_userdata('info'); // 获取session $info = $this->session->userdata('info'); // or $info = $this->session->info; // 删除单个session $this->session->unset_userdata('info'); // 同时删除多个值 // $array_items = array('username', 'email'); // $this->session->unset_userdata($array_items);
操作cookie
// 加载辅助函数 $this->load->helper('cookie'); // 添加cookie setcookie("name", 'lds', 86500); // or $this->input->set_cookie("name", 'lds', 60); // 获取cookie $name = get_cookie('name'); // 删除一条 Cookie delete_cookie('name'); // 删除多条 Cookie delete_cookie(['name', 'email']);