登録フォームを作成し、PHPにてMYSQLに情報を保存しようとしています。
テキストデータは問題なく保存できるのですが、画像データが保存できません。
いろいろ調べているのですが、テキストデータと画像データをいっぺんに保存する方法がわかりません。
なんとなくはどこらへんが問題なのかということはわかるのですが、具体的にどうすればいいかがわかりません。
アドバイスをご教示いただけないでしょうか。よろしくお願いします。
【mysqlテーブル】
create table entries (
id int not null auto_increment primary key,
name varchar(255),
address varchar(255),
image1 MEDIUMBLOB NOT NULL,
image1 MEDIUMBLOB NOT NULL,
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
【touroku.php】
<?php
error_reporting(E_ALL & ~E_NOTICE);
if ($_SERVER['REQUEST_METHOD']=="POST") {
$name = $_POST['name'];
$email = $_POST['email'];
$image1 = $_POST['image1'];
$image2 = $_POST['image2'];
$error = array();
// エラー処理
if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
$error['email'] = 'メールアドレスが正しくありません';
}
if ($email == '') {
$error['email'] = 'メールアドレスが入力されていません';
}
// エラーがなかった場合
if (empty($error)) {
// DBにデータを入れる
mysql_connect("localhost", "ユーザー名", "パスワード") or die("can't connect to DB: ".mysql_error());
mysql_select_db("DB名") or die("can't select to DB: ".mysql_error());
$q = sprintf("insert into entries (name, email, image1, image2) values ('%s', '%s', '%s', '%s')", mysql_real_escape_string($name), mysql_real_escape_string($email), mysql_real_escape_string($image1), mysql_real_escape_string($image2));
mysql_query($q) or die("can't run query: ".mysql_error());
// 登録完了画面に飛ぶ
header("Location: http://localhost/.../thanks.html");
}
}
?>
<!DOCTYPE html>
<html lang="ja">
<meta charset="UTF-8">
<title>登録フォーム</title>
<head>
</head>
<body>
<form method="post" action="">
<p>名前:</p>
<input type="text" name="name" value="<?php echo htmlspecialchars($name); ?>">
<?php if ($error['name']) echo $error['name']; ?>
<p>メールアドレス</p>
<input type="text" name="email" value="<?php echo htmlspecialchars($email); ?>">
<?php if ($error['email']) echo $error['email']; ?>
<br>
<p>画像1:</p>
<input type="file" name="image1">
<p>画像2:</p>
<input type="file" name="image2">
<p><input type="submit" value="登録"></p>
</form>
</body>
</html>
No.5ベストアンサー
- 回答日時:
どうやって使うかが決まらないうちに(どうやって使うかが理解出来ていないのに)、データを格納する部分を作るというのはおかしな話です。
>mysqlに格納してあるデータを検索して表示する
ということですから、その検索結果でレコードを特定出来るキーを渡します。でないと画像データが特定できません。「画像を返すスクリプト」は渡されたキーで所定のレコードを読み出して、そこに格納されている画像データを(適切なhttpレスポンスヘッダとともに)ブラウザに返します。
当然ですがimg要素を組み立てるときには、すでにそのデータを読んでいる(なのでキーを渡せる)ということです。
#本来であれば、その時点でキャッシュさせるなどの手法を
#採りたいところですが、それは今後の課題ということで(汗
なお、デバッグ時にはとりあえずキーを(QueryStringで渡さずに)決め打ちしてもいいです。まずは画像を表示できることを確認するのが先ですから(これを先にやってみた方がいいと思います)。
この回答への補足
ご回答ありがとうございます。
表示したい画像を特定するキーは、mysqlに保存した時に割り振りしているidを使いたいと考えています。
そうすると、
<?php echo '<img src="get_image.php?..... の「?」の後に、割り振ってあるidを入れて画像を特定し、get_image.phpファイルにて画像を読み出すという理解なのですがいかがでしょうか?
No.4
- 回答日時:
えっと・・・
「ブラウザに画像を返す」というときには(ブラウザのアドレスバーにURLを直接入力する以外では)img要素のsrc属性として指定するしかありませんが、それは理解されていますか?
データベースから画像を返すような場合には、そのsrc属性に
<img src="gazou.php?id=1234" />
などとphpスクリプトを指定して、そのスクリプトがデータベースから画像データを読み込んで「画像データを(適切なhttpレスポンスヘッダとともに)返す」ことになります。
src属性で画像ファイルを指定したらwebサーバがそのファイルをブラウザに返しますが、そのときの動作をphpスクリプトで再現することになります。なのでwebサーバが(httpレスポンスヘッダなど)どう動いているのかがわかっていないといけません。このあたりをキチンと理解していないと保存しても意味がありませんよ(汗
この回答への補足
ご回答ありがとうございます。
調べているうちにいろいろと錯誤してしまっていました。
今回、mysqlに格納してあるデータを検索して表示する中の1つの項目が画像なのですが、<img src="....phpのあとの「id=~~」の部分をどう書けばいいのかわかりません。検索結果として画像を表示するので、検索の際渡したidをそのまま使うのだろうとは思っています。
度々申し訳ありませんが、検索結果として表示する際について、idについてもう少しヒント、アドバイスよろしくお願いします。
No.3
- 回答日時:
>表示の際、<?php echo $row['image1']; ?>としているのですが、
ブラウザに「画像データ」を返すのですから、先に
header('content-type: image/jpeg');
などのhttpレスポンスヘッダを送出しておかないといけません(mimeタイプはデータによります)。当然、当該スクリプトではhttpヘッダと画像データ以外のものをブラウザに返してはいけません。
この回答への補足
ご回答ありがとうございます。
ご指摘頂いた点修正加えて見たのですが、今度は何も表示されなくなりました。
調べていると<img src="◯◯.php" ... とし、別途phpファイルでローダーを作った上で読み込ませるといった方法もあるみたいなのですが、どちらが方法として良いということはあるのでしょうか?
No.2
- 回答日時:
form要素にenctype属性がありません。
<form method="post" action="" enctype="multipart/form-data">
と書いてください。
>それとも、もっと別にコードを書く場所を設けるべきでしょうか?
今現在、
$image1 = $_POST['image1'];
と書いている部分を
$image1 = isset($_FILES['image1']) ? file_get_contents($_FILES['image1']['tmp_name']) : "";
などとするだけだと思います。
この回答への補足
ご回答ありがとうございます。
ご指摘頂いたように修正してみたところ、とりあえずはきちんと動作(?)したようです。
きちんと保存されているか確認のため、phpを使って出力してみているのですが、ずらっと文字列(文字化けともなんとも言いがたい・・)が並んで画像として表示がされません。
表示の際、<?php echo $row['image1']; ?>としているのですが、これは単純に出力のためのコードが間違っているのか、それともそもそもきちんと保存されていないのか、どちらになるのでしょうか?
度々申し訳ありませんが、ご教示いただけないでしょうか。
No.1
- 回答日時:
画像ファイルを取得する際のお作法に誤りがありますよ。
$_FILESを利用しましょう。
さらにDB側はBLOB型なわけですから、ファイルパスなどではなく
バイナリデータを格納しなければなりません。
$_FILES['tmp_name']にサーバにアップロードされたファイルが
あるので、それを読み込んで書きこむ必要があります。
http://php.net/manual/ja/reserved.variables.file …
この回答への補足
ご回答ありがとうございます。
なるほど、そうですね。
調べてみると$_FILESに関するサイトがいっぱいでてきたのですが、少し引っかかる部分があります。
それは、画像に関するコードを書く場所なのですが、「DBに接続する」の後、「&q = sprintf.....」の前にそのまま書いてしまってもいいものなのでしょうか?
それとも、もっと別にコードを書く場所を設けるべきでしょうか?
アドバイスご教示よろしくお願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- PHP PHP MySql 画像を取得 1 2022/06/04 14:05
- PHP PHPでユーザー情報を入力して簡易ログイン機能をつくってみたのですが 1 2023/05/29 08:51
- JavaScript 入力フォームの javascript で メールアドレスの正規チェックをを行い、ボタンをクリックして 2 2022/04/27 16:06
- PHP php テーブルが作成できない 1 2022/11/17 23:41
- MySQL php テーブルを作れない 2 2022/11/17 18:22
- PHP 入力した部分を表示させたまま(保持)するにはどうすれば良いでしょうか? 1 2023/01/25 11:14
- PHP PHPで画像の渡しが上手く行きません。 1 2023/02/02 09:39
- JavaScript ①入力フォーム→②確認表示画面→③送信完了画面のコードを書いているのです、 入力フォームから受け取っ 2 2022/05/10 16:45
- PHP PHPのエラーの解消法について教えて下さい。 1 2023/02/06 10:48
- PHP PHP MySQLに画像を直接保存 2 2022/06/05 11:50
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
phpで変数を使ってcopyできない
-
重複を防ぐ記述について教えて...
-
openCVのトラックバーについて
-
PHPで入力フォームでデータを確...
-
MySQL,PHPのリロードによる二重...
-
アップロードファイル名の文字化け
-
C# 同じ処理をまとめたい
-
Smartyのテンプレート内で、連...
-
PHPからHTMLへの変数の受け...
-
$_SESSIONに渡した後はそのまま...
-
【PHP】PHPでそのファイルが格...
-
phpからServletへmultipartのPO...
-
Fortranでのファイル名操作につ...
-
テキストボックスの値を取得したい
-
PHP ボタンが押されたら処理を...
-
PHPでユーザー情報を入力して簡...
-
PHPでCookieを使った訪問回数に...
-
フォームへの前回入力値をクリ...
-
アマゾンのような評価の星を選...
-
syntax error, unexpected '}' ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Flaskでサーバー立ち上げに関して
-
重複を防ぐ記述について教えて...
-
VBA で、スペースを含むファイ...
-
phpで変数を使ってcopyできない
-
PHPで入力フォームでデータを確...
-
PHPからHTMLへの変数の受け...
-
POSTの項目に追加
-
PHP MySql 画像を取得
-
MySQL,PHPのリロードによる二重...
-
UPDATEできない
-
ファイル名を変更してアップロ...
-
php、sqlite3にデーター追加で...
-
openCVのトラックバーについて
-
複数条件での検索について教え...
-
PHP5でsimple_xml_load_fileす...
-
PHPのリロード時の処理
-
連想配列を複数条件で比較して...
-
PDOのprepareでLIKEの部分一致...
-
POSTされない
-
アップロードしたファイルの絶...
おすすめ情報