プログラミング

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を貼り付けるだけではなく、こういった押したくなるような仕掛けがあると格段に効果はアップします

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

 

注目の記事

あばれる編(あばれる・はなびらのまい)PHPポケモン52
プログラミング
PHP,PHPポケモン,ポケモン
あばれる編(あばれる・はなびらのまい)PHPポケモン52

あばれる状態とは 技を使うと、しばらくの間その技のみしか使用できなくなる技があります。その状態を「あばれる状態」と言います。 あばれる状態(ポケモンwiki) https://wiki.ポケモン.com/wiki/あばれる_(状態変化) あばれるの効果 2~3ターンの間攻撃し続け、交換したり、他の指示を出すことが出...

経験値取得アニメーション編(動画有り) PHPポケモン 47
プログラミング
PHP,PHPポケモン,ポケモン
経験値取得アニメーション編(動画有り) PHPポケモン 47

経験値取得アニメーションの実装 最近は技の実装が続いていたので、気分転換にフロント側の演出づくりをしていきます。その中でも今回実装するのは「経験値取得アニメーション」です。 経験値バーはポケモンの第2世代から追加実装された演出です。初代では次のレベルにアップするまでの数値を、わざわざポケモンの...

事業所検索サービス「児発ねっと」児童発達支援・放課後等デイサービス
ビジネスモデル
SEO対策,プログラミング,児童デイサービス,児童発達支援,放課後等デイサービス
事業所検索サービス「児発ねっと」児童発達支援・放課後等デイサービス

どうも、児発ねっとの中の人です。 この度は児童発達支援・放課後等デイサービスといった療育施設の事業所検索サービス「児発ねっと」を開始することになりました。 本ブログでは、プログラミングやデザインといった内容のコンテンツを紹介しているため、児発ねっとのサービスは少し異色になります。なので、今回...

PHPポケモン「野生ポケモン遭遇編」18
プログラミング
PHP,PHPポケモン,ポケモン
PHPポケモン「野生ポケモン遭遇編」18

  PHPポケモンが第18回にしていよいよバトルの第一歩、野生ポケモンとの遭遇編に突入です。 新しいコントローラーの作成と、バトル画面の作成、そしてポケモンデータの受け渡しなどを中心にご紹介します。   バトル画面の実装  ポケモンのゲームでも、野生ポケモンが現れるとバトル画面へ移管し...

PHPポケモン(α)攻略wiki「最初のポケモン」
雑記
PHPポケモン,wiki,ポケモン
PHPポケモン(α)攻略wiki「最初のポケモン」

リリースから一ヶ月、遂にPHPポケモン(α)の攻略Wiki(仮)が公開です!   というのは大嘘で、内部の大幅変更の関係上、今回はPHPポケモンをプレイするにあたってのオススメなどをまとめて見た次第です。 ちなみに、バトルシステム自体は本家に沿って作成しているので、種族値や技性能に精通している人はブラウザ...

【配列とは】初心者が最短でPHPを使えるようになるための実践的な学び方
プログラミング
foreach,PHP,配列
【配列とは】初心者が最短でPHPを使えるようになるための実践的な学び方

  初心者の方、今からプログラミングを始める方、HTMLとCSSの領域から抜け出せない人たちを対象にした、PHPをできるだけ使えるようになるための方法を紹介するコーナー。 栄えある第二回は【配列編】です。   第一回を飛ばしてこのページへに来てしまい「変数って何?」というレベルの人は、第一回の【変数編...

パーティーの並び替え編 PHPポケモン 82
プログラミング
PHP,PHPポケモン,ポケモン
パーティーの並び替え編 PHPポケモン 82

パーティーの並び替え ポケモンをバトルに選出する際に欠かせないのが「パーティーの並び替え」です。パーティーの先頭(ひんし状態でない)がポケモンでは自動的に選択されるため、戦闘前に並び替えをしておく必要があります。 ゲーム上では簡単に見える処理ですが、これがPHPで行うとなれば少し厄介な問題が出てき...

XserverにSequel ProでSSH接続する方法を4ステップでわかりやすく解説
ネットワーク
phpMyAdmin,Sequel Pro,SSH,Xserver,データベース,公開鍵,秘密鍵
XserverにSequel ProでSSH接続する方法を4ステップでわかりやすく解説

  AWSなどが注目される中、Xserver(エックスサーバー)は操作やセットアップが簡単で、ポートフォリオや業務、個人ブログ(WordPess)で使用している方に需要が高いサービスです。 そしてMacのPCを使っている方はデータベースの管理ツールとして、無料で使えるSequel Proが人気があり、多くのユーザーが使用し...

カテゴリ

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 独立 神戸 福祉 秘密鍵 翻訳 自己啓発 英語 見積書 計算機 読書 起業 迷惑メール 配列 銀の弾丸 集客 雑学力