質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.48%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

2回答

1570閲覧

phpmyadminにデータが保存されない

xo_yo

総合スコア54

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2021/11/18 05:08

前提・実現したいこと

ここに質問の内容を詳しく書いてください。
(例)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/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2021/11/18 06:03

コードはマークダウンのcodeにてご提示ください。 あと、phpMyAdminはあくまでMySQLを操作するためのツールの一つでしかなく、そこにデータが保存されるわけではないのでご注意を。細かいですが大事です。
xo_yo

2021/11/18 07:24

すいません。ありがとうございます!
guest

回答2

0

自己解決

「require_once "./dbc.php";」のコードを二つ目のコードに書き忘れて上手くデータをDBに保存するルートを確保出来ていなかった。

「require_once "./dbc.php";」のコードを二つ目のコードに付け足すことで解決できました。

投稿2021/11/18 16:45

xo_yo

総合スコア54

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

VALUEではなくてVALUESです。PHPだけではSQLの発行がうまく行っているかどうか分かりづらいので、phpmyadminでその構文がうまくいくか実行してみましょう。

あと、phpmyadminはあくまでDBの編集ソフトのようなもので、実際操作しているDBはmysqlです。

sql

1INSERT INTO file_table (file_name,file_path,description) VALUES(?,?,?)

プレースホルダが面倒な場合は、パラメータをチェック入れてこのようにするといいでしょう。
phpmyadminのクエリで記述する

sql

1INSERT INTO file_table (file_name,file_path,description) VALUES(':a',':b',':c')

その後にbind parametersにチェックを入れるとフォーム枠が表示されるので、そこに値を代入していく。

投稿2021/11/18 07:33

編集2021/11/18 07:37
FKM

総合スコア3640

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

xo_yo

2021/11/18 07:59

ありがとうございます!実行してみます!
xo_yo

2021/11/18 12:44

すいません。実行してみましたが出来ませんでした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問