찾다
백엔드 개발PHP 튜토리얼PHP实现日志处理类库_PHP教程

PHP实现日志处理类库_PHP教程

Jul 13, 2016 am 10:39 AM
aspnet소프트웨어 프로그래밍

继上篇文章【微信开发之微电商网站】技术笔记之一,昨日做了日志处理的功能。

对于现在的应用程序来说,日志的重要性是不言而喻的。很难想象没有任何日志记录功能的应用程序运行在生产环境中。日志所能提供的功能是多种多样的,包括记录程序运行时产生的错误信息、状态信息、调试信息和执行时间信息等。在生产环境中,日志是查找问题来源的重要依据。应用程序运行时的产生的各种信息,都应该通过日志类库来进行记录

废话不多说了,附上日志类库的源代码: 

<span   1</span> <span /*</span><span *
</span><span   2</span> <span  * 日志处理类
</span><span   3</span> <span  * 
</span><span   4</span> <span  * @since alpha 0.0.1
</span><span   5</span> <span  * @date 2014.03.04
</span><span   6</span> <span  * @author genialx
</span><span   7</span> <span  * 
</span><span   8</span>  <span */</span>
<span   9</span>  
<span  10</span> <span class</span> <span Log</span><span {
</span><span  11</span>      
<span  12</span>     <span //</span><span 单例模式</span>
<span  13</span>     <span private</span> <span static</span> <span $instance</span>    = <span NULL</span><span ;
</span><span  14</span>     <span //</span><span 文件句柄</span>
<span  15</span>     <span private</span> <span static</span> <span $handle</span>      = <span NULL</span><span ;
</span><span  16</span>     <span //</span><span 日志开关</span>
<span  17</span>     <span private</span> <span $log_switch</span>     = <span NULL</span><span ;
</span><span  18</span>     <span //</span><span 日志相对目录</span>
<span  19</span>     <span private</span> <span $log_file_path</span>      = <span NULL</span><span ;
</span><span  20</span>     <span //</span><span 日志文件最大长度,超出长度重新建立文件</span>
<span  21</span>     <span private</span> <span $log_max_len</span>        = <span NULL</span><span ;
</span><span  22</span>     <span //</span><span 日志文件前缀,入 log_0</span>
<span  23</span>     <span private</span> <span $log_file_pre</span>       = 'log_'<span ;
</span><span  24</span>  
<span  25</span>          
<span  26</span>     <span /*</span><span *
</span><span  27</span> <span      * 构造函数
</span><span  28</span> <span      * 
</span><span  29</span> <span      * @since alpha 0.0.1
</span><span  30</span> <span      * @date 2014.02.04
</span><span  31</span> <span      * @author genialx
</span><span  32</span>      <span */</span>
<span  33</span>     <span protected</span> <span function</span> __construct(){<span //</span><span 注意:以下是配置文件中的常量,请读者自行更改</span>
<span  34</span>          
<span  35</span>         <span $this</span>->log_file_path     =<span  LOG_FILE_PATH;
</span><span  36</span>          
<span  37</span>         <span $this</span>->log_switch     =<span  LOG_SWITCH;  
</span><span  38</span>      
<span  39</span>         <span $this</span>->log_max_len    =<span  LOG_MAX_LEN;
</span><span  40</span>      
<span  41</span> <span     }
</span><span  42</span>      
<span  43</span>     <span /*</span><span *
</span><span  44</span> <span      * 单利模式
</span><span  45</span> <span      * 
</span><span  46</span> <span      * @since alpha 0.0.1
</span><span  47</span> <span      * @date 2014.02.04
</span><span  48</span> <span      * @author genialx
</span><span  49</span>      <span */</span>
<span  50</span>     <span public</span> <span static</span> <span function</span><span  get_instance(){
</span><span  51</span>         <span if</span>(!self::<span $instance</span><span  instanceof self){
</span><span  52</span>             self::<span $instance</span> = <span new</span><span  self;
</span><span  53</span> <span         }
</span><span  54</span>         <span return</span> self::<span $instance</span><span ;
</span><span  55</span> <span     }
</span><span  56</span>      
<span  57</span>     <span /*</span><span *
</span><span  58</span> <span      * 
</span><span  59</span> <span      * 日志记录
</span><span  60</span> <span      * 
</span><span  61</span> <span      * @param int $type  0 -> 记录(THING LOG) / 1 -> 错误(ERROR LOG)
</span><span  62</span> <span      * @param string $desc
</span><span  63</span> <span      * @param string $time
</span><span  64</span> <span      * 
</span><span  65</span> <span      * @since alpha 0.0.1
</span><span  66</span> <span      * @date 2014.02.04
</span><span  67</span> <span      * @author genialx
</span><span  68</span> <span      * 
</span><span  69</span>      <span */</span>
<span  70</span>     <span public</span> <span function</span> <span log</span>(<span $type</span>,<span $desc</span>,<span $time</span><span ){
</span><span  71</span>         <span if</span>(<span $this</span>-><span log_switch){
</span><span  72</span>              
<span  73</span>             <span if</span>(self::<span $handle</span> == <span NULL</span><span ){
</span><span  74</span>                 <span $filename</span> = <span $this</span>->log_file_pre . <span $this</span>-><span get_max_log_file_suf();
</span><span  75</span>                 self::<span $handle</span> = <span fopen</span>(<span $this</span>->log_file_path . <span $filename</span>, 'a'<span );
</span><span  76</span> <span             }
</span><span  77</span>             <span switch</span>(<span $type</span><span ){
</span><span  78</span>                 <span case</span> 0:
<span  79</span>                     <span fwrite</span>(self::<span $handle</span>, 'THING LOG:' . ' ' . <span $desc</span> . ' ' . <span $time</span> . <span chr</span>(13<span ));
</span><span  80</span>                     <span break</span><span ;
</span><span  81</span>                 <span case</span> 1:
<span  82</span>                     <span fwrite</span>(self::<span $handle</span>, 'ERROR LOG:' . ' ' . <span $desc</span> . ' ' . <span $time</span> . <span chr</span>(13<span ));
</span><span  83</span>                     <span break</span><span ;
</span><span  84</span>                 <span default</span>:
<span  85</span>                     <span fwrite</span>(self::<span $handle</span>, 'THING LOG:' . ' ' . <span $desc</span> . ' ' . <span $time</span> . <span chr</span>(13<span ));
</span><span  86</span>                     <span break</span><span ;
</span><span  87</span> <span             }
</span><span  88</span>              
<span  89</span> <span         }
</span><span  90</span> <span     }
</span><span  91</span>      
<span  92</span>     <span /*</span><span *
</span><span  93</span> <span      * 获取当前日志的最新文档的后缀
</span><span  94</span> <span      * 
</span><span  95</span> <span      * @since alpha 0.0.1
</span><span  96</span> <span      * @date 2014.02.04
</span><span  97</span> <span      * @author genialx
</span><span  98</span>      <span */</span>
<span  99</span>     <span private</span> <span function</span><span  get_max_log_file_suf(){
</span><span 100</span>         <span $log_file_suf</span> = <span null</span><span ;
</span><span 101</span>         <span if</span>(<span is_dir</span>(<span $this</span>-><span log_file_path)){
</span><span 102</span>             <span if</span>(<span $dh</span> = <span opendir</span>(<span $this</span>-><span log_file_path)){
</span><span 103</span>                 <span while</span>((<span $file</span> = <span readdir</span>(<span $dh</span>)) != <span FALSE</span><span ){
</span><span 104</span>                     <span if</span>(<span $file</span> != '.' && <span $file</span> != '..'<span ){
</span><span 105</span>                         <span if</span>(<span filetype</span>( <span $this</span>->log_file_path . <span $file</span>) == 'file'<span ){
</span><span 106</span>                             <span $rs</span> = <span split</span>('_', <span $file</span><span );
</span><span 107</span>                             <span if</span>(<span $log_file_suf</span> < <span $rs</span>[1<span ]){
</span><span 108</span>                                 <span $log_file_suf</span> = <span $rs</span>[1<span ];
</span><span 109</span> <span                             }
</span><span 110</span> <span                         }
</span><span 111</span> <span                     }
</span><span 112</span> <span                 }
</span><span 113</span>                  
<span 114</span>                 <span if</span>(<span $log_file_suf</span> == <span NULL</span><span ){
</span><span 115</span>                     <span $log_file_suf</span> = 0<span ;
</span><span 116</span> <span                 }
</span><span 117</span>                 <span //</span><span 截断文件</span>
<span 118</span>                 <span if</span>( <span file_exists</span>(<span $this</span>->log_file_path . <span $this</span>->log_file_pre . <span $log_file_suf</span>) && <span filesize</span>(<span $this</span>->log_file_path . <span $this</span>->log_file_pre . <span $log_file_suf</span>) >= <span $this</span>-><span log_max_len){
</span><span 119</span>                     <span $log_file_suf</span> = <span intval</span>(<span $log_file_suf</span>) + 1<span ;
</span><span 120</span> <span                 }
</span><span 121</span>                  
<span 122</span>                 <span return</span> <span $log_file_suf</span><span ;
</span><span 123</span> <span             }   
</span><span 124</span> <span         }
</span><span 125</span>          
<span 126</span>         <span return</span> 0<span ;
</span><span 127</span>          
<span 128</span> <span     }
</span><span 129</span>      
<span 130</span>     <span /*</span><span *
</span><span 131</span> <span      * 关闭文件句柄
</span><span 132</span> <span      * 
</span><span 133</span> <span      * @since alpha 0.0.1
</span><span 134</span> <span      * @date 2014.02.04
</span><span 135</span> <span      * @author genialx
</span><span 136</span>      <span */</span>
<span 137</span>     <span public</span> <span function</span><span  close(){
</span><span 138</span>         <span fclose</span>(self::<span $handle</span><span );
</span><span 139</span> <span     }
</span><span 140</span> }

 

