WEBLIC LLC

ブログ

TwitterでOGP画像が表示されない時の対処法

Web制作

2023年8月1日

Twitterで記事をシェアしたときに、期待したOGP画像が表示されないことはありませんか?
この記事では、その解決法について解説します。

OGPタグとは

OGPタグは、以下のようにHTMLの<head>部分に記述されます。

	<meta property="og:image" content="【画像URL】">
	<meta name="twitter:card" content="summary_large_image">

これらのタグは、ウェブページがSNS上で共有されたときにどのような表示にするかを制御するものです。しかし、正しく記述していても画像が表示されない場合があります。

Twitterカードの表示例
OGP画像が表示されているツイート

Twitter Card Validator

Twitterでは以前、ページのプレビューを確認できる「Card Validator」ツールを提供していました。しかし、2022年をもってこのツールは廃止され、現在は使用できません。

Twitterのキャッシュ問題

表示されない一因としては、Twitter側のキャッシュが考えられます。キャッシュが原因の場合、OGP画像のURLにパラメータを追加して再度試すと、正しく表示されることがあります。

しかし今回、私が遭遇した問題は異なりました。

Twitterのクローラのサイズ制限

実は、Twitterのクローラには特定のサイズ制限があります。ページ全体が一定のサイズを超えると、「ERROR: Fetching the page failed because the response is too large」というエラーが発生するのです。

この問題に直面したのは、最近私たちが制作したニチリンインターナショナル株式会社様のウェブサイトでした。サイトのデザインには、SVGを用いたアニメーションが特徴的で、そのためのSVGコードが非常に長くなってしまいました。また、PCとモバイルで異なるアニメーションを表示するために、それぞれに対応したSVGコードをページ内に全て含めていたため、一度に読み込まれるデータ量が大きくなってしまっていました。

この結果、ページ全体のサイズが大きくなりすぎ、Twitterのクローラによるページ取得がうまく行かなくなってしまいました。これが「ERROR: Fetching the page failed because the response is too large」のエラーメッセージの原因でした。

解決法

この問題を解決するために、Javascriptを使って必要なときだけSVGを出力するように変更。これにより、ページ全体のサイズを減らし、Twitterのクローラがページを正常に取得できるようになりました。

もしTwitterでOGP画像が表示されない場合、ページ全体のファイルサイズをチェックしてみてください。必要ない部分を削除したり、Javascritを使って表示を制御したりすることで、問題が解決するかもしれません。

関連記事

Web制作

WordPressがSEOに強いって言われるけどホントなの?

WordPressはSEO(検索エンジン最適化)に強いと言われますが、本当に強いのか疑問に思いません...

2023年10月10日

Web制作

共有レンタルサーバーが引き起こすリスク!IPブラックリスト問題とその解決策

新規契約したサーバー、ドメインなのにサイトが表示されない!!今回このような状況に陥ったので、原因究明...

2024年8月30日

Web制作

スマホサイトで便利!片方可変のボックスレイアウトの作りかた

こんにちは。丹羽です。スマホサイトでは画面の幅がデバイスによってバラバラです。より少ないCSSコーデ...

2016年10月31日

Web制作

WordPressでショートコードを使って外部PHPファイルを読み込む方法

WordPressでサイトを構築している方には馴染みのあるショートコード。例えばお問い合わせのプラグ...

2024年7月12日

Web制作

Sass mixinの引数に0を指定する方法

背景画像をカラムごとに違う画像を配置するため、mixinを使って設定しましたが、うまくいきませんでし...

2016年12月12日

  • カテゴリー

  • 本日、 17人が閲覧しました

    RELATED SITES

    関連サイト

    • SAKAMOTO Blog
    Designed by WEBLIC合同会社