Zend_Log-Formatters.xml 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. <sect1 id="zend.log.formatters">
  2. <title>Formatters</title>
  3. <para>
  4. Formatter是一个负责取得一个描述日志事件的<code>event</code>数组并输出一个格式化的日志行的对象.
  5. </para>
  6. <para>
  7. 有些Writer不是面向行的并且不能使用Formatter.一个例子是数据库Writer,它向数据库中直接插入一个事件项.
  8. 对于这样的Writer不支持Formatter,如果你对这样的Writer设置一个Formatter将抛出一个异常.
  9. </para>
  10. <sect2 id="zend.log.formatters.simple">
  11. <title>简单格式化</title>
  12. <para>
  13. <code>Zend_Log_Formatter_Simple</code> 是默认的.当未指定任何formatter时使用.
  14. 默认的配置等同于下面的配置:
  15. <programlisting role="php"><![CDATA[<?php
  16. $format = '%timestamp% %priorityName% (%priority%): %message%' . PHP_EOL;
  17. $formatter = new Zend_Log_Formatter_Simple($format);]]>
  18. </programlisting>
  19. </para>
  20. <para>
  21. 使用Writer的<code>steFormatter()</code>方法在个别的Writer上设置Formatter:
  22. <programlisting role="php"><![CDATA[<?php
  23. $writer = new Zend_Log_Writer_Stream('php://output');
  24. $formatter = new Zend_Log_Formatter_Simple('hello %message%' . PHP_EOL);
  25. $writer->setFormatter($formatter);
  26. $logger = new Zend_Log();
  27. $logger->addWriter($writer);
  28. $logger->info('there');
  29. // outputs "hello there"]]>
  30. </programlisting>
  31. </para>
  32. <para>
  33. <code>Zend_Log_Formatter_Simple</code>的构造函数接受单个参数: 格式化字符串.该字符串包含有单个百分号包裹的键(例如,<code>%message%</code>).
  34. 格式化字符串可以包含来自于任何事件数据数组的键。在 <code>Zend_Log_Formatter_Simple</code> 里使用 DEFAULT_FORMAT 常量,可以获取缺省键。
  35. </para>
  36. </sect2>
  37. <sect2 id="zend.log.formatters.xml">
  38. <title>格式化到XML</title>
  39. <para>
  40. <code>Zend_Log_Formatter_Xml</code>格式化日志数据到XML字符串中.
  41. 默认,它自动地纪录在事件数据数组中的所有项.
  42. <programlisting role="php"><![CDATA[<?php
  43. $writer = new Zend_Log_Writer_Stream('php://output');
  44. $formatter = new Zend_Log_Formatter_Xml();
  45. $writer->setFormatter($formatter);
  46. $logger = new Zend_Log();
  47. $logger->addWriter($writer);
  48. $logger->info('informational message');]]>
  49. </programlisting>
  50. </para>
  51. <para>
  52. 上面的代码输出下面的XML(为清晰添加了空格):
  53. <programlisting role="xml"><![CDATA[
  54. <logEntry>
  55. <timestamp>2007-04-06T07:24:37-07:00</timestamp>
  56. <message>informational message</message>
  57. <priority>6</priority>
  58. <priorityName>INFO</priorityName>
  59. </logEntry>]]>
  60. </programlisting>
  61. </para>
  62. <para>
  63. 可以定制根元素并指定一个到事件数据数组的XML元素映射.
  64. <code>Zend_Log_Formatter_Xml</code>的构造函数接受一个根元素名字
  65. 的字符串作为第一个参数和一个元素映射的关联数组作为第二个参数:
  66. <programlisting role="php"><![CDATA[<?php
  67. $writer = new Zend_Log_Writer_Stream('php://output');
  68. $formatter = new Zend_Log_Formatter_Xml('log', array('msg' => 'message', 'level' => 'priorityName'));
  69. $writer->setFormatter($formatter);
  70. $logger = new Zend_Log();
  71. $logger->addWriter($writer);
  72. $logger->info('informational message');]]>
  73. </programlisting>
  74. 上面的代码改变默认的根元素<code>logEntry</code>为<code>log</code>.
  75. 还可以映射元素<code>msg</code>到事件数据项<code>message</code>,下面是输出结果:
  76. <programlisting role="xml"><![CDATA[
  77. <log>
  78. <msg>informational message</msg>
  79. <level>INFO</level>
  80. </log>]]>
  81. </programlisting>
  82. </para>
  83. </sect2>
  84. </sect1>