実現したいこと
Twitter投稿時にツイッターカードを表示させたい
Laravel7を使っていて
サーバーはherokuを使っています
このサイトを参考にしています
https://catnose99.com/cloudinary-dynamic-ogp-image/
#悩んでいること
設定自体はできてると思っているのですが、Twitter Card validatorで確認したところ
ーーーーーーーーーーーーーーーーーーーーーーー
INFO: Page fetched successfully
WARN: No metatags found
ーーーーーーーーーーーーーーーーーーーーーーー
との表示がされます。実際にURL付きでツイートをしてみても何も表示されません
robots.txtや.htaccessで特に制限はしていない
画像が指定してあるURLを叩けばアクセスできる
OGPの設定を確認するchromeの拡張機能では設定通りの文言や画像が表示されている
chromeの「検証」でもメタタグが表示されている
のような感じです
いろいろ調べましたが、自分では検討がつかなくなってきましたので、どなたか助けて欲しいです。。。
よろしくお願いします!
参考
下記に、実際の設定内容を添付します
robots.txt(laravelデフォルト)
User-agent: * Disallow:
.htaccess(laravelデフォルト)
<IfModule mod_rewrite.c> <IfModule mod_negotiation.c> Options -MultiViews -Indexes </IfModule> RewriteEngine On # Handle Authorization Header RewriteCond %{HTTP:Authorization} . RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}] # Redirect Trailing Slashes If Not A Folder... RewriteCond %{REQUEST_FILENAME} !-d RewriteCond %{REQUEST_URI} (.+)/$ RewriteRule ^ %1 [L,R=301] # Send Requests To Front Controller... RewriteCond %{REQUEST_FILENAME} !-d RewriteCond %{REQUEST_FILENAME} !-f RewriteRule ^ index.php [L] </IfModule>
<meta property="og:site_name" content="sitename"/> <meta property="og:type" content="website"/> <meta property="og:title" content="title"/> <meta property="og:description" content="description"/> <meta property="og:url" content="https://xxx.net"/> <meta property="og:image" content="https://res.cloudinary.com/dajbcpqeh/image/upload/l_text:Sawarabi%20Gothic_50_bold:これはOGPテキストです!,co_rgb:333,w_500,c_fit/c_scale,h_420/v1623414920/ogp_ibkw4a.png"/> <meta property="og:locale" content="ja_JP"/> <meta name="twitter:card" content="summary_large_image"/> <meta name="twitter:title" content="sitename"/> <meta name="twitter:description" content="description"/> <meta name="twitter:image" content="https://res.cloudinary.com/dajbcpqeh/image/upload/l_text:Sawarabi%20Gothic_50_bold:これはOGPテキストです!,co_rgb:333,w_500,c_fit/c_scale,h_420/v1623414920/ogp_ibkw4a.png"/>
#追記
継承元のレイアウト
views/Layout/main.blade.php
<!DOCTYPE html> <html lang="ja"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <meta name="description" content="デスクリプション"> @yield('ogp') <link href="{{ asset('css/app.css') }}" rel="stylesheet"> <script defer src="https://use.fontawesome.com/releases/v5.13.0/js/all.js" integrity="sha384-ujbKXb9V3HdK7jcWL6kHL1c+2Lj4MR4Gkjl7UtwpSHg/ClpViddK9TI7yU53frPN" crossorigin="anonymous"></script> <script src="https://cdn.jsdelivr.net/gh/alpinejs/alpine@v2.x.x/dist/alpine.min.js" defer></script> @hasSection('title') <title>@yield('title') | {{ config('app.name') }}</title> @else <title>{{ config('app.name') }}</title> @endif </head> <body> <header> ヘッダー </header> <div class="bg-gray-100 flex-grow"> <div class="flex-grow"> @yield('main') </div> </div> <footer> フッター </footer> </body> </html>
content.blade.php
@extends('Layout.main') @section('ogp') <meta property="og:site_name" content="サイト名"/> <meta property="og:type" content="website"/> <meta property="og:title" content="タイトル"/> <meta property="og:description" content="デスクリプション"/> <meta property="og:url" content="サイトURL/> <meta property="og:image" content="https://res.cloudinary.com/dajbcpqeh/image/upload/l_text:Sawarabi%20Gothic_50_bold:これはOGPテキストです!,co_rgb:333,w_500,c_fit/c_scale,h_420/v1623414920/ogp_ibkw4a.png"/> <meta property="og:locale" content="ja_JP"/> <meta name="twitter:card" content="summary_large_image"/> <meta name="twitter:title" content="タイトル"/> <meta name="twitter:description" content="デスクリプション"/> <meta name="twitter:image" content="https://res.cloudinary.com/dajbcpqeh/image/upload/l_text:Sawarabi%20Gothic_50_bold:これはOGPテキストです!,co_rgb:333,w_500,c_fit/c_scale,h_420/v1623414920/ogp_ibkw4a.png"/> @endsection @section('main') <div> hogehoge </div> @endsection
該当ファイルを追記しました。
また自分で別のLaravelプロジェクトを作り、そこで同じコードでTwitter card Validatorをやってみるとちゃんと表示されました。
現在のLaravelプロジェクトのみ表示されないようです。。。
#追記2
###上手くいくほう
<!DOCTYPE html> <html lang="ja"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <meta name="description" content="デスクリプション"> <meta property="og:site_name" content="サイト名"/> <meta property="og:type" content="website"/> <meta property="og:title" content="タイトル"/> <meta property="og:description" content="デスクリプション"/> <meta property="og:url" content="サイトURL"/> <meta property="og:image" content="https://res.cloudinary.com/dajbcpqeh/image/upload/l_text:Sawarabi%20Gothic_50_bold:これはOGPテキストです!,co_rgb:333,w_500,c_fit/c_scale,h_420/v1623414920/ogp_ibkw4a.png"/> <meta property="og:locale" content="ja_JP"/> <meta name="twitter:card" content="summary_large_image"/> <meta name="twitter:title" content="タイトル"/> <meta name="twitter:description" content="デスクリプション"/> <meta name="twitter:image" content="https://res.cloudinary.com/dajbcpqeh/image/upload/l_text:Sawarabi%20Gothic_50_bold:これはOGPテキストです!,co_rgb:333,w_500,c_fit/c_scale,h_420/v1623414920/ogp_ibkw4a.png"/> <script defer src="https://use.fontawesome.com/releases/v5.13.0/js/all.js" integrity="sha384-ujbKXb9V3HdK7jcWL6kHL1c+2Lj4MR4Gkjl7UtwpSHg/ClpViddK9TI7yU53frPN" crossorigin="anonymous"></script> <script src="https://cdn.jsdelivr.net/gh/alpinejs/alpine@v2.x.x/dist/alpine.min.js" defer></script> </head>
<!DOCTYPE html> <html lang="ja"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <meta name="description" content="デスクリプション"> <meta property="og:site_name" content="サイト名"/> <meta property="og:type" content="website"/> <meta property="og:title" content="タイトル"/> <meta property="og:description" content="デスクリプション"/> <meta property="og:url" content="サイトURL"/> <meta property="og:image" content="https://res.cloudinary.com/dajbcpqeh/image/upload/l_text:Sawarabi%20Gothic_50_bold:これはOGPテキストです!,co_rgb:333,w_500,c_fit/c_scale,h_420/v1623414920/ogp_ibkw4a.png"/> <meta property="og:locale" content="ja_JP"/> <meta name="twitter:card" content="summary_large_image"/> <meta name="twitter:title" content="タイトル"/> <meta name="twitter:description" content="デスクリプション"/> <meta name="twitter:image" content="https://res.cloudinary.com/dajbcpqeh/image/upload/l_text:Sawarabi%20Gothic_50_bold:これはOGPテキストです!,co_rgb:333,w_500,c_fit/c_scale,h_420/v1623414920/ogp_ibkw4a.png"/> <script defer src="https://use.fontawesome.com/releases/v5.13.0/js/all.js" integrity="sha384-ujbKXb9V3HdK7jcWL6kHL1c+2Lj4MR4Gkjl7UtwpSHg/ClpViddK9TI7yU53frPN" crossorigin="anonymous"></script> <script src="https://cdn.jsdelivr.net/gh/alpinejs/alpine@v2.x.x/dist/alpine.min.js" defer></script> </head>
あなたの回答
tips
プレビュー