プログラミング

SNS拡散力アップ!PHPでOG画像付きリッチURLを自作する方法【Curl → Opengraph】

PHP WordPress
SNS拡散力アップ!PHPでOG画像付きリッチURLを自作する方法【Curl → Opengraph】

 

ブログやHPにサイトのURLをただ貼り付けても、どんなページなのか一目でわからないのでなかなか思うようにアクセスに繋がりません

ですが、毎回のようにURL先の画像を準備したり、説明文を設定するのも大変ですし、ページタイトルや画像が差し替わってしまうことも考えられます。

 

今回はそういった手間を簡略化したいと考えている人へ向けて、URLからOG情報を取得してリッチURLを作成する方法をご紹介します。

 

 

ライブラリ「Opengraph」を読み込む

 

URLから取得したOG情報を配列へパースするために、今回はOpengraphというライブラリを使用します。

githubで配布されているので、以下URLよりダウンロードしてください。

 

 

 

ダウンロード後、src内にOpengraphというフォルダがあるので、こちらを導入したいサイトに設置します。

 

設置したら、必要ファイルを読み込むために以下のように記述してください。今回はOG画像付きURLを生成する関数を作成するので、その関数を作るPHPファイルへ記述します。

もしWordPressへ導入する場合はfunctions.phpへ記述することで使用できます。

 

<?php

require_once dirname( __FILE__ ).'/Opengraph/Meta.php';
require_once dirname( __FILE__ ).'/Opengraph/Opengraph.php';
require_once dirname( __FILE__ ).'/Opengraph/Reader.php';

?>

 dirname( __FILE__ )以降は、そのファイルから見たパスを記述してください

 

これでライブラリの準備は完了です。

 

 

URLからページ情報を取得

 

ページ情報を取得するために、URLを引数とした関数を作成します。 

<?php

require_once dirname( __FILE__ ).'/Opengraph/Meta.php';
require_once dirname( __FILE__ ).'/Opengraph/Opengraph.php';
require_once dirname( __FILE__ ).'/Opengraph/Reader.php';

function createOgLink($url){

         # curlを使用
         $option = [
                   CURLOPT_RETURNTRANSFER => true, //文字列として返す
                   CURLOPT_TIMEOUT        => 3, // タイムアウト時間
         ];

         $ch = curl_init($url);
         curl_setopt_array($ch, $option);

         $json    = curl_exec($ch);
         $info    = curl_getinfo($ch);
         $errorNo = curl_errno($ch);

         // OK以外はエラーなので空白配列を返す
         if ($errorNo !== CURLE_OK) {
                   // 詳しくエラーハンドリングしたい場合はerrorNoで確認
                   // タイムアウトの場合はCURLE_OPERATION_TIMEDOUT
                   $json = [];
         }

         // 200以外のステータスコードは失敗とみなし空配列を返す
         if ($info['http_code'] !== 200) {
                   $json = [];

         }

         $reader = new Opengraph\Reader();
         $reader->parse($json);
         $content = $reader->getArrayCopy();

         echo '<pre>';
         print_r($content);
         echo '</pre>';

}

createOgLink('https://s-yqual.com/blog/655');

?>

 

今回はcreateOgLinkという自作関数を作成しました。

どういった情報が返ってくるのか確認するために、print_rpreタグで囲って出力しています。

 

返却データは以下の通りです。 

Array
(
    [og:site_name] => 読んで楽しいプログラミング -YQUAL-ワイコール
    [og:locale] => ja_JP
    [og:url] => https://s-yqual.com/blog/655
    [og:title] => 今からできる!ブログのアクセスを爆UPさせる3大SNS活用法 - YQUAL -ワイコール-
    [og:type] => article
    [og:description] => 集客するならSNSマーケティングは、現代では必須とまで言われるぐらいになりました。フェイスブックやツイッター、インスタグラムをどのように運用すればブログのアクセス数を伸ばすことが出来るのか。素人の方でも実践できる方法とタイトルやサムネイル、ディスクリプションの重要さ、収益化するための実用的な運用方法を公開します。
    [og:image] => Array
        (
            [0] => Array
                (
                    [og:image:url] => https://s-yqual.com/yqual/wp-content/uploads/2020/06/20200621-768x432.jpg
                )
        )
)

 

curlでアクセスしてOpengraphを使ってパースすることで、配列の状態で情報を取得することができました。

後は必要なものを取り出して、タグで出力するだけです。

 

 

