继上篇文章【微信开发之微电商网站】技术笔记之一,昨日做了日志处理的功能。
对于现在的应用程序来说,日志的重要性是不言而喻的。很难想象没有任何日志记录功能的应用程序运行在生产环境中。日志所能提供的功能是多种多样的,包括记录程序运行时产生的错误信息、状态信息、调试信息和执行时间信息等。在生产环境中,日志是查找问题来源的重要依据。应用程序运行时的产生的各种信息,都应该通过日志类库来进行记录。
废话不多说了,附上日志类库的源代码:
<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> }
立即学习“PHP免费学习笔记(深入)”;
功能说明:
该日志类利用单例模式,节省资源。自行判断文件大小,超出指定大小则按序自行创建文件。如:文件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();
立即学习“PHP免费学习笔记(深入)”;
感谢您的查阅!
文章来源:http://www.ihuxu.com/p/223.html
微信公众号(每日分享有价值的互联网资讯):胡旭个人博客

新浪微博:@身边的互联网
编程讨论群:235173087
QQ:2252065614
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号