環境:Windows10 XAMPP HeidiSQL
商品修正ページをつくり編集後OKを押した後
ページ遷移するよう作りましたが、Object not found!となってしまいます。
商品修正ページ(post側)
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>ろくまる農園</title> </head> <body> <?php try { $pro_code=$_GET['procode']; $dsn='mysql:dbname=shop;host=localhost;charset=utf8'; $user='root'; $password='4061319y'; $dbh=new PDO($dsn,$user,$password); $dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); $sql='SELECT name,price,gazou FROM mst_product WHERE code=?'; $stmt=$dbh->prepare($sql); $data[]=$pro_code; $stmt->execute($data); $rec=$stmt->fetch(PDO::FETCH_ASSOC); $pro_name=$rec['name']; $pro_price=$rec['price']; $pro_gazou_name_old=$rec['gazou']; $dbh=null; if($pro_gazou_name_old=='') { $disp_gazou=''; } else { $disp_gazou='<img src="./gazou/'.$pro_gazou_name_old.'">'; } } catch(Exception $e) { print'只今障害により大変ご迷惑をおかけいたしております。'; exit(); } ?> 商品修正<br /> <br /> 商品コード<br /> <?php print $pro_code; ?> <br /> <br /> <form method="post" action="pro_edit_check.php" enctype="multipart/form-data"> <input type="hidden" name="code" value="<?php print $pro_code;?>"> <input type="hidden" name="gazou_name_old" value="<?php print $pro_gazou_name_old; ?>"> 商品名<br /> <input type="text" name="name" style="width:200px" value="<?php print $pro_name; ?>"><br /> 価格<br /> <input type="text" name="price" style="width:50px" value="<?php print $pro_price; ?>">円<br /> <br /> <?php print $disp_gazou; ?> <br /> 画像を選んでください。<br /> <input type="file" name="gazou" style="width:400px"><br /> <br /> <input type="button" onclick="history.back()" value="戻る"> <input type="submit" value="OK"> </form> </body> </html>
受け取りがわ
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>ろくまる農園</title> </head> <body> <?php $pro_code=$_POST['code']; $pro_name=$_POST['name']; $pro_price=$_POST['price']; $pro_gazou_name_old=$_POST['gazou_name_old']; $pro_gazou=$_FILES['gazou']; $pro_code=htmlspecialchars($pro_code,ENT_QUOTES,'UTF-8'); $pro_name=htmlspecialchars($pro_name,ENT_QUOTES,'UTF-8'); $pro_price=htmlspecialchars($pro_price,ENT_QUOTES,'UTF-8'); if($pro_name=='') { print '商品名が入力されていません。<br />'; } else { print '商品名:'; print $pro_name; print '<br />'; } if(preg_match('/\A[0-9]+\z/',$pro_price)==0) { print'価格を正確に入力してください。<br />'; } else { print '価格:'; print $pro_price; print '円<br />'; } if($pro_gazou['size']>0) { if($pro_gazou['size']>1000000) { print'画像が大き過ぎます'; } else { move_uploaded_file($pro_gazou['tmp_name'],'./gazou/'.$pro_gazou['name']); print'<img src="./gazou/'.$pro_gazou['name'].'">'; print'<br />'; } } if($pro_name==''||preg_match('/\A[0-9]+\z/',$pro_price)==0||$pro_gazou['size']>1000000) { print '<form>'; print '<input type="button" onclick="history.back()" value="戻る">'; print '</form>'; } else { print '上記のように変更します。<br />'; print '<form method="post" action="pro_edit_done.php">'; print '<input type="hidden" name="code" value="'.$pro_code.'">'; print '<input type="hidden" name="name" value="'.$pro_name.'">'; print '<input type="hidden" name="price" value="'.$pro_price.'">'; print '<input type="hidden" name="gazou_name_old" value="'.$pro_gazou_name_old.'">'; print '<input type="hidden" name="gazou_name" value="'.$pro_gazou['name'].'">'; print '<br />'; print '<input type="button" onclick="history.back()" value="戻る">'; print '<input type="submit" value="OK">'; print '</form>'; } ?> </body> </html>
ご教授宜しくお願い致します。
どのObjectが見つからないのかを突き止めないと解決できません。
まずは大きなブロックから徐々に範囲を狭めて、問題のObjectを特定してみてください。
一応ご確認をお願いしたいのですが、自分も今勉強中でが、[ XAMPP ] Apache Web Server , MySQL Database は [ Running ] とこのように表示されていますでしょうか?
このもし[ Object not found! ]この画面になっているのは、
商品修正ページ(post側)
<form method="post" action="pro_edit_check.php" enctype="multipart/form-data">
( 受け取り側 )print '<form method="post" action="pro_edit_done.php">';
その自分で作成した、[ ???_???_???.php ] のファイル名の打ち間違いかもしれませんのでそこら辺もご確認ください。
proファイルの中に
[ pro_edit.php ] → [ pro_edit_check.php ] → [ pro_edit_done.php ]ここからコピって貼り付けてみてそれでもダメだったら、気軽に相談してもいいし、他の人にも聞いてみてください。
補足:URLでこうなっているかどうかも確認してみてください。
[ http://localhost/product/pro_edit.php ]とかになっているかも確認してみてください。
回答に書きましたので同じことが書いてあります。どうぞご覧ください。
回答1件
あなたの回答
tips
プレビュー