質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.50%

  • PHP

    20358questions

    PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

  • HTML

    8980questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

PHPの簡易掲示板での編集機能

受付中

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 126

mizuiti0616

score 2

現在PHPとHTMLを使い簡易掲示板を作成しているのですが2点ほど実装できない問題が発生しているので質問させていただきます。

<?php
$lines = file('keijiban.txt');


if ($_POST['write'] && $_POST['mode'] != 'editmode') {

  //投稿番号をつくる処理
  $items = explode("\t", $lines);
  $no = count($lines) + 1 ;

  //データを変数に格納
  $name = $_POST['name'];
  $comment = $_POST['comment'];
  $pass = $_POST['pass'];
  $time = date("Y/m/d H:i:s");

  //データを文字列でつくる処理
  $data = "$no\t$name\t$comment\t$pass\t$time\n";
  array_push($lines, $data);
}

//削除の処理
if ($_POST['delete']) {
  for ($i = 0; $i < count($lines); $i++) {
    $items = explode("\t", $lines[$i]);
    if ($items[0] == $_POST['delno'] && $items[3] == $_POST['delkey']) {
      array_splice($lines, $i, 1);
    }
  }
}

//編集ボタンを押したときの処理
if ($_POST['edit']) {
  for ($i = 0; $i < count($lines); $i++) {
    $items = explode("\t", $lines[$i]);
    if ($items[0] == $_POST['edino'] && $items[3] == $_POST['edikey']) {
      $edit_editer = $items[0];
      $edit_name = $items[1];
      $edit_comment = $items[2];
      $edit_pass = $items[3];
    }
  }
}

//編集内容を変更するときの処理
if ($_POST['mode'] == 'editmode') {
  for ($i = 0; $i < count($lines); $i++) {
    $items = explode("\t", $lines[$i]);
    if ($items[0] == $_POST['edino']) {
      $items[1] = $_POST['name'];
      $items[2] = $_POST['comment'];
      $items[3] = $_POST['pass'];

      $lines[$i] = "$items[0]\t$items[1]\t$items[2]\t$items[3]\t$items[4]\n";

    }
  }
}


//書き込みも編集もしないときの処理
if ($_POST['write'] || $_POST['delete']) {
  $fp = fopen('keijiban.txt', 'w');
  foreach($lines as $line) fputs($fp, $line);
  fclose($fp);
}

?>



<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="utf-8">
<title>簡易掲示板</title>
</head>
<body>
<form method="post" action="">
お名前:<input type="text" name="name" value="<?php echo $edit_name; ?>"><br>
コメント:<input type="text" name="comment" value="<?php echo $edit_comment; ?>"><br>
<?php
if($_POST['edino']){
  $edino = $_POST['edino'];
echo '<input type="hidden" name="mode" value="editmode">';
echo '編集番号<input type="text" name="edino" value = echo $edit_editer> ';
}
?>

パスワード:<input type="password" name="pass" value="<?php echo $edit_pass; ?>"><br>
<input type="submit" name="write" value="送信">
</form>
<hr>

<form method="post" action="">
削除指定番号:<input type="text" name="delno">
 パスワード: <input type="password" name="delkey">
 <input type="submit" name="delete" value="削除">
</form>

<form method="post" action="">
編集指定番号:<input type="text" name="edino">
 パスワード: <input type="password" name="edikey">
 <input type="submit" name="edit" value="編集">
</form>
<hr>

<?php
foreach($lines as $line) {
  $line = trim($line);
  $items = explode("\t", $line);
  print "{$items[0]} ";
  print "   $items[1]";
  print " &nbsp; ";
  print "{$items[2]}";
  print "   {$items[4]}<hr> \n";

}
?>

</body>
</html>


実装したい機能は2点です
・編集番号を指定し、編集を押した際に上の編集指定番号に番号が表示されるようにしたい。
・テキストファイルで掲示板の投稿を保存しているが、そちらの方だけ変数と変数の間に<>という区切り文字を入れて保存したい。例:投稿番号<>名前<>コメント<>日時

この2つです。よろしくお願いします><

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • kei344

    2018/07/24 17:06

    https://teratail.com/questions/137294 この質問と内容が同じです。teratailは質問内容の編集ができるので、変更がある場合は新しい質問をするのではなく編集してください。また、こちらの質問を削除されるよう運営に連絡されることをお勧めします。https://teratail.com/contact/input

    キャンセル

  • mts10806

    2018/07/24 17:08

    以前の質問での指摘事項がほとんど反映されていません。

    キャンセル

  • asahina1979

    2018/07/24 17:59

    というか簡易掲示板(PHP)=荒らしじゃ?

    キャンセル

回答 1

+3

パット見で問題点に気づいた。
$no = count($lines) + 1 ;で投稿番号を発番しているようだけど、
投稿を削除したら行数(データ数)も減ってしまうのだけど
そこの仕様はちゃんと考えてあるのだろうかと。
例えば、
1,2,3,4,5番が使われていました、
3番を削除すると1,2,4,5になるけど、行数は4。
4+1で5番を使ってデータを追記すると、
5番のデータが複数存在する状態になるね。
array_splice($lines, $i, 1);なんてコードで配列要素を削除しているんだけど、
そのときに投稿番号を振り直してはいないようだし、
ミスが発生しやすい状況だと思います。
投稿番号を振り直すやり方でやってみるのも一興、
振り直さずに保存しておいて新たな投稿番号を発番するところを工夫するのも一興。

file()関数での読み込み、
fopen()&fputs()&fclose()での書き込み、
なんら排他制御もかかっていないから、
同じタイミングで似たようなアクションがあった場合
簡単にデータファイルが壊れそうですね。

flock()という汎用のファイルロック関数もあるけど、
それを使ったところで読み込みから書き込みまでの一連の処理中に
他のアクションが発生して割り込まない保証もないので、
そういう意味で「簡易掲示板」であって実用性は低いものだと思ってください。

実務的にはトランザクション処理の概念があるデータベースシステムと組み合わせます。

投稿番号は、
データファイルを読み込んで精査して、
例えば使われている投稿番号の最大値+1を使う、
などとすれば、
今読み込んでいるデータの中での投稿番号のダブリは防げそう。
(但しほぼ同じタイミングで似たようなアクションがあった場合においては保証されない。)

データの区切り文字を「<>」にしたいそうだけど、
$data = "$no\t$name\t$comment\t$pass\t$time\n";

$data = "$no<>$name<>$comment<>$pass<>$time\n";
になるだろうし、
$items = explode("\t", $lines[$i]);

$items = explode("<>", $lines[$i]);
になるだろう。

さて、投稿テキスト内に「<>」があった場合どうなるだろうね。
実務に置いては入力されたデータ一つ一つ検証する必要があるよ。
もしも「<>」が入力されたら例えば「&lt;&gt;」に置き換えるようにしようか、
さらに「&lt;&gt;」が入力されたら例えば「&amp;lt;&amp;gt;」に置き換えるようにしようか、
ってところまで考慮しなくちゃいけない。
投稿テキスト内にタブコード\tを含めるのも、<>を含めるのも、
意地悪しようと思えば比較的簡単なことなので
対策を講じる必要があるよ。

さぁがんばって。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.50%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • PHP

    20358questions

    PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

  • HTML

    8980questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。