【スポンサーリンク】

「URLはGoogleに登録されていますが問題があります」? 【AMP動画の必須属性】

「URLはGoogleに登録されていますが問題があります」? 【AMP動画の必須属性】

Googleの検索にブログのURLを登録しようとしたら、こんなエラーに遭遇しました。

動画を扱っているページだったので、動画のAMP対応をしました。

\記事が役に立ったらシェアしてね/
【スポンサーリンク】

1. 「URLはGoogleに登録されていますが問題があります」とは

ブログ記事が出来上がって、Google Search Consoleで、URLをテストしました。

すると、エラーメッセージが表示されました。

「URLはGoogleに登録されていますが問題があります」とは

URLはGoogleに登録されていますが問題があります

AMP AMPページが無効です

はい、またです。

また、AMPページのエラーです。

「URLはGoogleに登録されていますが問題があります」とは

URLテストをすると、AMPページのエラーもすぐにチェックできるんですね

今回は何なのか?ということで、理由を見てみます。

「URLはGoogleに登録されていますが問題があります」とは

AMP HTMLタグの属性で指定されたレイアウトが無効です。

通常ページからAMPページ(軽量版)を機械的に生成するときに、必要な項目が抜けていたようです。

2. amp-videoタグの必須属性

AMPページでは<video>タグを<amp-video>タグに変更する必要があります。この時に、必須属性であるwidth, heightを書き加えないとエラーになってしまうのです。

AMP-VIDEOタグの必須属性
  • width
  • height
GoogleのAMPテスト
GoogleのAMPテスト

必要属性「height」がタグ「amp-video」にありません。

3. 必須属性を自動で追加するようにfunction.phpをいじる

毎回、videoタグで高さや幅を指定するのは大変ですし、通常ページでは大きく表示したいです。

ということで、videoタグをamp-videoタグに書き換える処理に、必須項目を追加する関数をfuntions.phpに追加しました。

function my_convert_content_for_amp( $content ) {
  if ( is_amp() === false ) {
    return $content;
  }
  
  /** video 開きタグを置換 */
  $pattern = '<video';
  $append  = '<amp-video layout="responsive" width="16" height="9"';
  $content = str_replace( $pattern, $append, $content );
  /** video 閉じタグを置換 */
  $content = str_replace( '</video>', '</amp-video>', $content );
  
  return $content;
}
add_filter( 'the_content', 'my_convert_content_for_amp', 999999999 );

WordPressではadd_filterに関数を追加して、いろいろな置換処理を追加できます。

こんな感じで、funtion.phpの末尾にフィルター関数(my_convert_content_for_amp)を追記しています。

function.phpにフィルター関数を追加する

これで、「動画ブロック」を挿入するだけで、AMP有効な動画になります。

動画ブロックを挿入する

できました!

再テストすると、ちゃんと「有効なAMPページです」と表示されました。

有効なAMPページです

元記事に感謝です。ありがとうございました。

こちらもどうぞ

AMPエラー HTML タグに必須属性がありません。- formとJavaScript
AMPエラー HTML タグに必須属性がありません。- formとJavaScript
ブログ記事の中にフォームを入れていたら、AMPエラーになりました。カスタムHTMLを使うとよくAMPエラーになりますね。足りなかったのは、formタグのtarget属性でした。formタグの説明では特に見かけなかったんですが、必須属性なんですね。今回のコードでは、javascriptの関数を動作させるためのボタンを配置するためにフォームを作りました。特にデータをサーバーに送るものでもなかったので、formのプロパティを指定していなかったのが、よくなかったようです。こちらが参考...
AMP HTML タグの属性で指定されたレイアウトが無効です!?〜 video 動画のサイズ指定
AMP HTML タグの属性で指定されたレイアウトが無効です!?〜 video 動画のサイズ指定
「グーグル・サーチ・コンソール」の通知に「AMP HTML タグの属性で指定されたレイアウトが無効です。」というエラーが表示されました。今回は、動画ファイルをアップロードするときの注意点を書きました。表示されたエラーメッセージを読むと通知メッセージによると、AMP(スマホ用に高速表示されるページ)のタグに問題があるようです。Search Console により、貴サイトに影響する「AMP」関連の問題が 1 件検出されました。主なエラーエラーにより、貴サイトのページまたは機能が...
QRコードを読み込むと、関連記事を確認できます。

「URLはGoogleに登録されていますが問題があります」? 【AMP動画の必須属性】
【スポンサーリンク】
タイトルとURLをコピーしました