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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

2回答

9685閲覧

base64を使った画像取得の方法がうまくいきません。

退会済みユーザー

退会済みユーザー

総合スコア0

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

2クリップ

投稿2016/10/13 14:39

編集2016/10/13 14:40

画像をbase64にエンコードしてデータベースに保存するまでは恐らくできたと思うのですがそれを呼び出す際の処理がよくわかりません。

base64は64種類の文字列に置き換えて画像はサイトに埋め込むという理解でよろしいでしょうか。

そう仮定して以下のことをお聞きしたいです。

①base64に置き換えた時に中身をechoするとみたい文字列になっていますがこれも大丈夫でしょうか。

②base64に置き換えた文字列から画像を呼び出す際の処理は一旦別ページにheader("Content-Type: image/jpeg");で画像を出力してからecho "<img src="....">で引っ張てくる方法でしょうか。

試してみたのですがうまくいかず、単純な見落としで表示できていないかのか、重要な記述が抜けたり、間違ったりしているのかがわからない状態です。

よろしくお願いします。

【投稿.php】 <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title></title> <script type="text/javascript"> function changeBase64(imageFile) { if (!imageFile.files.length) return; var file = imageFile.files[0]; var fr = new FileReader(); fr.onload = function(evt) { document.getElementById("image").src = evt.target.result; document.getElementById("imagedata").value = evt.target.result; } fr.readAsDataURL(file); } </script> </head> <body> <form method="POST" action="xxx.php"> <img id="image" src="" alt="画像"> <input type="hidden" name="imagedata" id="imagedata"> <input type="file" accept="image/jpg,image/gif,image/png" onchange="changeBase64(this)"> <input type="submit" value="確定"> </form> </body> </html>
【データベース送る.php】 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>ありがとう</title> </head> <body> <h2>ありがとう</h2> <a href="index.php">戻る</a> <div class="content"> <?php $image=$_REQUEST['imagedata']; insert_proc ($image); // ------------------------------------------------------------------ // // ------------------------------------------------------------------ function insert_proc ($image) { echo ('*** insert_proc *** start ***<br />'); $dsn = 'xxxx'; $user = 'xxx'; $password = 'xxx'; echo('image='. $image. '</br>'); date_default_timezone_set('Asia/Tokyo'); $date_mod = date ("Y-m-d"); echo ('date_mod = ' . $date_mod . '<br />'); try { $pdo = new PDO($dsn,$user,$password); } catch (PDOException $e) { exit('データベースに接続できませんでした。' . $e->getMessage()); } $stmt = $pdo->query('SET NAMES utf8'); if (!$stmt) { $info = $pdo->errorInfo(); exit($info[2]); } echo "*** check *** ppp ***<p />"; $sql="insert into xxx (imagedata)" . "values ('" . $image. "')"; echo $sql . "\n"; $stmt=$pdo->prepare ($sql); $stmt->execute (); } // ------------------------------------------------------------------ ?> </div> </body> </html>

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

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

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

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

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

guest

回答2

0

ベストアンサー

  • まず設計として,表示する直前にBase64エンコードし,それ以外のタイミングでは生データのまま保持しておいたほうが都合がいいです.JavaScriptで無理して変換せず$_FILESで受け取るようにし,データベースにもvarcharやtextではなくblobで突っ込みましょう
  • PDOの書き方に色々と問題があります.SQLインジェクション脆弱性もあります.
  • <meta /> <br /> <hr />などはXHTMLの書き方なので, /の部分は消しましょう.
  • 画像形式の縛り方ですが,JPEGに対応するのはimage/jpegです.しかしIEはどうやら誤って(?)image/jpgとしてしまうこともあるようなので,こちらも念のため入れています.
  • ロジックは頭に書いて,HTMLは後ろに書きましょう.

base64に置き換えた文字列から画像を呼び出す際の処理は一旦別ページにheader("Content-Type: image/jpeg");で画像を出力してからecho "<img src="....">で引っ張てくる方法でしょうか。

それでもいいですが,画像サイズが巨大でなければ  のように埋め込むデータURIスキームのほうがいいと思います.

PHPでデータベースに接続するときのまとめ - Qiita (「初心者がやりがちなミス」の複数に該当しています)
ファイルアップロードの例外処理はこれぐらいしないと気が済まない - Qiita

