楽天商品リンクショートコードのリンク切れを知る方法

ショートコード
この記事は約2分で読めます。

Cocoon1.6.4から、楽天APIで商品情報取得できなかった際にログ出力するようにしました。

楽天商品のリンク切れを確認するための機能です。

楽天商品リンク詳細はこちら。

楽天商品リンクの初期設定方法と使い方
楽天商品リンク機能を利用するには、事前準備が必要です。特に、「楽天アプリケーションID」と「楽天アフィリエイトID」は必須となります。加えて、楽天商品の商品番号の取得方法の紹介です。

\エックスサーバー開発のWordPressテーマ/
エックスサーバー開発のWordPressテーマ

Amazon商品リンクエラーログの場所

エラーログが出力されるのは、以下の場所になります。

WordPressインストールディレクトリ/wp-content/uploads/cocoon-resources/logs/rakuten_product_error.log

FTPなどでrakuten_product_error.logファイルを、ダウンロードしてテキストエディタで開けば、内容を確認できます。

ログの内容

ログの内容は、カンマ区切りのCSV形式になっています。

日付,ID,No(検索文字),エラーページURL

rakuten_product_error.logファイルをコードエディター等で開けば、エラーが出ているページのURLに飛んで確認することも出来るかと思います。

楽天商品リンクエラー

ショートコードにはキャッシュ機能があるので、すぐにはログに反映されないと思います。1ヶ月に1回くらいチェックするくらいでちょうど良いかと思います。

メール通知する方法

楽天商品リンクのリンク切れを、メールでお知らせする機能も追加しました。

利用方法の詳細はこちら。

Amazon・楽天商品リンクが切れていた時にメール通知を行う設定方法
Amazon商品リンク、楽天商品リンクの商品情報が取得できない際にメールでメッセージを送信する機能です。

まとめ

ログファイルの機能追加により「楽天商品価格ナビのリンク切れ」はある程度確認できるようになるかと思います。

今後インターフェースつきで実装するかどうかは、利用状況を見て考えます。

タイトルとURLをコピーしました
'); /* ヘッダーの高さの変化分、paddingで調整しスクロール位置を止まらせる */ $("#header-fixed").css({ 'padding-top': `${threashold}px`, }); /* トップメニュータイプに変更する */ $("#header-container-in").removeClass('hlt-center-logo hlt-center-logo-top-menu').addClass("hlt-top-menu wrap"); $("#header-container").addClass("fixed-header"); $("#header-container").css({ 'position': 'fixed', 'top': '-100px', 'left': '0', 'width': '100%', }); const wpadminbar = document.getElementById('wpadminbar'); const headerContainerTop = wpadminbar ? wpadminbar.clientHeight : 0; $('#header-container').animate( { top: headerContainerTop, }, 500 ); } } /*固定ヘッダーの解除*/ function staticHeader() { if ($("#header-container").hasClass("fixed-header")) { /*センターロゴタイプに戻す*/ $("#header-container-in").removeClass("hlt-top-menu hlt-tm-right hlt-tm-small hlt-tm-small wrap").addClass(" hlt-center-logo"); $("#header-container").removeClass("fixed-header"); $("#header-container").css({ 'position': 'static', 'top': 'auto', 'left': 'auto', 'width': 'auto', }); /* ヘッダーの高さの戻る分、padding削除しスクロール位置を止まらせる */ $("#header-fixed").css({ 'padding-top': '0', }); $("#header-fixed").remove(); } } /* 境界値をヘッダーコンテナに設定 */ var threashold = $('#header-container').height(); var prevScrollTop = -1; var $window = $(window); var mobileWidth = 1023; $window.scroll(function() { var scrollTop = $window.scrollTop(); var s1 = (prevScrollTop > threashold); var s2 = (scrollTop > threashold); var w = $window.width(); /*スクロールエリアの位置調整*/ function adjustScrollArea(selector) { if ($(selector) && $(selector).offset()) { offset = $(selector).offset().top; h = $("#header-container").height(); pt = $(selector).css('padding-top'); if (pt) { pt = pt.replace('px', ''); } else { pt = 0; } if ((scrollTop >= offset - h) && (w > mobileWidth)) { if ((pt <= 1) && $("#header-container").hasClass('fixed-header')) { $(selector).css({ 'padding-top': h + 'px', }); } } else { if (pt > 0) { $(selector).css({ 'padding-top': 0, }); } } } } /*スクロール追従エリアの調整*/ function adjustScrollAreas() { adjustScrollArea('#sidebar-scroll'); adjustScrollArea('#main-scroll'); } /*固定ヘッダーのスタイル決め*/ function adjustFixedHeaderStyle(s1, s2, w, scrollTop, mobileWidth) { if (s1 ^ s2) { if (s2 && (w > mobileWidth)) { stickyHeader(); } } /* 境界値に達したら固定化 */ if (scrollTop <= threashold || w <= mobileWidth) { staticHeader(); } } adjustFixedHeaderStyle(s1, s2, w, scrollTop, mobileWidth); adjustScrollAreas(); prevScrollTop = scrollTop; }); /*ウインドウがリサイズされたら発動*/ $window.resize(function () { /*ウインドウの幅を変数に格納*/ var w = $window.width(); if (w <= mobileWidth) { /*モバイル端末の場合*/ staticHeader(); } else { /*パソコン端末の場合*/ var scrollTop = $window.scrollTop(); if (scrollTop >= 50) { stickyHeader(); } } }); })(jQuery);