前提・実現したいこと
データベースに登録された画像を1つ表示するプログラムは以下のページを参考にしてできたのですが
データベースに登録された画像をすべて表示するプログラムを作成したいです
参考にしたサイト
upimg.php (画像をデータベースに登録するコード)
<HTML> <HEAD> <META http-equiv="Content-Type" content="text/html; charset=utf-8"> <TITLE>データベースへの画像の格納</TITLE> </HEAD> <P>ファイルのアップロード</P> <BODY> <FORM method="POST" enctype="multipart/form-data" action="upimg.php"> <INPUT type="hidden" name="MAX_FILE_SIZE" value="65536"> 画像のファイル名を入力してください(最大64KByte)<BR> ファイル名:<INPUT type="text" name="file_name"><BR> パス:<INPUT size="30" type="file" name="upfile"><BR> <BR> <INPUT type="submit" name="submit" value="送信"> <INPUT type="reset" name="reset" value="リセット"> </FORM> <?php if(isset($_POST["submit"])){ try{ $dsn = 'mysql:dbname=map;host=localhost'; $user = 'root'; $password = ''; $dbh = new PDO($dsn, $user, $password); //データベースに接続 $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $dbh->query('SET NAMES utf8'); //文字コードのための設定 print "<hr>"; $file_name = $_POST["file_name"]; $imgdat = file_get_contents($_FILES["upfile"]["tmp_name"]); $sql = "INSERT INTO picture (name,data,type) values (?,?,?)"; $stmt = $dbh->prepare($sql); $data[] = $file_name; $data[] = $imgdat; $data[] = mime_content_type($_FILES["upfile"]["tmp_name"]); $stmt->execute($data); $dbh = null; //データベースから切断 } catch(PDOException $e){ print 'サーバが停止しておりますので暫くお待ちください。'; exit(); } } ?> </BODY> </HTML>
display.php (画像を表示させるコード)
<?php try{ $dsn = 'mysql:dbname=map;host=localhost'; $user = 'root'; $password = ''; $dbh = new PDO($dsn, $user, $password); //データベースに接続 $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $dbh->query('SET NAMES utf8'); //文字コードのための設定 $sql = "SELECT * FROM picture"; $stmt_pic = $dbh->prepare ( $sql ); $stmt_pic->execute (); $row = $stmt_pic->fetchAll ( PDO::FETCH_BOTH ); $dbh = null; //データベースから切断 } catch(PDOException $e){ die($e->getMessage()); print 'サーバが停止しておりますので暫くお待ちください。'; exit(); } foreach($row as $data){ echo '<img src="image.php?id='.$data["id"].'"><br>'.PHP_EOL; } ?>
image.php
<?php try{ $dsn = 'mysql:dbname=map;host=localhost'; $user = 'root'; $password = ''; $dbh = new PDO($dsn, $user, $password); //データベースに接続 $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $dbh->query('SET NAMES utf8'); //文字コードのための設定 $sql = "SELECT * FROM picture where id=?"; $stmt_pic = $dbh->prepare ( $sql ); $stmt_pic->execute ([$_GET["id"]]); $row = $stmt_pic->fetch(PDO::FETCH_ASSOC); $dbh = null; //データベースから切断 } catch(PDOException $e){ die($e->getMessage()); print 'サーバが停止しておりますので暫くお待ちください。'; exit(); } header("Content-Type: ".$row["type"]); print $row["data"]; ?>
補足情報(FW/ツールのバージョンなど)
回答2件
あなたの回答
tips
プレビュー