本文執行個體總結了CI架構常用經典操作類。分享給大家供大家參考,具體如下:
1. 超級對象中的URI
CI_URI類的解析url的相關資訊
直接使用$this->uri可以使用它的相關屬性
system/core/URI.php檔案中
部分常用屬性:
(1) 分段擷取url相關資訊
$this->uri->segment(4);//擷取url中pathinfo//的第四段的值
入口檔案.php/控制器/動作/參數1/參數2/...
(2) 通過方法中的形參傳參
需要設預設值和順序要注意
index.php/user/index/3/zhangsan
public function index($id=0,$name=''){ echo $id,$name;}
2.CI控制器的擴充
在application/core/檔案夾下面
添加自己的擴充控制器
class MY_Controller extends CI_Controller{ public function __construct(){ parent::__construct }}
配置模型首碼
$config['subclass_prefix']='MY_';//預設值
3.模型的相關操作
檔案名稱全小寫,類名首字母大寫
建議類名加上 _model尾碼
在控制器中載入模型:
在construct中加入:
$this->load->model('User_model');$this->User_model->get();
為模型起別名
$this->load->model('User_model','user');$this->user->get();
4.url中的常用函數
(1)協助我們組建控制器
$this->load->helper('url');site_url('控制器/方法');
(2)圖片路徑的使用
$this->load->helper('url');
upload/a.jpg" />
可以在autoload.php中配置自動載入
$autoload['helper']加入url
5. CI中的路由與偽靜態
(1) 路由偽靜態
$router['show/([\d]+)\.html']='article/show/$1';article/show/5.html => article/show/5;
(2) 隱藏入口檔案
#開啟apache的rewrite模組#在根目錄中放入.htaccess檔案進行重寫RewriteEngine onRewriteCond %{REQUEST_FILENAME} !-dRewriteCond %{REQUEST_FILENAME} !-fRewriteRule ^(.*)$ index.php/$1 [QSA,PT,L]
6. CI中的分頁
//模型中操作//裝載分頁類檔案$this->load->library('pagination');$this->load->helper(url);//分頁連結$config['base_url'] = site_url('user/test');//總記錄條數$config['total_rows'] = 100;//每頁顯示10條資料$config['per_page'] = 10;//位移量$offset_limit = intval($this->uri->segment(3));$this->pagination->initialize($config);echo $this->pagination->create_links();
分頁中按鈕的定製(注意在初始化之前配置好)
$config['first_link'] = '首頁';...$config['uri_segment'] =3;//分頁資料查詢位移量
在url的哪一段上,對應上面的$offset
預設是3,否則需要修改對應值
7. CI 中session的使用
//載入session庫$this->load->library('session');
(1)擷取系統session
//比如擷取用戶端的ip地址$this->session->userdata('ip_address');
(2) 添加自訂session
//添加$this->session->set_userdata('some_name', 'some_value');//擷取$this->session->userdata('some_name');//刪除$this->session->unset_userdata('some_name');
(3)閃出資料 (取出一次後失效)
//添加$this->session->set_flashdata('item', 'value');//擷取$this->session->flashdata('item');
登入資料中 返回登入前的那一個頁面的url可以記錄下來,
注意:一次性的資料,讀取一次後會自動銷毀。
為了確保安全,在config.php產生隨機加密的字串中加入
$config['encryption_key']="fjkdsffjkhjd#kjh";
是否要將cookie加密
$config['sess_encrypt_cookie'] =TRUE;
8. CI中的檔案上傳
上傳處理:
$config['upload_path']="./upload";$config['allowed_types']='gif|jpeg|jpg';$this->load->library('upload',$config);$this->upload->do_upload('pic');
檔案上傳的資料
$filedata = $this->upload->data();
9. CI中的驗證碼
//產生驗證碼$this->load->helper('captcha');$this->load->helper('url');$vals = array( 'word'=>rand(1000,9999), 'img_path'=>'./captcha/', 'img_url'=>base_url().'/captcha/' 'img_width'=>'150', 'img_height'=>'100', 'expiration'=>7200);$cap = create_captcha($vals);echo $cap['image'];//將驗證碼擷取的數字放在session中session_start();$_SESSION['cap'] = $cap['word'];
更多關於CodeIgniter相關內容感興趣的讀者可查看本站專題:《codeigniter入門教程》、《CI(CodeIgniter)架構進階教程》、《php優秀開發架構總結》、《ThinkPHP入門教程》、《ThinkPHP常用方法總結》、《Zend FrameWork架構入門教程》、《php物件導向程式設計入門教程》、《php+mysql資料庫操作入門教程》及《php常見資料庫操作技巧匯總》
希望本文所述對大家基於CodeIgniter架構的PHP程式設計有所協助。