CodeIgniter記錄錯誤日誌的方法
這篇文章主要介紹了CodeIgniter記錄錯誤日誌的方法,詳細分析了CodeIgniter框架的文件結構與相應的功能,結合實例分析了CodeIgniter框架記錄錯誤日誌的實現技巧,並分析了隱藏index文件與數據傳輸等技巧,總結非常全面,需要的朋友可以參考下
本文實例講述了CodeIgniter記錄錯誤日誌的方法。分享給大家供大家參考,具體如下:
CI工作流程:
所有的入口都從根目錄下的index.php進入,確定應用程式所在目錄後,載入codeigniter/CodeIgniter.php 文件,該文件會依序載入以下文件執行整個流程。
index.php:偵測檔案路徑,載入codeigniter.php檔案
#codeigniter.php:載入Common/constants....文件。取得檔案模式、設定計時器、實例化類別(錯誤類別、擴充類別、鉤子類別、系統擴充、設定類別、編碼類別、路由類別、過程類別、輸出類別、安全類別、語言類別、控制器)、載入請求方法、渲染輸出view。
CodeIgniter的一個類別會儲存為一個php文件,類別名稱與檔案名稱同名,它的核心應用類別會在類別名稱前加上"CI_"。
system/core/common.php:包含偵測php版本、檔案權限、載入核心類別、取得設定參數、載入異常/錯誤類別、取得http請求狀態等公用函數
application/config/constants.php:設定檔案權限常數、應用程式巨集定義檔
system/core/Benchmark.php:用來記錄執行時間
system/core/Hooks.php:偵測是否有鉤子物件呼叫
system/core/Config.php: 為管理設定檔提供方法,偵測application/config/config.php參數
application/config/config.php:設定全域參數
system/core/URI.php:解析url參數
system/core/Router.php:偵測路由配置,解析HTTP 請求,以決定誰來處理
system/core/Output.php:檢查是否有快取文件,如果存在則直接輸出內容。
system/core/Input.php:過濾HTTP 請求和任何使用者提交的資料
system/core/Long.php:初始化提示語言變數
system/core/conctroller.php:控制輸出類別
##記錄錯誤日誌:
預設程序不記錄錯誤日誌,如果有需要的話可以設定:1、在application/config/config.php中設定:$config['log_threshold'] = 1//(可设置:1/2/3/4)
##如果為0表示不輸出錯誤日誌,具體可查看裡面的介紹;
2、在需要寫入錯誤的頁面調用全域函數log_message('級別','訊息'),等級有三個,一是error,也就是php運行錯誤,二是debug,系統調試,CI本身在很多頁面也加了自己的系統debug,三是info,介紹運行中的一些消息,消息內容自己寫;
3.預設錯誤日誌存放在application/logs/log-[time].php中,它會按日期存放文件,例如:log-2011-6-26表示存入今天的日誌內容,一般情況下為了隱藏日誌內容必須將這個位址挪位,可以在$config['log_path']中設定路徑,依需求最好是完整路徑資訊。
設定自己的全域變數/配置:有時需要定義自己的全過程變數以供在其它地方使用,如自訂的session等,在CI中這項工作也很輕鬆。
1、在application/config/中建立自己的config文件,注意存放文件位置。例如建立一個自己的設定檔mysetting.php,內容,
$config['try'] = 'this is my trying';
#2、在需要呼叫自訂全域變數的地方使用$this->config ->load('settingfile')函數,例如:
$this->config->load('mysetting');
如果有需要也可以透過application/config/autoload.php設定為自動加載。
3、接下來在同一頁面中使用
$this->config->item('varname')
#函數,例如:$this->config->item(' try');會輸出:this is my trying;
上面可以看出,CI中函數呼叫為:$this->filename的形式
,也可以看出CI把整個系統看成一個大的類,然後透過載入、繼承等方式取得相應方法。 更多自訂變數參考:http://codeigniter.org.cn/user_guide/libraries/config.html
其实不管是在用CI还是ZF都有同样一个问题,就是路径的问题。前期,我在用ZF做CMS时,我在.htaccess文件中设置了如遇到js,css,img等资源文件都不重定向。但今天在用CI时,却忘记了,弄了半天都没搞好,登陆CI的中国官方网,终于在论坛高手的帮助下把问题觖决了,在这里把它贴出来,供大家分享。 首先,隐藏url中的index.php文件,这样访问其它目录的时候就不会有http://www.xxx.com/index.php/xxx的样式出现,面是直接http://www.xxx.com/xxx形式,在根目录.htaccess文件里设置(作用是隐藏index.php,有时index.php可能不在根目录,则htaccess须移到index.php所在目录),如下: 这里JS,CSS,IMG等资源文件夹与SYSTEM文件夹放在同一级下,独立放置的好处是不用受htaccess的限制,因为htaccess文件写明Deny from all,即拒绝访问。打开application/config/config.php改写配置: 如果 后面没加'/',则在model_rewrite最后一行应写RewriteRule ^(.*)$ /index.php/$1 [L],在index.php前加一个'/'。然后在JS文件夹中建立ajax.js文件,我在VIEW层中的文件为index.html。这样我要引入JS时,可以用CI自带的BASE_URL来设置,如下: 在controllers里相关控制网页里添加(在其它load之前): 在views表现的index.html里: 复制代码 代码如下: 注:这里url是网站相对URL(好处是可以更改根目录后相对地址不用改变) 这里js文件夹没有重定向,所以可以正常访问,而如果是受限制的页面则比较麻烦了。 好了,CI中引入外部的JS与CSS就这么简单。 注别的说明:“ RewriteCond $1 !^(index\.php|images|js|css|robots\.txt) ”这里代码的意思是:任意你想访问的资源都不被重定向时,都可写在这里。有时,网站没有加载CSS,JS(它的路径都是正确的)时,都是被重定向了,这要注意。 具体可查看CI的中国官论坛 http://codeigniter.org.cn/user_guide/helpers/url_helper.html,URL辅助函数一节, (另外:特别谢谢CI中国官论坛上的Hex 与visvoy ) 数据间的传输: 1、将数据从控制器传入视图 由于控制器controllers在ci中扮演交通警察的角色,其是一个大类,而视图view作为controller类中的一个函数中的函数,所以view可以使用controller中的属性。所以可以这样写: Controller类Test View.php 这种直接使用controllers类中的值的方法虽然可行,却不是ci所提倡的。一般来说在controller中使用$this->load->view()的时候可以通过参数传值给view视图: 这里,把需要传递的数值加入至$data数组,ci在核心类中给自动使用extract()函数把数组“解压”出来,成为一个个变量。所以在view中可以直接这样使用变量: 2、模型与视图的交互 在ci中模型总是用以处理数据,模型中数据处理也是通过controller中转到view,所以最好不要试图模型直接与视图联系。手册中有这样一个例子:RewriteEngine on
RewriteCond $1 !^(index\.php|images|js|css|robots\.txt)
#这里排除了images、js、css目录及index.php、robots.txt文件
RewriteRule ^(.*)$ index.php/$1 [L]
$config['base_url'] = "http://127.0.0.1/";
$config['index_page'] = "index.php";
$config['base_url'] = http://127.0.0.1;
$this->load->helper('url');
http://codeigniter.org.cn/user_guide/general/urls.html,url设置,
http://codeigniter.org.cn/forums/thread-4-1-2.html,Hex关于隐藏index.php的说明,但他在model_rewrite用了index\\.php,我觉得用双反斜杠有误。class Test extends CI_Controller {
public static $test2=''; //定义一个属性
public function __construct(){
parent::__construct();
self::$test2 = $this->load->view('new','',true); //给$test2这个属性赋值
}
public function index() {
$this->load->helper('url');
$this->load->view('anchor');
}
}
<?php
echo Test::$test2; //直接使用类中的值
?>
function index()
{
$data['css'] = $this->css;
$data['base'] = $this->base;
$data['mytitle'] = 'Welcome to this site';
$data['mytext'] = "Hello, $name, now we're getting dynamic!";
$this->load->view('testview', $data); //$data通过参数传递到view
}
echo $css;
class Blog_controller extends CI_Controller {
function blog() {
$this->load->model('Blog'); //载入模型
$data['query'] = $this->Blog->get_last_ten_entries(); //使用模型中的方法,将返回值存入$data数组
$this->load->view('blog', $data); //像上例一样,通过参数传给视图view
}
}
相关推荐:
CI框架(CodeIgniter)实现的数据库增删改查操作总结
以上是CodeIgniter記錄錯誤日誌的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