タイムアウトの設定

 

注意点をいくつかご紹介します。

urlを投げて情報を取得するだけなら、file_get_contentsを使っても可能です。ですが、それだとエラーやタイムアウトへの対応がしづらくなるため、今回はcurlを使用して取得しています。

ユーザーの接続環境が悪いと、タイムアウトの設定がされていなければ接続に時間がかかってしまい、ページを表示する前に離脱してしまうことが懸念されます。

なので、必ずタイムアウトの設定はしておきましょう

 

 

取得できなかった場合を想定

 

タイムアウトしたり、URL先にOG情報が設定されていない場合、出力時にエラーが発生します。

そのため、curlで取得したjsonデータが空だった場合は、その時点で中断してそのままURLのみで返却します。

 

なので、$reader = new Opengraph\Reader(); の前に以下のコードを追加します。

if(empty($json)){
         ?>
         <a href="<?=$url?>"><?=$url?></a>
         <?php
         return;
}

 

これで、余分な処理が行われる前にURLのみのタグを返却することができます。

もし、こちらに装飾をしたい場合は、書き出したいタグやクラスを指定してください。

 

 

画像付きURLの作成

 

配列を準備できれば、後は展開するだけです。

今回は画像とタイトルとディスクリプションをaタグで囲うだけの単純な出力をします。

<?php

require_once dirname( __FILE__ ).'/Opengraph/Meta.php';
require_once dirname( __FILE__ ).'/Opengraph/Opengraph.php';
require_once dirname( __FILE__ ).'/Opengraph/Reader.php';

function createOgLink($url){

         # curlを使用
         $option = [
                   CURLOPT_RETURNTRANSFER => true, //文字列として返す
                   CURLOPT_TIMEOUT        => 3, // タイムアウト時間
         ];

         $ch = curl_init($url);
         curl_setopt_array($ch, $option);

         $json    = curl_exec($ch);
         $info    = curl_getinfo($ch);
         $errorNo = curl_errno($ch);

         // OK以外はエラーなので空白配列を返す
         if ($errorNo !== CURLE_OK) {
                   // 詳しくエラーハンドリングしたい場合はerrorNoで確認
                   // タイムアウトの場合はCURLE_OPERATION_TIMEDOUT
                   $json = [];
         }

         // 200以外のステータスコードは失敗とみなし空配列を返す
         if ($info['http_code'] !== 200) {
                   $json = [];
         }

         # 返却値が空であれば、og無しのURLを返却
         if(empty($json)){
                   ?>
                   <a href="<?=$url?>"><?=$url?></a>
                   <?php
                   return;
         }

         $reader = new Opengraph\Reader();
         $reader->parse($json);
         $content = $reader->getArrayCopy();

         ?>
         <a href="<?=$url?>">
                   <img src="<?=$content['og:image'][0]['og:image:url']?>">
                   <h3><?=$content['og:title']?></h3>
                   <p><?=$content['og:description']?></p>
         </a>
         <?php

}

createOgLink('https://s-yqual.com/blog/655');

?>

 

出力結果は以下のようになります。 サイトのデザインに応じて、タグを追加したりCSSで装飾をするようにしてください。

 

 

パーツ不足を想定

 

サイトによっては、画像の設定がされていなかったりディスクリプションが抜けているなどというケースも考えられます。

エラーやレイアウト崩れを回避するためにも、しっかりと分岐させて出力をするようにしておきましょう 

<a href="<?=$url?>">

         <?php if(isset($content['og:image'][0]['og:image:url']) && $content['og:image'][0]['og:image:url']): ?>
                   <img src="<?=$content['og:image'][0]['og:image:url']?>">
         <?php endif; ?>

         <?php if(isset($content['og:title']) && $content['og:title']): ?>
                   <h3><?=$content['og:title']?></h3>
         <?php endif; ?>

         <?php if(isset($content['og:description']) && $content['og:description']): ?>
                   <p><?=$content['og:description']?></p>
         <?php endif; ?>

</a>

 

空出力されてもレイアウト崩れしない場合は、issetのみで分岐しても構いません。もしターゲットを指定する場合、第2引数で指定することもできるので、実際の運用に合わせて追加してください。

 

以下が最終コードです。

<?php

require_once dirname( __FILE__ ).'/Opengraph/Meta.php';
require_once dirname( __FILE__ ).'/Opengraph/Opengraph.php';
require_once dirname( __FILE__ ).'/Opengraph/Reader.php';

