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

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

ただいまの
回答率

87.92%

PHPでgoogle検索結果を抽出する際に出るエラー

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 484

score 5

前提・実現したいこと

PHPです。
mysqlのクエリ結果をfile_get_contentsの()内に入れるとエラーがでます。
同じ文字列を直接書き込んだり、新たに宣言して変数にして()内に入れるとエラー無く表示されます。クエリの結果をそのまま、もしくは、一度変数に置き換えてもエラーがでます。

■■な機能を実装中に以下のエラーメッセージが発生しました。

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

failed to open stream: HTTP request failed! HTTP/1.0 400 Bad Request in /home/*****

エラー行
$data = file_get_contents($title2);

該当のソースコード

$sql3 = "SELECT * FROM AAA WHERE `title` like '" . $title . "'  LIMIT 0 , 1";
$stmt3 = $pdo->query($sql3);

while($rs3 = $stmt3->fetch(PDO::FETCH_ASSOC)){

$img = $rs3['thumb'];
if($img==""){

//$title = "車"; このように同じ文字列でも代入するとエラーはでません。                                            
//$title2 = "https://www.google.co.jp/search?q=" . $title . "&tbm=isch";
$title2 = "https://www.google.co.jp/search?q=$title&tbm=isch";        
$data = file_get_contents($title2);
$data = explode( "\n", $data );
$cnt = count( $data );
for( $i=0;$i<$cnt;$i++ )
{
echo($data[$i]);
}

試したこと

試したことは、()内を出力してみてなにか変な事になっていないか?は試しましたが一見おかしな所はないように思えました。

//の部分はこれも試したという部分です。

※追記やりたいことの説明を説明いたします。

やりたいこととソースの流れをご説明させていただきます。

$sql3 = "SELECT * FROM AAA WHERE title like '" . $title . "' LIMIT 0 , 1";
$stmt3 = $pdo->query($sql3);

while($rs3 = $stmt3->fetch(PDO::FETCH_ASSOC)){

$img = $rs3['thumb'];
if($img==""){

データーベースの中からタイトルを検索し、そのタイトルに画像$rs3['thumb']が無い場合
下記の処理に移ります。

$title2 = "https://www.google.co.jp/search?q=$title&tbm=isch";

↑次の行のfile_get_contentsでエラーが出たため()内の状態を見る為に一度$title2に代入してみました。
echo やvar_dumpでも確認しましたが、 所はなかったです。

$data = file_get_contents($title2);←エラーがでます。

もしエラーが出なければ、検索結果のページを表示したいです。

$data = explode( "\n", $data );
$cnt = count( $data );
for( $i=0;$i<$cnt;$i++ )
{
echo($data[$i]);


$title2 = "https://www.google.co.jp/search?q=$title&tbm=isch";
この状態ではエラーがますが

$title2 = "https://www.google.co.jp/search?q=車&tbm=isch";
上記のように変数を入れなければエラーがでません

また、
$title = "車";
$title2 = "https://www.google.co.jp/search?q=$title&tbm=isch";
のように直前で宣言した場合でもエラーはでません。

※※
この$titleは直前に下記の様な方法で取得しております。
while($rs2 = $stmt2->fetch(PDO::FETCH_ASSOC)){
// 1行ごとに$rsにデータが入ります
$title = $rs2['title'];

補足情報(FW/ツールのバージョンなど)

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

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • TAPIOKAMAN

    2019/09/20 15:41 編集

    ご返信、ご指摘ありがとうございます。
    まず、ソースを切り抜いたときに生じた記述ミス、そしてインデントの修正を行わせていただきました。

    やりたいこととソースの流れをご説明させていただきます。
    ※追記として編集させていただきました。

    何卒よろしくお願いいたします。

    キャンセル

  • yambejp

    2019/09/20 15:47

    ソースは質問に追記する形で記載ください

    キャンセル

  • TAPIOKAMAN

    2019/09/21 00:35

    ご返信ありがとうございます。
    初回利用の為かってが解らずご迷惑をおかけしております。
    追記として編集させていただきました。

    キャンセル

回答 2

+2

Google検索の結果を機械的に取得することは、原則禁止されています。

Google の利用規約では、どのような種類かに関わらず、自動化されたクエリを Google から明示的な許可を事前に得ずに Google のシステムに送信することは禁止されています。(Search Console ヘルプより)

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

checkベストアンサー

+1

エラー行と書かれたソースの「$title2」は、該当のソースに記載がありません
そのあたりから検証が必要でしょうね
またgoogle検索と言いつつ、sqlで検索をするような内容も整合性が取れていません
何をどうするとどういう結果が期待されるのかきちんとまとめてから質問されると良いでしょう

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/09/20 15:43

    ご返信、ご指摘ありがとうございます。
    まず、ソースを切り抜いたときに生じた記述ミス、そしてインデントの修正を行わせていただきました。

    やりたいこととソースの流れをご説明させていただきます。

    $sql3 = "SELECT * FROM AAA WHERE `title` like '" . $title . "' LIMIT 0 , 1";
    $stmt3 = $pdo->query($sql3);

    while($rs3 = $stmt3->fetch(PDO::FETCH_ASSOC)){

    $img = $rs3['thumb'];
    if($img==""){

    データーベースの中からタイトルを検索し、そのタイトルに画像$rs3['thumb']が無い場合
    下記の処理に移ります。

    $title2 = "https://www.google.co.jp/search?q=$title&tbm=isch";

    ↑次の行のfile_get_contentsでエラーが出たため()内の状態を見る為に一度$title2に代入してみました。
    echo やvar_dumpでも確認しましたが、 所はなかったです。

    $data = file_get_contents($title2);←エラーがでます。

    もしエラーが出なければ、検索結果のページを表示したいです。

    $data = explode( "\n", $data );
    $cnt = count( $data );
    for( $i=0;$i<$cnt;$i++ )
    {
    echo($data[$i]);



    $title2 = "https://www.google.co.jp/search?q=$title&tbm=isch";
    この状態ではエラーがますが

    $title2 = "https://www.google.co.jp/search?q=車&tbm=isch";
    上記のように変数を入れなければエラーがでません

    また、
    $title = "車";
    $title2 = "https://www.google.co.jp/search?q=$title&tbm=isch";
    のように直前で宣言した場合でもエラーはでません。

    ※※
    この$titleは直前に下記の様な方法で取得しております。
    while($rs2 = $stmt2->fetch(PDO::FETCH_ASSOC)){
    // 1行ごとに$rsにデータが入ります
    $title = $rs2['title'];



    何卒よろしくお願いいたします。

    キャンセル

  • 2019/09/20 15:56

    AAAテーブルのthumbカラムの型はBlobか何か?

    $title = $rs2['title'];で$titileが埋まっているなら
    $title2 = "https://www.google.co.jp/search?q=$title&tbm=isch";
    のtitleは埋まっているはずですが?
    ただし$titleはurlencodeしないとダメです

    $h_title=htmlspecialchars($title);
    $title2 = "https://www.google.co.jp/search?q={$h_title}&tbm=isch";

    キャンセル

  • 2019/09/21 00:47

    thumbカラムの型はtextです。

    上記ためしてみましたがエラーは変わらすでした。

    $title2 = "https://www.google.co.jp/search?q={$h_title}&tbm=isch";

    $title2 を出力してみたのですが、問題なく表示されているようでした。
    出力は文字化けしているのですが、$titleのエンコードを変えてもだめでした。文字化けしたままでもエラーにはならないはず、原因は他にある?と考えてしまいます。

    Warning: file_get_contents(https://www.google.co.jp/search?q=縲舌げ繝�せ繝槫�闕キ諠��ア縲素igma縲後い繝エ繧ァ繝ウ繧ク繝」繝シ/繧ク繝」繝ウ繝後�繝€繝ォ繧ッ縲斐が繝ォ繧ソ縲� 譁ー螳ソver.縲阪€後げ繝ェ繝�ラ繝槭Φ縲阪⊇縺狗匱螢イ譌・豎コ螳�&tbm=isch) [function.file-get-contents]: failed to open stream: HTTP request failed! HTTP/1.0 400 Bad Request in /home/user

    キャンセル

  • 2019/09/21 00:54

    urlencode で解決しました!ありがとうございます。

    キャンセル

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

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

関連した質問

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