前提・実現したいこと
ここに質問の内容を詳しく書いてください。
(例)PHP(CakePHP)で●●なシステムを作っています。
■■な機能を実装中に以下のエラーメッセージが発生しました。
PHP.CSS.HTMLを使用して、写真をアップロードし、phpmyadminにデータを保存するシステムを作りたいのですが、うまくphpmyadminにデータが保存ができません。
プログラミング初心者です。なぜ上手くいかないのか、三日ほど悩んでいます。力を貸していただければ幸いです。よろしくお願いします。
発生している問題・エラーメッセージ
エラーメッセージ
該当のソースコード
<?php require_once "./dbc.php"; $files = getAllFile(); foreach($files as $file){ print_r ($file); } ?> <!DOCTYPE html> <html lang="ja"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>アップロードフォ-ム</title> </head> <style> body { padding: 30px; margin: 0 auto; width: 50%; } textarea { width: 98%; height: 60px; } .file-up { margin-bottom: 10px; } .submit { text-align: right; } .btn { display: inline-block; border-radius: 3px; font-size: 18px; background: #67c5ff; border: 2px solid #67c5ff; padding: 5px 10px; color: #fff; cursor: pointer; } </style> <body> <form enctype="multipart/form-data" action="file_upload.php" method="POST"> <div class="file-up"> <input type="hidden" name="MAX_FILE_SIZE" value="1048576" /> <input name="img" type="file" accept="image/*" /> </div> <div> <textarea name="caption" placeholder="キャプション(140文字以下)" id="caption" ></textarea> </div> <div class="submit"> <input type="submit" value="送信" class="btn" /> </div> </form> <div> <?php foreach($files as $file);?> <img src="<?php echo"{$file['$file_path']}"?>" alt=""> <p><?php echo h("{$file['discription']}"); ?></p> </div> </body> </html><?php $file=$_FILES['img']; $filename=basename($file['name']); $tmp_path=$file['tmp_name']; $file_err=$file['error']; $filesize=$file['size']; $upload_dir='/Applications/MAMP/htdocs/php.ec/images/'; $caption=filter_input(INPUT_POST,'caption',FILTER_SANITIZE_SPECIAL_CHARS); $save_filename= date('YmdHis').$filename; $err_msgs=array(); $save_path=$upload_dir.$save_filename; if(empty($caption)){ array_push($err_msgs,'キャプションを入力して下さい'); } if(strlen($caption)>140){ array_push($err_msgs,'キャプションは140文字以内で入力して下さい'); } if($filesize>1048576 || $file_err==2){ array_push($err_msgs,'ファイルサイズは1MB未満にして下さい'); } $allow_ext=array('jpg','jpeg','png'); $file_ext=pathinfo($filename,PATHINFO_EXTENSION); if(!in_array(strtolower($file_ext),$allow_ext)){ array_push($err_msgs,'画像ファイルを付与して下さい'); } if(count($err_msgs) === 0){ if(is_uploaded_file($tmp_path)){ if (move_uploaded_file($tmp_path,$save_path)){ echo $filename.'を'.$upload_dir.'にアップしました。'; $result= fileSave($filename,$save_path,$caption,); if($result){ echo'データーベースに保存しました。'; }else{ echo'データーベースに保存ができませんでした。'; } }else{ echo'ファイルが保存できませんでした。'; } }else{ echo'ファイルが選択されていません'; } }else{ foreach($err_msgs as $msg){ echo $msg; } } ?>
<a href="http://localhost:8888/php.ec/uplaod_file.php">戻る</a>
<?php require_once "./dbc.php"; function dbc() { $host="localhost"; $dbname="file_db"; $user="root"; $pass="root"; $dns="mysql:host=$host;dbname=$dbname; charsset=utf8"; try{ $pdo=new PDO($dns,$user,$pass, [ PDO::ATTR_ERRMODE=>PDO::ERRMODE_EXCEPTION, PDO::ATTR_DEFAULT_FETCH_MODE=>PDO::FETCH_ASSOC ]); return $pdo; }catch(PDOException $e){ exit($e->getMessage()); } } /* *ファイルデータを保存 * @param string $filename ファイルの名前 * @param string $save_path 保存先のパス * @param string $caption 投稿の説明 * @return bool $result */ function fileSave($filename,$save_path,$caption){ $result=False; $sql="INSERT INTO `file_table` (file_name,file_path,description) VALUE(?,?,?)"; try{ $stmt=dbc()->prepare($sql); $stmt->bindValue(1, $filename); $stmt->bindValue(2, $save_path); $stmt->bindValue(3, $caption); $result=$stmt->execute(); return $result; }catch(\Exception $e){ echo $e->getMessage(); return $result; } } function getAllFile() { $sql = "SELECT * FROM `file_table`"; $fileDate=dbc()->query($sql); return $fileDate; } function h($s){ return htmlspecialchars($s,ENT_QUOTES,"UTF-8"); } $sql = "SELECT * FROM `file_table`"; ?>
ソースコード
試したこと
phpmyadminにデータをうまく保存できるようにしたいです。
ここに問題に対して試したことを記載してください。
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
回答2件
あなたの回答
tips
プレビュー