yopisan
@yopisan (kota)

Are you sure you want to delete the question?

If your question is resolved, you may close it.

Leaving a resolved question undeleted may help others!

We hope you find it useful!

phpであ問い合わせフォームの編集機能を実装中です。idの受け渡しができていないため編集ができずにいるので解決したい

1. やりたいことや目的、概要

お問い合わせフォームの編集画面(edit.php)から編集完了(update.php)後のデータの受け渡しができるようにしたい。

2. 何についての悩みや起きている問題か

編集画面(edit.php)で入力後、送信し(update.php)に遷移し一覧に戻るをクリックしてお問い合わせフォーム(contact.php)の下にDBの結果をテーブルで用意してあるので、確認したところ編集したはずの入力が更新できていないことを確認

3. 試したこと、または試そうと考えていること

edit.phpやupdate.phpで周辺を確認し、var_dumpで値の確認を行ったりしている。
uodate.phpにて(14行目〜16行目)
var_dump($post);
$id = 159;
var_dumpの中身を見てみるとidが引き渡せていないことを確認。
$id = 159;ベタ打ちで確かめてみたところ編集できていることは確認できているので、やはりidが原因かと考えています。
どこを修正すればいいのかわからないのでどなたか教えていただけないでしょうか。

4. 該当コード

edit.php

<!DOCTYPE html>
<html lang="ja">

<?php
session_cache_limiter('none');
//セッション接続
session_start();

$err['name'] = '';
$err['kana'] = '';
$err['phone'] = '';
$err['address'] = '';
$err['question'] = '';

if ($_SERVER['REQUEST_METHOD'] === 'POST') {
  $result = filter_input_array(INPUT_POST, FILTER_SANITIZE_FULL_SPECIAL_CHARS);

  if ($result['name'] === '') {
    $err['name'] = 'err';
  } elseif (10 < mb_strlen($result['name'], 'UTF-8')) {
    $err['name'] = 'err';
  }
  if ($result['kana'] === '') {
    $err['kana'] = 'err';
  } elseif (10 < mb_strlen($result['kana'], 'UTF-8')) {
    $err['kana'] = 'err';
  }
  if ($result['phone'] === '') {
    true;
  } elseif (!preg_match('/^[0-9]+$/', $result['phone'])) {
    $err['phone'] = 'err';
  }
  if ($result['address'] === '') {
    $err['address'] = '';
  } elseif (!preg_match('/^[0-9a-z_.\/?-]+@([0-9a-z-]+\.)+[0-9a-z-]+$/', $result['address'])) {
    $err['address'] = 'err';
  }
  if ($result['question'] === '') {
    $err['question'] = 'err';
  }

  if (empty($err['name']) && empty($err['kana']) && empty($err['phone']) && empty($err['address']) && empty($err['question'])) {
    $_SESSION['form'] = $result;
    header("Location: update.php");
    exit;
  }
}

session_destroy();

//DB接続
include "db_open.php";

$dbh = db_open();
//データ取得&表示
$stmt = $dbh->prepare('SELECT * FROM cafe.contacts WHERE id=:id');
$id = $_GET['id'];
$stmt->bindValue(':id', (int)$id, PDO::PARAM_INT);

$stmt->execute();

$result = $stmt->fetch(PDO::FETCH_ASSOC);
?>

<!DOCTYPE html>
<html lang="ja" dir="ltr">

<head>
<head>
<meta charset="UTF-8">
  <title></title>
  <link rel="stylesheet" type="text/css" href="base.css">
  <meta name="viewport" content="width=device-width,initial-scale=1">
  <link href="https://use.fontawesome.com/releases/v5.6.1/css/all.css" rel="stylesheet">
  <script type="text/javascript" src="index.js"></script>
  <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
</head>
</head>

