現在一言コメントを投稿できる掲示板を実装しているのですが、リロードするとフォームが送信されてしまいます。そこで、$_SERVER['REQUEST_METHOD'] == 'POST'
と記述したのですが、二重投稿されてしまいます。
PHP
1<?php 2 3$dataFile = 'bbs.dat'; 4 5// CSRF対策 6 7session_start(); 8 9function setToken() { 10 $token = sha1(uniqid(mt_rand(), true)); 11 $_SESSION['token'] = $token; 12} 13 14function checkToken() { 15 if (empty($_SESSION['token']) || ($_SESSION['token'] != $_POST['token'])) { 16 echo "不正なPOSTが行われました!"; 17 exit; 18 } 19} 20 21function h($s) { 22 return htmlspecialchars($s, ENT_QUOTES, 'UTF-8'); 23} 24 25if ($_SERVER['REQUEST_METHOD'] == 'POST' && 26 isset($_POST['message']) && 27 isset($_POST['user'])) { 28 29 checkToken(); 30 31 $message = trim($_POST['message']); 32 $user = trim($_POST['user']); 33 34 if ($message !== '') { 35 36 $user = ($user === '') ? 'ななしさん' : $user; 37 38 $message = str_replace("\t", ' ', $message); 39 $user = str_replace("\t", ' ', $user); 40 41 $postedAt = date('Y-m-d H:i:s'); 42 43 $newData = $message . "\t" . $user . "\t" . $postedAt. "\n"; 44 45 $fp = fopen($dataFile, 'a'); 46 fwrite($fp, $newData); 47 fclose($fp); 48 } 49} else { 50 setToken(); 51} 52 53$posts = file($dataFile, FILE_IGNORE_NEW_LINES); 54 55$posts = array_reverse($posts); 56 57?> 58<!DOCTYPE html> 59<html lang="ja"> 60<head> 61 <meta charset="utf-8"> 62 <title>簡易掲示板</title> 63</head> 64<body> 65 <h1>簡易掲示板</h1> 66 <form action="" method="post"> 67 message: <input type="text" name="message"> 68 user: <input type="text" name="user"> 69 <input type="submit" value="投稿"> 70 <input type="hidden" name="token" value="<?php echo h($_SESSION['token']); ?>"> 71 </form> 72 <h2>投稿一覧(<?php echo count($posts); ?>件)</h2> 73 <ul> 74 <?php if (count($posts)) : ?> 75 <?php foreach ($posts as $post) : ?> 76 <?php list($message, $user, $postedAt) = explode("\t", $post); ?> 77 <li><?php echo h($message); ?> (<?php echo h($user); ?>) - <?php echo h($postedAt); ?></li> 78 <?php endforeach; ?> 79 <?php else : ?> 80 <li>まだ投稿はありません。</li> 81 <?php endif; ?> 82 </ul> 83</body> 84</html>
「PHP リロード 多重送信」「PHP リロード対策」等のキーワードでgoogle検索やteratail内検索すると、参考になりそうな記事がいくつもひっかりますが、読んでみましたか?
読んだ上でifで$_SERVER['REQUEST_METHOD'] == 'POST' postされたときになる様な仕組みにしたのですが、なぜそれでは意図した結果にならないのか、またその対策を質問したい為今回質問させていただきました。
回答3件
あなたの回答
tips
プレビュー