function createOgLink($url){

         # curlを使用
         $option = [
                   CURLOPT_RETURNTRANSFER => true, //文字列として返す
                   CURLOPT_TIMEOUT        => 3, // タイムアウト時間
         ];
 
         $ch = curl_init($url);
         curl_setopt_array($ch, $option);

         $json    = curl_exec($ch);
         $info    = curl_getinfo($ch);
         $errorNo = curl_errno($ch);

         // OK以外はエラーなので空白配列を返す
         if ($errorNo !== CURLE_OK) {
                   // 詳しくエラーハンドリングしたい場合はerrorNoで確認
                   // タイムアウトの場合はCURLE_OPERATION_TIMEDOUT
                   $json = [];
         }

         // 200以外のステータスコードは失敗とみなし空配列を返す
         if ($info['http_code'] !== 200) {
                   $json = [];
         }

         # 返却値が空であれば、og無しのURLを返却
         if(empty($json)){
                   ?>
                   <a href="<?=$url?>"><?=$url?></a>
                   <?php
                   return;
         } 

         $reader = new Opengraph\Reader();
         $reader->parse($json);
         $content = $reader->getArrayCopy(); 

         echo '<pre>';
         print_r($content);
         echo '</pre>';

         ?>
         <a href="<?=$url?>">

                   <?php if(isset($content['og:image'][0]['og:image:url']) && $content['og:image'][0]['og:image:url']): ?>
                            <img src="<?=$content['og:image'][0]['og:image:url']?>">
                   <?php endif; ?>

                   <?php if(isset($content['og:title']) && $content['og:title']): ?>
                            <h3><?=$content['og:title']?></h3>
                   <?php endif; ?>

                   <?php if(isset($content['og:description']) && $content['og:description']): ?>
                            <p><?=$content['og:description']?></p>
                   <?php endif; ?>

         </a>
         <?php

}

createOgLink('https://s-yqual.com/blog/655');

?>

 

 

まとめ

 

いかがだったでしょうか。

ページ内リンクをさせてPV数を上げる場合、ただURLを貼り付けるだけではなく、こういった押したくなるような仕掛けがあると格段に効果はアップします

また、ブログの場合は記事内で画像がくれば、それだけページのクオリティは高く感じられるため、外部リンクで使用する場合も効果的です。なので、サイト作りやブログ運営をしている人は、ぜひ参考にしてみてくださいね。

 

注目の記事

動画編集に役立つ基本的な考え方【Adobe AfterEffects】
動画編集
Adobe,AfterEffects,PremierePro,YouTube
動画編集に役立つ基本的な考え方【Adobe AfterEffects】

  YouTubeの人気に合わせて、動画編集の需要も高まってきましたが、その大変さから挫折してしまう人も続出しています。 動画編集は奥が深く、技術的な部分に関してはプロのクリエイターであっても自分がよく使うような一部しか把握していないのが普通であり、調べても該当する情報が出てきにくいということもあ...

【Youも明日からデザイナー】デザインセンスを磨くコツ3つ
デザイン
YouTube,サムネイル,バナー
【Youも明日からデザイナー】デザインセンスを磨くコツ3つ

  デザイナーにセンスは必要か?   この問いに、私は必ず「必要ない」と答えます。確かに、センスを磨くことは大切ですが、それがあたかも才能のように表現するのは間違っていると思っているからです。 デザインは誰にでもできます。そしてオリジナリティは各自が必ず持っています。だからこそ、なりたい...

PHPポケモン「バトルシステム編〜努力値の獲得〜」33
プログラミング
PHP,PHPポケモン,ポケモン
PHPポケモン「バトルシステム編〜努力値の獲得〜」33

努力値の実装 今回はポケモンのやりこみ要素の一つ、努力値システムを導入します。既に努力値の項目は「ピカチュウで学ぶオブジェクト指向」の段階で実装し、ステータス計算にも判定済みですが、肝心な「努力値を獲得する仕組み」自体は出来ていませんでした。なので、バトルシステムも終盤となったこのタイミングで...

甘い誘惑に気をつけよう「わからないことへの対処法」
雑記
甘い誘惑に気をつけよう「わからないことへの対処法」

  最近は開発記事が多めだったので、今回は気分転換も込めてみんな大好きコラムのコーナーです。開発疲れという理由ももちろんありますが、久々に考えを書き綴りたくなったというのが本音です。   今回のテーマは「甘い誘惑に気をつけよう」です。高校生ぐらいまではあまり縁がなかったことでも、大学生・社会...