功能说明:
该日志类利用单例模式,节省资源。自行判断文件大小,超出指定大小则按序自行创建文件。如:文件log_0大于指定大小,则重新创建log_1文件(注意:创建文件是安装文件名后缀的数字的,请勿随意更改日志文件名)。

有待优化:没有指定文件的最大个数,所以定期要手动删除过多的日志文件。


调用示例:

<span 1</span> <span //</span><span LOG</span>
<span 2</span> <span $L</span> = <span Log</span>::<span get_instance();
</span><span 3</span> <span //</span><span 第一个参数 int 0代表事件记录(THING LOG:),1代表错误记录(ERROR LOG:)
</span><span 4</span> <span //第二个参数 string 描述文字
</span><span 5</span> <span //第三个参数 string 时间</span>
<span 6</span> <span $L</span>-><span log</span>(1,'日志描述', <span date</span>('Y-n-j H:m:s'<span ));
</span><span 7</span> <span $L</span>->close();

 

感谢您的查阅!

文章来源:http://www.ihuxu.com/p/223.html

微信公众号(每日分享有价值的互联网资讯):胡旭个人博客

新浪微博:@身边的互联网

编程讨论群:235173087

QQ:2252065614

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/732360.htmlTechArticle继上篇文章 【微信开发之微电商网站】技术笔记之一 ,昨日做了日志处理的功能。 对于现在的应用程序来说,日志的重要性是不言而喻的。...
성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
PHP의 지속적인 사용 : 지구력의 이유PHP의 지속적인 사용 : 지구력의 이유Apr 19, 2025 am 12:23 AM

