最近幾天用CI寫一個項目,可是配置控制器的時候遇到問題。先後臺控制器分離,在3.x版本不能直接實現,可是在2.X版本是能夠的。
php
本機環境是wnmp 而線上測試機是lamp ,php版本和mysql的版本也是不一樣的,遇到好多小問題。好比,加載數據庫一直出問題,只要用$this->load->database(),之後的代碼就直接至關於被die掉了,顯示空白頁。網上搜了好多,可是大多數都是由於mysql的配置項沒開啓,我這裏的已經啓用了,找了很久未果。看CI框架system裏的代碼排查,(數據庫的問題,直接把全部的@抑制符去掉,能夠顯示數據庫報錯),結果發現是鏈接數據庫設置編碼的問題。
mysql
<?php //system/database/drivers/mysql/mysql_driver.php裏面的 function db_set_charset($charset, $collation) { if ( ! isset($this->use_set_names)) { // mysql_set_charset() requires PHP >= 5.2.3 and MySQL >= 5.0.7, use SET NAMES as fallback $this->use_set_names = (version_compare(PHP_VERSION, '5.2.3', '>=') && version_compare(mysql_get_server_info(), '5.0.7', '>=')) ? FALSE : TRUE; } if ($this->use_set_names === TRUE) { return @mysql_query("SET NAMES '".$this->escape_str($charset)."' COLLATE '".$this->escape_str($collation)."'", $this->conn_id); } else { //線上php版本較低跳到這個分支,然而下面的函數並無效果;才致使每次加載數據庫都失敗 //手動設置下編碼便可 return @mysql_set_charset($charset, $this->conn_id); } } ?>
CI仍是有許多技巧並不清楚,之前都是粗略的會用,也沒去看框架的代碼sql
好比 CI 的url輔助函數裏面的,site_url(),base_url(),redirect()比設置congfig好用多了。數據庫
還有CI能夠全局加載自定義函數,須要放置在 core/common.php 之前有些函數都是經過輔助函數來加載的框架
CI的表單驗證類看起來還能夠,沒用過。函數
暫時更到這裏,一邊學習一邊添加吧。學習