PHPで編集機能を作成していますが、変更画面に遷移しません。

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 586

andrew57

score 116

前提・実現したいこと

PHPでテーブル一覧(①)を表示させた後に、変更画面(②)に遷移させたいです。

イメージ説明

イメージ説明

データベース内容
イメージ説明

発生している問題・エラーメッセージ

テーブル一覧を表示させることはできました、変更画面に遷移しません。
イメージ説明
編集ボタンを押すと、下記の画像のようになる。
イメージ説明

192.168.33.1:64947 [500]: /update2.php - Cannot use try without catch or finally in /home/vagrant/public_php/update2.php on line 43

該当のソースコード

テーブル一覧画面 update1.php

<?php

header("Content-type: text/html; charset=utf-8");

require_once("index_db.php");


$sql = "SELECT id, rank, nation, food, reason FROM country";
$statement = $pdo->query($sql);

// 結果の取得
$country = array();
foreach ($statement as $row) {
    $country[] = $row;
}
var_dump($country);

// データベース切断
$pdo = null;

?>

<!DOCTYPE html>
<html>
<head>
<title>国一覧</title>
</head>
<body>
<h1>国一覧</h1>

<table border='1'>
<tr><td>id</td><td>順位</td><td>国名</td><td>食べたい食べ物</td><td>理由</td></tr>

<?php
foreach($country as $row){
 ?>



 <tr>
 <td><?=$row['id']?></td>
 <td><?=htmlspecialchars($row['rank'], ENT_QUOTES, 'UTF-8')?></td>
 <td><?=htmlspecialchars($row['nation'], ENT_QUOTES, 'UTF-8')?></td>
 <td><?=htmlspecialchars($row['food'], ENT_QUOTES, 'UTF-8')?></td>
 <td><?=htmlspecialchars($row['reason'], ENT_QUOTES, 'UTF-8')?></td>
 <td>
   <form action="update2.php" method="post">
   <input type="submit" value="編集">
   <input type="hidden" name="id" value="<?=$row['id']?>">
   </form>
 </td>
</tr>



 <?php
 }
 ?>

</table>

</body>
</html>

変更画面 update2.php

<?php

header("content-type: text/html; charset=utf-8");
require_once("index_db.php");


try {

if(empty($_POST)) {
   echo "<a href='update1.php'>update1.php</a>←こちらのページからどうぞ";
   exit();
}else {
  if (!isset($_POST['id'])  || !is_numeric($_POST['id']) ){

       echo "idエラー";
       exit();
   }else {
    //プリペアドスタートメント
    $stmt = $dbh->prepare('select * from country where id=?');
    if ($stmt) {
      //プレースホルダへ実際の値を設定する
      $stmt->bind_param('id',$id);
      $id = $_POST['id'];

  //クエリの実行
  $stmt->execute();

  //結果変数のバインド
  $stmt->bind_result($id,$name);
  //値の取得
  $stmt->fetch();

  //ステートメント切断
  $stmt = null;
}else {
    echo $mysqli->errno . $mysqli->error;
}
}
}
}

//データベース切断
$pdo = null;

?>

<iDOCTYPE html>
  <!DOCTYPE html>
  <html>

<head>
  <title>変更画面</title>
</head>

<body>

<p>変更してください</p>
<form action="update3.php">

<input type="text" name="rank" value="<htmlspecialchars($rank, ENT_QUOTES, 'UTF-8')?>">
<input type="text" name="nation" value="<htmlspecialchars($rank, ENT_QUOTES, 'UTF-8')?>">
<input type="text" name="food" value="<htmlspecialchars($rank, ENT_QUOTES, 'UTF-8')?>">
<input type="text" name="reason" value="<htmlspecialchars($rank, ENT_QUOTES, 'UTF-8')?>">
<input type="submit" value="変更する">


</form>

</body>

  </html>

ご教授いただけたら嬉しいです。
宜しくお願い致します。

補足情報(言語/FW/ツール等のバージョンなど)

PHP 5.6.30,mysql Ver 14.14,vagrant

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • m.ts10806

    2017/08/29 20:37 編集

    ソースコードを整形してくれる機能があるエディタの利用をご検討ください。

    キャンセル

回答 1

checkベストアンサー

+2

try文に対するcatchが書かれていないのが原因でしょう。
http://php.net/manual/ja/language.exceptions.php

また、インデントが謎状態なのでしっかりとインデントを組んだほうが良いと思います。
インデントがわけわからなくなっていると、より原因が見つけにくくなります。

try {

    if(empty($_POST)) {
        echo "<a href='update1.php'>update1.php</a>←こちらのページからどうぞ";
        exit();
    }else {
        if (!isset($_POST['id'])  || !is_numeric($_POST['id']) ){

            echo "idエラー";
            exit();
        }else {
            //プリペアドスタートメント
            $stmt = $dbh->prepare('select * from country where id=?');
            if ($stmt) {
                //プレースホルダへ実際の値を設定する
                $stmt->bind_param('id',$id);
                $id = $_POST['id'];

                //クエリの実行
                $stmt->execute();

                //結果変数のバインド
                $stmt->bind_result($id,$name);
                //値の取得
                $stmt->fetch();

                //ステートメント切断
                $stmt = null;
            }else {
                echo $mysqli->errno . $mysqli->error;
            }
        }
    }
} // ここにcatchがない

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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