気づけばプロ並みというPHPの参考書で勉強していますが、画像が表示されなくて困っています。
move_uploaded_file()を使って画像をフォルダに移動させるとことまでは成功しているのですが、その画像をテーブルに格納することができません。どこか間違っていますか。一応「商品を追加しました」のメッセージとともに画像は画面に表示されますが格納されていないです。テーブルにファイル名が出ていません。
ちなみにこのコードは著者が公開している解答のコードです。
<body> 商品追加<br /> <br /> <form method="post" action="pro_add_check.php" enctype="multipart/form-data"> 商品名を入力してください。<br /> <input type="text" name="name" style="width:200px"><br /> 価格を入力してください。<br /> <input type="text" name="price" style="width:50px"><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>コード
pro_add_check.php
1<body> 2 3<?php 4 5$pro_name=$_POST['name']; 6$pro_price=$_POST['price']; 7$pro_gazou=$_FILES['gazou']; 8 9$pro_name=htmlspecialchars($pro_name,ENT_QUOTES,'UTF-8'); 10$pro_price=htmlspecialchars($pro_price,ENT_QUOTES,'UTF-8'); 11 12if($pro_name=='') 13{ 14 print '商品名が入力されていません。<br />'; 15} 16else 17{ 18 print '商品名:'; 19 print $pro_name; 20 print '<br />'; 21} 22 23if(preg_match('/\A[0-9]+\z/',$pro_price)==0) 24{ 25 print '価格をきちんと入力してください。<br />'; 26} 27else 28{ 29 print '価格:'; 30 print $pro_price; 31 print '円<br />'; 32} 33 34if($pro_gazou['size']>0) 35{ 36 if($pro_gazou['size']>1000000) 37 { 38 print '画像が大き過ぎます'; 39 } 40 else 41 { 42 move_uploaded_file($pro_gazou['tmp_name'],'./gazou/'.$pro_gazou['name']); 43 print '<img src="./gazou/'.$pro_gazou['name'].'">'; 44 print '<br />'; 45 } 46} 47 48if($pro_name=='' || preg_match('/\A[0-9]+\z/',$pro_price)==0 || $pro_gazou['size']>1000000) 49{ 50 print '<form>'; 51 print '<input type="button" onclick="history.back()" value="戻る">'; 52 print '</form>'; 53} 54else 55{ 56 print '上記の商品を追加します。<br />'; 57 print '<form method="post" action="pro_add_done.php">'; 58 print '<input type="hidden" name="name" value="'.$pro_name.'">'; 59 print '<input type="hidden" name="price" value="'.$pro_price.'">'; 60 print '<input type="hidden" name="gazou_name" value="'.$pro_gazou['name'].'">'; 61 print '<br />'; 62 print '<input type="button" onclick="history.back()" value="戻る">'; 63 print '<input type="submit" value="OK">'; 64 print '</form>'; 65} 66 67?> 68</body>コード
pro_add_done.php<?php
1 2try 3{ 4 5$pro_name=$_POST['name']; 6$pro_price=$_POST['price']; 7$pro_gazou_name=$_POST['gazou_name']; 8 9$pro_name=htmlspecialchars($pro_name,ENT_QUOTES,'UTF-8'); 10$pro_price=htmlspecialchars($pro_price,ENT_QUOTES,'UTF-8'); 11 12$dsn='mysql:dbname=shop;host=localhost;charset=utf8'; 13$user='root'; 14$password=''; 15$dbh=new PDO($dsn,$user,$password); 16$dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); 17 18$sql='INSERT INTO mst_product(name,price,gazou) VALUES (?,?,?)'; 19$stmt=$dbh->prepare($sql); 20$data[]=$pro_name; 21$data[]=$pro_price; 22$data[]=$pro_gazou_name; 23$stmt->execute($data); 24 25$dbh=null; 26 27print $pro_name; 28print 'を追加しました。<br />'; 29 30} 31catch(Exception$e) 32{ 33 print'ただいま障害により大変ご迷惑をお掛けしております。'; 34 exit(); 35} 36 37?> 38 39<a href="pro_list.php">戻る</a> 40 41</body>コード
あなたの回答
tips
プレビュー