<body>

  <!--header-->
  <!-- <script src="index.js"></script> -->
  <?php include "layouts/header.php"; ?>
  <?php  session_start() ?>
  <!--header-->
  <div class="form-wrapper">
      <div class="error">
        <h1>
          <?php 
            if(isset($_SESSION["texts"])){
            foreach($_SESSION["texts"] as $error){
              echo $error."<br>";
              }
            }?>
        </h1>
      </div>
  <div class="form">
        <div class="form-title">
          <h1 style="text-align:center;">お問い合わせ編集 </h1>
        </div>
        <div class="form-main">
          <div class="back">  
            <h2>下記の編集項目をご記入の上送信ボタンを押してください</h2>
          </div>  
            <p>送信頂いた件につきましては、当社より折り返しご連絡を差し上げます。<br>
               なお、ご連絡までに、お時間を頂く場合もございますので予めご了承ください。<br>
            <span>*</span>は必須項目となります。</p>

          <input type="hidden" id="id" name="id" value="<?php echo $result['id']; ?>">
        <form action="db_open.php" method="POST">
              <div class="form-contents">
                <div class="form-content">
                  <h3>氏名<span>*</span></h3>
                  <input type="text" name="name"  value="<?php echo $result['name']; ?>">
            <?php if ($err['name'] === 'err') : ?>
              <p class="error">
                <font color=red>氏名は、必須入力です。10文字以内でご入力ください</font>
              </p>
            <?php endif; ?>
            </div>

          <div class="form-content">
                  <h3>フリガナ<span>*</span></h3>
                  <input type="text" name="kana" value="<?php echo $result['kana']; ?>">
            <?php if ($err['kana'] === 'err') : ?>
              <p class="error">
                <font color="red">フリガナは、必須入力です。10文字以内でご入力ください。</font>
              </p>
            <?php endif; ?>
          </div>

          <div class="form-content">
                  <h3>電話番号</h3>
                  <input type="text" name="phone"  value="<?php echo $result['phone']; ?>">
            <?php if ($err['phone'] === 'num') : ?>
              <p class="error">
                <font color="red">電話番号は0-9の数字でのご入力ください。</font>
              </p>
            <?php endif; ?>
          </div>

          <div class="form-content">
              <h3>メールアドレス<span>*</span></h3>
                  <input type="text" name="address" value="<?php echo $result['address']; ?>">
            <?php if ($err['address'] === 'err' || $err['address'] === 'address') : ?>
              <p class="error">
                <font color="red">メールアドレスは、正しくご入力ください。</font>
              </p>
            <?php endif; ?>
          </div>
        </div>
              <div class="back">  
                <h2>お問い合わせ内容をご記入ください<span>*</span></h2>
              </div>  
              <textarea name="question" class="inputQuestion"><?php echo $result['question']; ?></textarea>
            <?php if ($err['question'] === 'err') : ?>
              <p class="error">
                <font color="red">お問い合わせ内容は、必須入力です。</font>
              </p>
            <?php endif; ?>
        
        <input type="submit" value="送    信" class="form-submit" formaction="validate.php" >

        </div>
      </form>
   </div>
  </div>

  <!--footer-->
  <?php include "layouts/footer.php"; ?>
  <!--footer-->

</body>

</html>

update.php

<?php
//セッション接続
session_start();

$post = $_SESSION;
// var_dump ($post);
$id = $post[':id'];
$name = $post[':name'];
$kana = $post[':kana'];
$phone = $post[':phone'];
$address = $post[':address'];
$question = $post[':question'];
//URLからの接続禁止
$referer = $_SERVER['HTTP_REFERER'];
$url = "edit.php";
if (!strstr($referer, $url)) {
  header("Location: contact.php");
  exit;
}

session_destroy();
//DB接続
include "db_open.php";
$dbh = db_open();
//更新
$sql = "UPDATE contacts
       SET name=:name,kana=:kana,phone=:phone,address=:address,question=:question
      -- SET name='坂本',kana='サカモト',phone='098932535',address='sakamoto@sakamorto',question='コンニチは';
       Where id=:id";

try {
  $stmt = $dbh->prepare($sql);
  $stmt->bindValue(":name", $name, PDO::PARAM_STR);
   $stmt->bindValue(":kana", $kana, PDO::PARAM_STR);
   $stmt->bindValue(":phone", $phone, PDO::PARAM_STR);
   $stmt->bindValue(":address", $address, PDO::PARAM_STR);
   $stmt->bindValue(":question", $question, PDO::PARAM_STR);
   $stmt->bindValue(":id", $id, PDO::PARAM_INT);
   $stmt->execute();
 

  echo "編集が完了しました。" . "<br/>";
  echo "<a href='contact.php'>一覧に戻る</a>";
} catch (Exception $e) {
  echo "エラーが発生しました:" . ($e->getMessage()) . "<br>";
  exit;
}

?>

<!DOCTYPE html>
<html lang="ja" dir="ltr">

<head>
  <meta charset="utf-8">
  <title>Lesson Sample Site</title>
</head>

<body>
</body>

</html>


新規登録(contact.php)

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <title></title>
  <link rel="stylesheet" type="text/css" href="base.css">
  <meta name="viewport" content="width=device-width,initial-scale=1">
  <link href="https://use.fontawesome.com/releases/v5.6.1/css/all.css" rel="stylesheet">
  <script type="text/javascript" src="index.js"></script>
  <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