여전히 인기있는 것은 사용 편의성, 유연성 및 강력한 생태계입니다. 1) 사용 편의성과 간단한 구문은 초보자에게 첫 번째 선택입니다. 2) 웹 개발, HTTP 요청 및 데이터베이스와의 우수한 상호 작용과 밀접하게 통합되었습니다. 3) 거대한 생태계는 풍부한 도구와 라이브러리를 제공합니다. 4) 활성 커뮤니티와 오픈 소스 자연은 새로운 요구와 기술 동향에 맞게 조정됩니다.

PHP 및 Python : 유사점과 차이점을 탐구합니다PHP 및 Python : 유사점과 차이점을 탐구합니다Apr 19, 2025 am 12:21 AM

PHP와 Python은 웹 개발, 데이터 처리 및 자동화 작업에 널리 사용되는 고급 프로그래밍 언어입니다. 1.PHP는 종종 동적 웹 사이트 및 컨텐츠 관리 시스템을 구축하는 데 사용되며 Python은 종종 웹 프레임 워크 및 데이터 과학을 구축하는 데 사용됩니다. 2.PHP는 Echo를 사용하여 콘텐츠를 출력하고 Python은 인쇄를 사용합니다. 3. 객체 지향 프로그래밍을 지원하지만 구문과 키워드는 다릅니다. 4. PHP는 약한 유형 변환을 지원하는 반면, 파이썬은 더 엄격합니다. 5. PHP 성능 최적화에는 Opcache 및 비동기 프로그래밍 사용이 포함되며 Python은 Cprofile 및 비동기 프로그래밍을 사용합니다.