<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>アップロード</title> </head> <body> <form method="post" action="upload.php" enctype="multipart/form-data"> <input type="file" name="image" accept="image/gif,image/jpeg,image/jpg,image/png"> <input type="submit" value="確定"> </form> </body> </html>
<?php try { if (!isset($_FILES['image']['error']) || !is_int($_FILES['image']['error'])) { throw new RuntimeException('パラメータが不正です', 400); } switch ($_FILES['image']['error']) { case UPLOAD_ERR_OK: break; case UPLOAD_ERR_NO_FILE: throw new RuntimeException('ファイルが選択されていません', 400); case UPLOAD_ERR_INI_SIZE: case UPLOAD_ERR_FORM_SIZE: throw new RuntimeException('ファイルサイズが大きすぎます', 413); default: throw new RuntimeException('その他のエラーが発生しました', 500); } $imagetype = mime_content_type($_FILES['image']['tmp_name']); $imagedata = file_get_contents($_FILES['image']['tmp_name']); if (!in_array($imagetype, ['image/gif', 'image/jpeg', 'image/png'], true)) { throw new RuntimeException('ファイル形式が不正です', 415); } $pdo = new PDO( 'mysql:dbname=example;host=localhost;charset=utf8', 'xxx', 'yyy', [ PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, ] ); $stmt = $pdo->prepare('INSERT INTO images(imagedata) VALUES(?)'); $stmt->execute([$imagedata]); } catch (RuntimeException $e) { header('Content-Type: text/plain; charset=UTF-8', true, $e->getCode() ?: 500); exit($e->getMessage()); } ?> <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>アップロード完了</title> </head> <body> <h1>アップロード完了しました</h1> <a href=".">戻る</a> <div class="content"> <img src="data:<?=$imagetype?>;base64,<?=base64_encode($imagedata)?>"> </div> </body> </html>

投稿2016/10/13 15:49

編集2016/10/13 16:09
mpyw

総合スコア5223

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

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

退会済みユーザー

退会済みユーザー

2016/10/14 05:40

コメントありがとうございます。 最初はBLOBでデータベースに入れていたのですがこちらで質問した際に画像はデータベースに突っ込まないほうがいいとアドバイスがあったためbase64にする方法を試しています。 BLOBで入れて直前にエンコードする方法があるなんて知らなかったです。 検索した限りだと一般的にはbase64に変換して…ばかりだったので。 http://qiita.com/mpyw/items/b00b72c5c95aac573b71の方何度か読ませていただいています。 ロジックは頭に書くなどは本体の方ではやっていたのですが今回のサンプル版では怠っていました。 すいません。 PDOの書き方は一番苦手なので今回のコード含めて出来る限り正しい書き方をもう一度読んでみます。
退会済みユーザー

退会済みユーザー

2016/10/14 05:41

読んで→勉強してみます。
mpyw

2016/10/14 05:46

>> 最初はBLOBでデータベースに入れていたのですがこちらで質問した際に画像はデータベースに突っ込まないほうがいいとアドバイスがあったためbase64にする方法を試しています。 あ,いや,理想は「ファイル名だけをデータベースに入れてバイナリはファイルとして保存しておく」ですね.もちろんバイナリをデータベースに突っ込んだほうが一元的な管理ができるなど有利な面も無くはないですが,コンテンツ配信のために頻繁にデータを取り出す場合には不利になってしまいますね. ただ1つ言えるのは,Base64エンコードしてテキストとしてデータベースに突っ込むのは,この両者のどちらにも劣る方法だということです.
退会済みユーザー

退会済みユーザー

2016/10/14 06:01

なるほど。 だとすると今試している方法は一旦保留にしてみます。 その上で「ファイル名だけをデータベースに入れてバイナリはファイルとして保存しておく」方法とPDOの正しい書き方も再度挑戦してみます。 この度は教えていただきありがとうございます。
guest

0

画像ファイルを作成するのではなく、表示するhtmlに直接
<img src="data:image/png:base64,xxxxx..." />
と書けば表示されます。

投稿2016/10/14 04:13

katsuya141

総合スコア367

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

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

退会済みユーザー

退会済みユーザー

2016/10/14 05:31

コメントありがとうございます。 実は昨日<img src="data:image/png:base64,xxxxx..." /> で画像は出せたのですが何故か出せる画像と出せない画像があります。 これは容量的な問題なのでしょうか。 出せない画像はhttp://tomari.org/main/java/base64d.htmlのサイトでやってもぼやけたりします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問