保守っていくらで何をする?フリーランスWebエンジニア対象!保守業務について解説します
フリーランス
システムエンジニア,フリーランス,プログラマー
保守っていくらで何をする?フリーランスWebエンジニア対象!保守業務について解説します

  サイトの保守を頼まれたけど、具体的に何をやればいいの?   フリーランスの、特に独学やスクール上がりでなった人にとっては保守は何をすれば良いかわからないという悩みを抱えている人は多いのではないでしょうか。 システム開発会社や制作会社にいた人でも、どのぐらいの金額で請け負うのが良いか検...

ブログ運営者のための「よくわかるSEO対策」フィード編
SEO対策
atom,feedly,rss,WebSub,WordPress,xml,フィード
ブログ運営者のための「よくわかるSEO対策」フィード編

  アメブロやFC2など優れたブログサービスが存在している中、好きなデザイン、こだわった機能を求めてWordPressを選択される方も多いですね。 また、コーポレートサイトにWordPressを用いる方もいるでしょう。ただしSEO対策がしっかりとされていなければ、提供されているサービスに太刀打ちできません。  もちろん...

初心者必見!仕事がデキる人のIllustrator活用術3選
デザイン
Adobe,Illustrator,サムネイル
初心者必見!仕事がデキる人のIllustrator活用術3選

  仕事の速い人の大半は、「効率の良い方法」や「便利な使い方」を知っていて使いこなしています。これは、デザインの現場でも同じです。 今回はその中でもIllustratorで知っておくと便利な機能を3つご紹介します。この3つを押さえておくだけで、作業効率は格段にアップするので、これからソフトの使い方を覚...

config実装編(ドット記法・多次元配列) PHPポケモン 71
プログラミング
PHP,PHPポケモン,ポケモン
config実装編(ドット記法・多次元配列) PHPポケモン 71

configファイルの作成 プログラミングでは設定値というものを使うことが良くあります。量が多い場合はデータベースへ格納して管理する場合も多いですが、わざわざテーブルを用意してまで格納するほどのものでなければ、ファイルに配列として定義してアクセスできる方が便利です。フレームワークではこれらをconfigフ...

カテゴリ

SEO対策 イベント デザイン ネットワーク ビジネスモデル フリーランス プログラミング マーケティング ライティング 動画編集 雑記

タグ

5G Adobe AfterEffects AI ajax amazon Animate api artisan atom Automator AWS Bluetooth CSS CVR description EC-CUBE4 ECショップ ESLint Facebook feedly foreach function Google Google AdSense Honeycode htaccess HTML IEEE 802.11ax Illustrator Instagram IoT JavaScript jQuery jQuery UI keyword LAN Laravel Linux MacBook MAMP meta MLM MySQL NoCode note OS OSI参照モデル Paypal Photoshop PHP phpMyAdmin PHPポケモン PremierePro rss SEO SEO対策 Sequel Pro Skype SNS SSH Symfony TCP/IP title Toastr Trait Twig Twitter UCC V系 WAN WebSub Wi-Fi wiki Windows WordPress XAMPP xml Xserver YouTube YouTuber Zoom アーティスト アウトプット アクセス層 アニメーション アフィリエイト イーブイ インターネット インプット エンジニア オブジェクト指向 お金配り クリック単価 クリック数 コミュニケーション能力 コロナ コンサルティング サムネイル システムエンジニア スタートアップ スタイルシート スパム データベース ディープフェイク デザイナー デザイン テレワーク ナンパ ニュース ネットワークモデル ノマドワーク バナー ピカチュウ ビジネス フィード フリーランス ブロガー ブログ プログラマー プログラミング プログラミング学習 プログラミング教育 プロトコル ホームページ制作 ポケモン マークアップ マーケティング メール リモートワーク レンダリング 三井住友 三宮 仕事依頼 児童デイ 児童デイサービス 児童発達支援 公開鍵 初心者 助成金 勉強法 営業 広告 広告収入 必勝マニュアル 放課後等デイサービス 朝活 楽天 深層学習 無線LAN 独立 神戸 福祉 秘密鍵 翻訳 自己啓発 英語 見積書 計算機 読書 起業 迷惑メール 配列 銀の弾丸 集客 雑学力