PHP와 Python : 다른 패러다임이 설명되었습니다PHP와 Python : 다른 패러다임이 설명되었습니다Apr 18, 2025 am 12:26 AM

PHP는 주로 절차 적 프로그래밍이지만 객체 지향 프로그래밍 (OOP)도 지원합니다. Python은 OOP, 기능 및 절차 프로그래밍을 포함한 다양한 패러다임을 지원합니다. PHP는 웹 개발에 적합하며 Python은 데이터 분석 및 기계 학습과 같은 다양한 응용 프로그램에 적합합니다.

PHP와 Python : 그들의 역사에 깊은 다이빙PHP와 Python : 그들의 역사에 깊은 다이빙Apr 18, 2025 am 12:25 AM

PHP는 1994 년에 시작되었으며 Rasmuslerdorf에 의해 개발되었습니다. 원래 웹 사이트 방문자를 추적하는 데 사용되었으며 점차 서버 측 스크립팅 언어로 진화했으며 웹 개발에 널리 사용되었습니다. Python은 1980 년대 후반 Guidovan Rossum에 의해 개발되었으며 1991 년에 처음 출시되었습니다. 코드 가독성과 단순성을 강조하며 과학 컴퓨팅, 데이터 분석 및 기타 분야에 적합합니다.

PHP와 Python 중에서 선택 : 가이드PHP와 Python 중에서 선택 : 가이드Apr 18, 2025 am 12:24 AM

PHP는 웹 개발 및 빠른 프로토 타이핑에 적합하며 Python은 데이터 과학 및 기계 학습에 적합합니다. 1.PHP는 간단한 구문과 함께 동적 웹 개발에 사용되며 빠른 개발에 적합합니다. 2. Python은 간결한 구문을 가지고 있으며 여러 분야에 적합하며 강력한 라이브러리 생태계가 있습니다.

PHP 및 프레임 워크 : 언어 현대화PHP 및 프레임 워크 : 언어 현대화Apr 18, 2025 am 12:14 AM

PHP는 현대화 프로세스에서 많은 웹 사이트 및 응용 프로그램을 지원하고 프레임 워크를 통해 개발 요구에 적응하기 때문에 여전히 중요합니다. 1.PHP7은 성능을 향상시키고 새로운 기능을 소개합니다. 2. Laravel, Symfony 및 Codeigniter와 같은 현대 프레임 워크는 개발을 단순화하고 코드 품질을 향상시킵니다. 3. 성능 최적화 및 모범 사례는 응용 프로그램 효율성을 더욱 향상시킵니다.

PHP의 영향 : 웹 개발 및 그 이상PHP의 영향 : 웹 개발 및 그 이상Apr 18, 2025 am 12:10 AM

phphassignificallyimpactedwebdevelopmentandextendsbeyondit

스칼라 유형, 반환 유형, 노조 유형 및 무효 유형을 포함한 PHP 유형의 힌트 작업은 어떻게 작동합니까?스칼라 유형, 반환 유형, 노조 유형 및 무효 유형을 포함한 PHP 유형의 힌트 작업은 어떻게 작동합니까?Apr 17, 2025 am 12:25 AM

PHP 유형은 코드 품질과 가독성을 향상시키기위한 프롬프트입니다. 1) 스칼라 유형 팁 : PHP7.0이므로 int, float 등과 같은 기능 매개 변수에 기본 데이터 유형을 지정할 수 있습니다. 2) 반환 유형 프롬프트 : 기능 반환 값 유형의 일관성을 확인하십시오. 3) Union 유형 프롬프트 : PHP8.0이므로 기능 매개 변수 또는 반환 값에 여러 유형을 지정할 수 있습니다. 4) Nullable 유형 프롬프트 : NULL 값을 포함하고 널 값을 반환 할 수있는 기능을 포함 할 수 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경