Zend_View-Migration.xml 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 17172 -->
  4. <sect1 id="zend.view.migration">
  5. <title>以前のバージョンからの移行</title>
  6. <para>
  7. この章では、主に <classname>Zend_View</classname> での過去との互換性のない変更について説明します。
  8. 以前のバージョンからの移行の助けになることでしょう。
  9. </para>
  10. <sect2 id="zend.view.migration.zf5748">
  11. <title>1.7.5 より前のバージョンからの移行</title>
  12. <para>
  13. Zend Framework 開発陣は、1.7.5 より前のバージョンにおいて
  14. <methodname>Zend_View::render()</methodname> メソッドにローカルファイル読み込み
  15. (Local File Inclusion: LFI) 脆弱性の問題があることに気づきました。
  16. 1.7.5 より前のバージョンでは、このメソッドはデフォルトで
  17. 親ディレクトリを指す記法 ("../" や "..\")
  18. を含むビュースクリプトも指定できてしまいます。
  19. フィルタリングをしていないユーザ入力が <methodname>render()</methodname>
  20. メソッドに渡されると、LFI 攻撃を受ける可能性が出てきます。
  21. </para>
  22. <programlisting language="php"><![CDATA[
  23. // $_GET['foobar'] = '../../../../etc/passwd' だったら……
  24. echo $view->render($_GET['foobar']); // LFI
  25. ]]></programlisting>
  26. <para>
  27. <classname>Zend_View</classname> は、このようなビュースクリプトがリクエストされると
  28. デフォルトで例外を発生させるようになりました。
  29. </para>
  30. <sect3 id="zend.view.migration.zf5748.disabling">
  31. <title>render() メソッドにおける LFI 保護機能の無効化</title>
  32. <para>
  33. 多くの開発者から「ユーザの入力では<emphasis>ない</emphasis>
  34. 場面で、意図的にこれらの記法を使っていることもある」という指摘を受けたため、
  35. 特別なフラグを用意してデフォルトの保護機能を無効化できるようにしました。
  36. 無効化する方法は二通りあります。コンストラクタのオプションで
  37. 'lfiProtectionOn' キーを指定するか、あるいは
  38. <methodname>setLfiProtection()</methodname> メソッドをコールします。
  39. </para>
  40. <programlisting language="php"><![CDATA[
  41. // コンストラクタでの無効化
  42. $view = new Zend_View(array('lfiProtectionOn' => false));
  43. // メソッドコールによる無効化
  44. $view = new Zend_View();
  45. $view->setLfiProtection(false);
  46. ]]></programlisting>
  47. </sect3>
  48. </sect2>
  49. </sect1>
  50. <!--
  51. vim:se ts=4 sw=4 et:
  52. -->