番茄小說是一款非常熱門的小說閱讀軟體,我們在番茄小說中經常會有新的小說和漫畫可以去閱讀,每一本小說和漫畫都很有意思,很多小伙伴也想著要去寫小說來賺取賺取零用錢,在把自己想要寫的小說內容編輯成文字,那麼我們要怎麼樣在這裡面去寫小說呢?小伙伴們都不知道,那就讓我們一起到本站本站中花點時間來看寫小說的方法介紹。分享番茄小說寫小說方法教學 1、先在手機上打開番茄免費小說app,點擊個人中心——作家中心 2、跳到番茄作家助手頁面——點擊創建新書在小說的結

而後悔莫及、人們常常會因為一些原因不小心刪除某些聯絡人、微信作為一款廣泛使用的社群軟體。幫助用戶解決這個問題,本文將介紹如何透過簡單的方法找回被刪除的聯絡人。 1.了解微信聯絡人刪除機制這為我們找回被刪除的聯絡人提供了可能性、微信中的聯絡人刪除機制是將其從通訊錄中移除,但並未完全刪除。 2.使用微信內建「通訊錄恢復」功能微信提供了「通訊錄恢復」節省時間和精力,使用者可以透過此功能快速找回先前刪除的聯絡人,功能。 3.進入微信設定頁面點選右下角,開啟微信應用程式「我」再點選右上角設定圖示、進入設定頁面,,

