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

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

ただいまの
回答率

90.32%

簡易掲示板の編集機能(配列の差し替え)

受付中

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,824

yu_moto

score 5

簡易掲示板を作っていて、下記のコードで編集機能を実装しようとしているのですが、編集内容として送られてきた配列の値と編集前の配列の値の差し替えが上手くいきません。

下記のコードをどう書き直せば上手くいくのでしょうか。

<?php

    $name = $_POST['name'];
    $name = htmlspecialchars($name);

    $comment = $_POST['comment'];
    $comment = htmlspecialchars($comment);

    $delete = $_POST['delete'];
    $delete = htmlspecialchars($delete);

    $edit = $_POST['edit'];
    $edit = htmlspecialchars($edit);

    $editContents = $_POST['editContents'];
    $editContents = htmlspecialchars($editContents);

    $time = date("Y/m/d H:i:s");

    $line = file("kb.txt");
    $num = count($line);

    $write =  "{". $num . "}<>{" . $name . "}<>{" . $comment . "}<>{" . $time . "}";

    if (!empty($name) && !empty($comment)) {
        $fp = fopen ("./kb.txt","a");
        fputs ($fp, $write."\n");
        fclose ($fp);
    }

    if (!empty($delete)) {
        $delCon = file("kb.txt");
        for ($j = 0; $j < count($delCon) ; $j++) {
            $delData = explode("<>", $delCon[$j]);
            if ($delData[0] == "{".$delete."}") {
                array_splice($delCon, $j, 1);
                file_put_contents("./kb.txt", $delCon);
            }
        }
    }

    if (!empty($edit)) {
        $ediCon = file("kb.txt"); 
        for ($k = 0; $k < count($ediCon); $k++) {
            $ediData = explode("<>", $ediCon[$k]);
            if ($ediData[0] == "{".$edit."}") {
                for($h = 0; $h < count($ediData); $h++){
                    $simEdit[$h] = mb_substr(trim($ediData[$h]), 1, -1);
                }
            }
        }
    }

    if(!empty($editContents)) {
        $edi = file("kb.txt"); 
        for ($l = 0; $l < count($edi); $l++) {
            $ediDatat = explode("<>", $edi[$l]);
            if ($ediDatat[0] == "{".$num."}") {
                //array_replace使用?
                file_put_contents("./kb.txt", $edi);
            }
        }
    }


?>
<!DOCTYPE html>
<html>

<head>
<meta charset="UTF-8">
</head>

<body>
    <form method="POST" action="<?php echo($_SERVER['PHP_SELF']) ?>">
        <label for="name">名前:</label>
        <input type="text" name="name" value="<?php echo $simEdit[1]; ?>"><br><br>

        <label for="comment">コメント:</label>
        <textarea name="comment" cols="30" rows="5"><?php echo $simEdit[2]; ?></textarea><br>
        <input type="submit" value="投稿する">

        <?php
        if (!empty($simEdit[1]) && !empty($simEdit[2])) {
            echo '<input type="hidden" name="editContents" value="editContents">';
        }
        ?>

    </form>

    <br>

    <form method="POST" action="<?php echo($_SERVER['PHP_SELF']) ?>">
        <?php
        if (isset($simEdit[1]) && isset($simEdit[2])) {
             echo '<input type="hidden" name="delete"><br>';
        } else {
            echo '<label for="delete">削除対象番号</label><br>
                  <input type="text" name="delete"><br>
                  <input type="submit" value="削除する">';
        }
        ?>
    </form>

    <br>

    <form method="POST" action="<?php echo($_SERVER['PHP_SELF']) ?>">
        <?php
        if (isset($simEdit[1]) && isset($simEdit[2])) {
             echo '<input type="hidden" name="edit"><br>';
         } else {
            echo '<label for="edit">編集対象番号</label><br>
                  <input type="text" name="edit"><br>
                  <input type="submit" value="編集する">';
         }
        ?>
    </form>

<?php

    $contents = file('kb.txt');
    foreach($contents as $line){
        $data = explode("<>", $line);
        for($i = 0 ; $i < count($data); $i++){
            echo $data[$i]."<br>";
        }
    }

?> 
</body>
</html>
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

0

htmlspecialchars関数は
<a href="index.php">あ</a>というHTMLタグを
&lt;a href=&quot;index.php&quot;&gt;あ&lt;/a&gt;のように変換してくれる関数ですが、

本来はHTMLとして表示させる場合においてに使うものです。

ですので

$name = $_POST['name'];
$name = htmlspecialchars($name);

とするのではなく以下のようなその1~その4のようにして入力データを受け取る必要があります。

// その1
$name = isset($_POST['name']) && is_string($_POST['name']) ? $_POST['name'] : null;
// その2
$name = $_POST['name'] ?? null;
// その3
$name = $isset($_POST['name']) ?: null;
// その4
$name = (string)filter_input(INPUT_POST, 'name');

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

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