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

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

ただいまの
回答率

90.52%

  • PHP

    20288questions

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

  • Android

    6509questions

    Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

PHPからAndroidに画像(バイナリ)を送りたい

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 505

takg

score 57

前提・実現したいこと

androidからPOSTされた検索ワードを基に、
MySQLからMEDIUMBLOB型に詰められた画像をSELECTし、
androidに送り返そうとしています。

発生している問題・エラーメッセージ

android側で画像が受け取れません。

該当のソースコード

(DB)
name VARCHAR
image MEDIUMBLOB

(PHP)

<?php
  //検索ワードの取り出し
  $searchWord = $_POST['searchWord'];

  //略

  //クエリの実行
  $stmt = $mysqli->prepare("SELECT * FROM xxx WHERE name = ?");
  $stmt->bind_param("s", $searchWord);
  $result = $stmt->execute();

  //データの送信
  header('Content-type: image/jpeg');
  echo $row['image'];
  exit;
?>

(Android)

@非同期処理クラス
  protected Bitmap doInBackground(Void... params) {
    //略

   //画像の受け取り
   InputStream inputStream = connection.getInputStream();
   Bitmap bitmap_result = BitmapFactory.decodeStream(inputStream);
  }

試したこと

android側で、connection.getContentType()を用いたところ、
Content-type: image/jpeg
が受け取れていることは確認できています。
受け取ったBitmapがNULLになってしまっている状態です。

宜しくお願いします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • Y.H.

    2017/03/03 12:58 編集

    「$searchWord = $_POST['searchWord'];」 を一時的に「$searchWord = $_GET['searchWord'];」に変更し、ブラウザで 「http://example.com/getimage.php?searchWord=ほげほげ」にアクセスすれば表示されます。(FQDNとphpのファイル名および「ほげほげ」はtakgさんの環境に合わせてください。)

    キャンセル

  • takg

    2017/03/03 17:58

    ありがとうございます。確かにGETを使えば簡単に確認できますね。 確認してみたところうまくゆかず、SELECT文周辺の処理に問題があることが分かり、無事解決致しました。 Y.H.様にご指摘頂いたブラウザを用いた確認というアイデアが、大変勉強になりました。 ご助言ありがとうございました。

    キャンセル

  • Y.H.

    2017/03/03 18:04

    ご自分で回答としてphp側の問題だった旨記載し解決済みにしていただければと思います

    キャンセル

回答 2

+1

$row['image']が唐突に出てきますが、$resultから$rowを抜き出してないからではないでしょうか?

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/03/03 17:49

    すみません、質問を投稿する際の記入漏れでした。。。
    確認不足、大変申し訳ありません。

    キャンセル

check解決した方法

0

通信処理に特に問題は無く、SELECT文周りの処理を変えてみると画像を受け取ることが出来ました。
まだきちんと理解できていませんが、SELECTの処理には結果を変数にバインドする必要があるようです。
参考:[PHP] mysqli使い方まとめ(MySQL接続~SELECT実行まで)

取り急ぎ下記のような方法で解決しましたが、画像が複数になったときや、他のパラメータも同時に送りたくなったときにどうするのか?といった問題が考えられるので、もう少し工夫する必要があると思います。

<?php
    $searchWord = $_POST['name'];

    //略

    $sql = "SELECT image FROM xxx WHERE name = ?";
    if ($stmt = $mysqli->prepare($sql)) {
        global $searchWord;
        // 条件値をSQLにバインドする
        $stmt->bind_param("s", $searchWord);

        // 実行
        $stmt->execute();

        // 取得結果を変数にバインドする
        $stmt->bind_result($image);
        while ($stmt->fetch()) {
            header('Content-type: image/jpeg');
            echo $image;
        }
        $stmt->close();
    }
?>

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 90.52%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • PHP

    20288questions

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

  • Android

    6509questions

    Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。