ホームページ >バックエンド開発 >PHPチュートリアル >同期トークンを含むフォーム ツールキット

同期トークンを含むフォーム ツールキット

WBOY
WBOYオリジナル
2016-07-25 09:09:56972ブラウズ
2011 年の深センでのユニバーシアード大会が近づいていたため、深セン大学はボランティア サービス ステーションを設立したいと考えていました。その奉仕のために私は青年団委員会に逮捕されました。その過程で、私は小さなフォーム ツールキットを作成しました。検証機能は私自身が実装したものではなく、Kohana_Validate (Kohana V3.0x ブランチ) に依存しています。しかし、私は「J2EE Disgusting Mode」の指示​​に従って、フォームの繰り返しの送信を防ぐための同期トークンを取得しました。このコンポーネントは抽象化レイヤーも設定します。検証コードもトークンのサブクラスとして統合できると思います。でも、今は時間がないので、先にコードを共有して、販売されるのを待ちます~
  1. namespace Form;
  2. use VolunteerFormAbstractForm;
  3. class NewsPoster extends AbstractForm
  4. {
  5. /**
  6. * プリセットフォーム要素をすべて追加します
  7. *
  8. * @abstract
  9. */
  10. public function bindingAllElement()
  11. {
  12. $this->bindToken(' valid_token')
  13. ->addElement('ニュース タイトル', 'タイトル',
  14. array(
  15. 'not_empty' => null,
  16. 'max_length' => array(60)
  17. ),
  18. array(
  19. 'trim ' => null,
  20. 'htmlspecialchars' => array(ENT_QUOTES),
  21. ))
  22. ->addElement('短縮URL', 'urlName',
  23. array(
  24. 'max_length' => array(50 ) ,
  25. 'regex' => array('~^[a-zA-Z0-9-%]+$~')
  26. ),
  27. array(
  28. 'trim' => null,
  29. 'urlencode' = > ; null,
  30. ))
  31. ->addElement('keyword', 'keyWords',
  32. array(
  33. 'max_length' => array(100),
  34. ),
  35. array(
  36. 'trim' => null,
  37. 'htmlspecialchars' => array(ENT_QUOTES),
  38. ))
  39. ->addElement('ニュース著者と記者', 'author',
  40. array(
  41. 'max_length' => array(60),
  42. ),
  43. array(
  44. 'trim' => null,
  45. 'htmlspecialchars' => array(ENT_QUOTES),
  46. ))
  47. ->addElement('ニュースエディタ', 'エディタ',
  48. array(
  49. 'max_length ' = > array(60),
  50. ),
  51. array(
  52. 'trim' => null,
  53. 'htmlspecialchars' => array(ENT_QUOTES),
  54. ))
  55. ->addElement('ニュースソース', 'ソース',
  56. array(
  57. 'max_length' => array(60),
  58. ),
  59. array(
  60. 'trim' => null,
  61. 'htmlspecialchars' => array(ENT_QUOTES),
  62. ))
  63. -> ;addElement('ニュース カテゴリ', 'カテゴリ',
  64. array(
  65. 'not_empty' => null,
  66. 'digit' => null,
  67. 'regex' => array('~^[1- 9] d*$~')
  68. ),
  69. array())
  70. ->addElement('cover image', 'cover_image',
  71. array(),
  72. array(
  73. 'trim' => null,
  74. ' urlencode' => null,
  75. ))
  76. ->addElement('メディア情報が含まれます', 'mediaTag',
  77. array(
  78. 'not_empty' => null,
  79. 'digit' => null,
  80. '正規表現' = > array('~^[0123]$~')
  81. ),
  82. array())
  83. ->addElement('ニュース概要', '概要',
  84. array(
  85. 'max_length' => array (255 ),
  86. ),
  87. array(
  88. 'trim' => null,
  89. 'htmlspecialchars' => array(ENT_QUOTES),
  90. ))
  91. ->addElement('リリースステータス', '状態',
  92. array(
  93. 'not_empty' => null,
  94. 'digit' => null,
  95. 'regex' => array('~^[01]$~')
  96. ),
  97. array())
  98. -> ;addElement ('「ホームページに表示するかどうか」オプション', 'showInHome',
  99. array(
  100. 'boolean' => null,
  101. ),
  102. array())
  103. ->addElement('ニュースコンテンツ', 'content ',
  104. array(
  105. 'not_empty' => null,
  106. ),
  107. array(
  108. 'tidy_parse_string' => array(
  109. array(
  110. 'indent' => true,
  111. 'output-xhtml' => true、
  112. 'clean' => true、
  113. 'drop-font-tags'=> true、
  114. 'show-body-only'=> true
  115. )、'UTF8')、
  116. 'trim' => ; null
  117. ));
  118. }
  119. }
コードをコピーします
  1. public function action_GET()
  2. {
  3. // URL 内の ID を取得します
  4. $id = $this->request->param('id', null);
  5. // トークンを送信しますビューレイヤー (フォームの非表示フィールドに配置)
  6. $this->view['token'] = FormNewsPoster::getToken()->useToken();
  7. }
  8. public function action_POST()
  9. {
  10. $id = $this->request->param('id', null);
  11. $form = FormNewsPoster::factory($_POST);
  12. $form->bindAllElement();
  13. if ($ form- >checkForm()) {
  14. // 検証に合格しました。ドメイン モデルを呼び出して操作を実行します~
  15. $this->view['success'] = true;
  16. } else {
  17. $this->view ['success' ] = false;
  18. // エラー メッセージをビュー レイヤに送り返す
  19. $this->view['message'] = array_values($form->getMessage());
  20. }
  21. }
コードをコピー
同期トークンを含むフォーム ツールキット 同期トークンを含むフォーム ツールキット 同期トークンを含むフォーム ツールキット


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。