</head>
<body>

    <?php include 'layouts/header.php'; ?>
    <?php  session_start() ?>
    <div class="form-wrapper">
      <div class="error">
        <h1>
          <?php 
            if(isset($_SESSION["texts"])){
            foreach($_SESSION["texts"] as $error){
              echo $error."<br>";
              }
            }?>
        </h1>
      </div>        
      <div class="form">
        <div class="form-title">
          <h1 style="text-align:center;">お問い合わせ </h1>
        </div>
        <div class="form-main">
          <div class="back">  
            <h2>下記の項目をご記入の上送信ボタンを押してください</h2>
          </div>  
            <p>送信頂いた件につきましては、当社より折り返しご連絡を差し上げます。<br>
               なお、ご連絡までに、お時間を頂く場合もございますので予めご了承ください。<br>
            <span>*</span>は必須項目となります。</p>
            <form action="db_open.php" method="POST">
              <div class="form-contents">
                <div class="form-content">
                  <h3>氏名<span>*</span></h3>
                  <input type="text" name="name" 
                    value="<?php 
                      if(!empty($_SESSION["name"])){
                        echo $_SESSION["name"];
                      }
                      ?>" placeholder="山田太郎" class="inputName">
                </div>
                <div class="form-content">
                  <h3>フリガナ<span>*</span></h3>
                  <input type="text" name="kana" 
                    value="<?php 
                      if(!empty($_SESSION["kana"])){
                        echo $_SESSION["kana"];
                      }
                      ?>" placeholder="ヤマダタロウ" class="inputKana">
                </div>
                <div class="form-content">
                  <h3>電話番号</h3>
                  <input type="text" name="phone" 
                  value="<?php 
                   if(!empty($_SESSION["phone"])){
                    echo $_SESSION["phone"];
                  }
                  ?>" placeholder="09012345678" class="inputPhone">
                </div>
                <div class="form-content">
                  <h3>メールアドレス<span>*</span></h3>
                  <input type="text" name="address"
                    value="<?php 
                    if(!empty($_SESSION["address"])){
                      echo $_SESSION["address"];
                    }
                    ?>" placeholder="test@test.co.jp" class="inputAddress">
                </div>
              </div>
              <div class="back">  
                <h2>お問い合わせ内容をご記入ください<span>*</span></h2>
              </div>  
              <textarea name="question" class="inputQuestion"><?php 
                if(!empty($_SESSION["question"])){
                  echo $_SESSION["question"];
                }?></textarea><br>
              <input type="submit" value="送    信" class="form-submit" formaction="validate.php" >
            </form>
           
          </div>
        </div>
       
    </div>

    <section id=db>
        <?php
        //DB接続
        include "db_open.php";

        try {
            $dbh = db_open();
            $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
            $dbh->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);

            $sql = "SELECT * FROM cafe.contacts";
            $stmt = $dbh->prepare($sql);
            $stmt->execute();
        } catch (PDOException $Exception) {
            die('接続エラー:' . $Exception->getMessage());
        }
        ?>

        <table>
            <tr>
                <th>システムID</th>
                <th>氏名</th>
                <th>フリガナ</th>
                <th>電話番号</th>
                <th>メールアドレス</th>
                <th>お問い合わせ</th>
                <th>送信日時</th>
            </tr>

            <?php
            $row = filter_input_array(INPUT_POST, FILTER_SANITIZE_FULL_SPECIAL_CHARS);
            while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
            ?>

                <tr>
                    <td><?= $row['id'] ?></td>
                    <td><?= $row['name'] ?></td>
                    <td><?= $row['kana'] ?></td>
                    <td><?= $row['phone'] ?></td>
                    <td><?= $row['address'] ?></td>
                    <td><?= nl2br($row['question']) ?></td>
                    <td><?= $row['created_at'] ?></td>
                    <td><a href="edit.php?id=<?php echo (int)$row['id']; ?>">編集</a></th>
                    <td><a href="dele.php?id=<?php echo (int) $row['id']; ?>" onclick="return confirm('本当に削除しますか?')">削除</a></td>
                </tr>
 
            <?php
           }
            $pdh = null;
            ?>

        </table>

    </section>

    <?php include 'layouts/footer.php'; ?>
    <!-- <script type="text/javascript" src="index.js"></script>
     <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script> -->

</body>
</html>


0

1Answer

edit.php
          <input type="hidden" id="id" name="id" value="<?php echo $result['id']; ?>">
        <form action="db_open.php" method="POST">

idパラメータを設定しているinputタグがformタグの外にあるからではないでしょうか?

あとはどういった経路でupdate.phpまで行っているか分からないので回答は難しいですね。
formのリクエスト先であるdb_opne.phpのコードがあれば分かるかもしれません。

0Like

Comments

  1. @yopisan

    Questioner

    ありがとうございます。
    今先ほど指摘されたformタグの中に入れ込んだら解決することができました。

    ちなみに先ほどおっしゃられたdb_opne.phpは下記のコードです

    <?php
    function db_open() :PDO{
    $db='mysql:dbname=cafe;host=localhost;charset=utf8';
    $db_user='php_user';
    $db_password='ykb02566';
    $db_opt=[
    PDO::ATTR_ERRMODE=>PDO::ERRMODE_EXCEPTION,
    PDO::ATTR_EMULATE_PREPARES=>false,
    ];
    $dbh = new PDO($db,$db_user,$db_password,$db_opt);
    return $dbh;
    }
    ?>
    <?php
    function db_open() :PDO{
    $db='mysql:dbname=cafe;host=localhost;charset=utf8';
    $db_user='php_user';
    $db_password='ykb02566';
    $db_opt=[
    PDO::ATTR_ERRMODE=>PDO::ERRMODE_EXCEPTION,
    PDO::ATTR_EMULATE_PREPARES=>false,
    ];
    $dbh = new PDO($db,$db_user,$db_password,$db_opt);
    return $dbh;
    }
    ?>

Your answer might help someone💌