继上篇文章【微信开发之微电商网站】技术笔记之一,昨日做了日志处理的功能。
对于现在的应用程序来说,日志的重要性是不言而喻的。很难想象没有任何日志记录功能的应用程序运行在生产环境中。日志所能提供的功能是多种多样的,包括记录程序运行时产生的错误信息、状态信息、调试信息和执行时间信息等。在生产环境中,日志是查找问题来源的重要依据。应用程序运行时的产生的各种信息,都应该通过日志类库来进行记录。
废话不多说了,附上日志类库的源代码:
<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

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

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

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

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

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

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

phphassignificallyimpactedwebdevelopmentandextendsbeyondit

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


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

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

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경
