Cocoonフォーラム

サイト内検索
書き込みの前に以下の3点をご確認ください。
  1. 1つのトピックにつき1つの質問を書き込んでください
  2. 不具合・カスタマイズ対象ページのURLを提示高速化を無効にしてください
  3. 該当部分のキャプチャ・環境情報とともに書き込んでいただけると助かります

何を書き込んだら良いか分からない場合は、以下のテンプレートをコピペしてご利用ください。

不具合・カスタマイズ対象ページのURL:

相談内容:

不具合の発生手順:

解決のために試したこと:

※文字だけでは正しく伝わらない可能性があるため、スクショ画像の添付もお願いします。
※高速化設定をしている場合は無効にしてください。
環境情報:

※↑こちらに「Cocoon設定 → テーマ情報」にある「環境情報」を貼り付けてください。

環境情報の取得方法はこちら。
https://wp-cocoon.com/theme-report/
高速化設定を無効にするにはこちら。
https://wp-cocoon.com/theme-trouble/

フォーラム利用ガイドリンク

  1. フォーラムガイドライン
  2. よくある質問と答え(FAQ)
  3. サポート対象外のケース
  4. 原因不明の不具合用トラブルシューティング
  5. トピックにHTMLを貼り付ける方法(推奨ツール:notepad.pw
  6. 真っ白画面でのエラーメッセージの確認方法
  7. ブラウザ環境チェックツール
  8. Cocoonカスタマイズ依頼

フォーラム質問後、問題等が解決した場合は結果を書き込んでいただけると幸いです。同様の問題で調べている方には、結果が一番気になる部分となります。

外部ブログカードのog:image取得...
 
共有:
通知
すべてクリア

外部ブログカードのog:image取得について再度確認したく

1 投稿
1 ユーザー
0 Reactions
12 表示
大門未知子
(@chu-ya)
Illustrious Member Registered
結合: 4年前
投稿: 3902
トピックスターター  

度々申し訳ありません。再度確認していて、疑問があり。
----------------------------------------------
テーマ名:Cocoon
バージョン:2.8.8
カテゴリー数:18
タグ数:123
ユーザー数:1
----------------------------------------------

●疑問点

以下のフックですが余り意味をなさないでは?

https://github.com/xserver-inc/cocoon/blob/21c48f06e0515af506e1f6819e8bd3d2b43dbdd3/lib/blogcard-out.php#L152-L153
https://github.com/xserver-inc/cocoon/blob/21c48f06e0515af506e1f6819e8bd3d2b43dbdd3/lib/blogcard-out.php#L156-L157

以下でサムネイル部のimgタグを作成しているが、リサイズ指定にが準じない

https://github.com/xserver-inc/cocoon/blob/21c48f06e0515af506e1f6819e8bd3d2b43dbdd3/lib/blogcard-out.php#L317


●処理の流れ

fetch_card_image() → 画像をダウンロード+任意でリサイズ

get_original_image_tag($image, THUMB160WIDTH, THUMB160HEIGHT, ...)

<img src="キャッシュ画像URL" width="160" height="90">

としている。

このため、fetch_card_image() 内でリサイズしても、get_original_image_tagで固定としており、意味がないのでは?


●再提案

単に元画像をダウンロードし、そのままキャッシュ保存するようにしては?

GDライブラリを使わないので、resize時の問題がない。
また、そのまま元画像を保存するので、MIME/TYPEの違いも影響しない。

//外部サイトからブログカードサムネイルを取得する
if ( !function_exists( 'fetch_card_image' ) ):
function fetch_card_image($image, $url = null){
  // URLのクエリを除去(?以降を削除)
  $image = preg_replace('/\?.*$/i', '', $image);

  // ファイル名・拡張子をそのまま使用
  $filename = basename($image);
  $ext = strtolower(pathinfo($filename, PATHINFO_EXTENSION));

  // キャッシュディレクトリを取得・存在しなければ作成
  $dir = get_theme_blog_card_cache_path();
  if ( !file_exists($dir) ) {
    mkdir($dir, 0777);
  }

  // キャッシュ保存先パス
  $new_file = trailingslashit($dir) . md5($image) . '.' . $ext;

  // WordPress関数を用い一時ダウンロード
  $tmp = download_url($image);
  if ( is_wp_error($tmp) ) {
    return;
  }

  // キャッシュにコピー
  copy($tmp, $new_file);
  @unlink($tmp);

  // 公開URLに変換して返す
  return str_replace(WP_CONTENT_DIR, content_url(), $new_file);
}
endif;

 


●補足

●Ver2.8.8リリース版

fetch_card_image()が機能していなかった。
og:imageを外部参照しそのまま表示していた。

●今までの経緯

GDライブラリを使用した場合、以下で述べたような問題もある。

https://wp-cocoon.com/community/postid/86959/

MIME/TYPEが異なる場合もある。

https://wp-cocoon.com/community/postid/87004/


このトピックは2時間前 6回から大門未知子に変更されました

   
引用
共有:

問題の解決に至った場合には、トピック冒頭の「解決済み」をクリックしていただけますと幸いです。

また、有用な回答があった場合は返信右下にある「いいね!」もご活用ください。回答者の励みになります。

「いいね!」機能はフォーラム登録者のみが利用できる機能です。

CC BY-ND 2.1)準じていれば(リンクを貼っていただければ)転載も自由です。カスタマイズ記事を書く際にコード等をコピペ利用していただいて構いません。

フォーラムの使い方がよくわからない場合は、テストトピックで自由にテストしていただいて構いません。

最近の書き込みはこちら。

詳細なカスタマイズ依頼をするならこちら。

タイトルとURLをコピーしました