七彩虹主機板在中國國內市場享有較高的知名度和市場佔有率,但是有些七彩虹主機板的用戶還不清楚怎麼進入bios進行設定呢?針對這一情況,小編專門為大家帶來了兩種進入七彩虹主機板bios的方法,快來試試吧!方法一:使用u盤啟動快捷鍵直接進入u盤裝系統七彩虹主機板一鍵啟動u盤的快捷鍵是ESC或F11,首先使用黑鯊裝機大師製作一個黑鯊U盤啟動盤,然後開啟電腦,當看到開機畫面的時候,連續按下鍵盤上的ESC或F11鍵以後將會進入到一個啟動項順序選擇的窗口,將遊標移到顯示“USB”的地方,然

手機遊戲成為了人們生活中不可或缺的一部分,隨著科技的發展。它以其可愛的龍蛋形象和有趣的孵化過程吸引了眾多玩家的關注,而其中一款備受矚目的遊戲就是手機版龍蛋。幫助玩家們在遊戲中更好地培養和成長自己的小龍,本文將向大家介紹手機版龍蛋的孵化方法。 1.選擇合適的龍蛋種類玩家需要仔細選擇自己喜歡並且適合自己的龍蛋種類,根據遊戲中提供的不同種類的龍蛋屬性和能力。 2.提升孵化機的等級玩家需要透過完成任務和收集道具來提升孵化機的等級,孵化機的等級決定了孵化速度和孵化成功率。 3.收集孵化所需的資源玩家需要在遊戲中

字體大小的設定成為了重要的個人化需求,隨著手機成為人們日常生活的重要工具。以滿足不同使用者的需求、本文將介紹如何透過簡單的操作,提升手機使用體驗,調整手機字體大小。為什麼需要調整手機字體大小-調整字體大小可以使文字更清晰易讀-適合不同年齡段用戶的閱讀需求-方便視力不佳的用戶使用手機系統自帶字體大小設置功能-如何進入系統設置界面-在在設定介面中找到並進入"顯示"選項-找到"字體大小"選項並進行調整第三方應用調整字體大小-下載並安裝支援字體大小調整的應用程式-開啟應用程式並進入相關設定介面-根據個人

Win11管理員權限取得方法匯總在Windows11作業系統中,管理員權限是非常重要的權限之一,可以讓使用者對系統進行各種操作。有時候,我們可能需要取得管理員權限來完成一些操作,例如安裝軟體、修改系統設定等。下面就為大家總結了一些取得Win11管理員權限的方法,希望能幫助大家。 1.使用快捷鍵在Windows11系統中,可以透過快捷鍵的方式快速開啟命令提

Oracle版本查詢方法詳解Oracle是目前世界上最受歡迎的關聯式資料庫管理系統之一,它提供了豐富的功能和強大的效能,廣泛應用於企業。在進行資料庫管理和開發過程中,了解Oracle資料庫的版本是非常重要的。本文將詳細介紹如何查詢Oracle資料庫的版本信息,並給出具體的程式碼範例。查詢資料庫版本的SQL語句在Oracle資料庫中,可以透過執行簡單的SQL語句

在現今社會,手機已經成為我們生活中不可或缺的一部分。而微信作為我們日常溝通、工作、生活的重要工具,更是經常被使用。然而,在處理不同事務時可能需要分開兩個微信帳號,這就要求手機能夠支援同時登入兩個微信帳號。華為手機作為國內知名品牌,很多人使用,那麼華為手機開啟兩個微信帳號的方法是怎麼樣的呢?下面就來揭秘一下這個方法。首先,要在華為手機上同時使用兩個微信帳號,最簡
