WordPress ウィジェットで cookie を使う

前回の WordPress ウィジェットでAjaxを使う で、Ajaxを使ってブラウザ幅に応じたテキストウィジェットの切り替えを行える事を検証してみましたが、今回は cookie を使ってテキストウィジェットの切り替えを行なってみます

cookie 概要

Cookie とは、ウェブサイト等のインターネット上のサービスで使用され、ユーザー情報やサイトの訪問回数、日時、買い物履歴等を保持する為の小さな情報ファイルです

Cookie はブラウザに保存され、任意のデータ(最大4096バイト)を保持出来、ドメイン、パス、有効期限等の属性をもっています

保存するには、サーバーがHTTPヘッダーを使い Set-Cookie でブラウザへ送信するやり方と、ブラウザの JavaScript を使って保存する方法があります

Cookie は、ブラウザがアクセスした時に、そのアクセス先のURLに関連付けられている Cookie がブラウザに存在すれば、HTTPのヘッダーを使い自動的に送信されます
送信は、ドメイン、パス、有効期限等の属性により判断されます

ブラウザ情報を Cookie に保存

今回の目的は、ブラウザの幅データを cookie を使って取得することです

前回使った WordPress ウィジェットサンプルの is_mobile_text ウィジェットを修正して実装していきます
(プログラムは、後日公開します)

ブラウザの情報なので、サーバーから送った javascript により、ブラウザ内で javascript を使い cookie を保存します。そうすると、ページ読み込みのたびにブラウザからサーバーに cookie が自動的に送られるっていう寸法です (^^)

さっそく JavaScript を作成していきますが、まだ慣れていないのでググりながら作りまっす
PHPとJavaScript で処理しやすいようにデータはjson 形式として、こんなスクリプトコードを実装しました

  1. function setJsonCookie(name, jsondt, dir, days){
  2. // 名前と値
  3. var val = encodeURIComponent(name) +"="+ encodeURIComponent(JSON.stringify(jsondt)) +"; ";
  4. //パス
  5. var path = location.pathname;
  6. if (dir !== undefined)
  7. path = "path="+ dir + "; ";
  8. //有効期間
  9. var expire = "";
  10. if (days !== undefined)
  11. expire = "expires=" + new Date( Date.now() + 1000 * 3600 * 24 * days).toUTCString() + ";";
  12. //保存
  13. document.cookie = val + path + expire;
  14. }
  15.  
  16. function getJsonCookie(name) {
  17. var result = null;
  18. var c_name = name + '=';
  19. var cookies = document.cookie;
  20. var idxof = cookies.indexOf( c_name );
  21. if( idxof != -1 ) {
  22. var s_idx = idxof + c_name.length;
  23. var e_idx = cookies.indexOf( ';', s_idx );
  24. if( e_idx == -1 )
  25. e_idx = cookies.length;
  26. result = JSON.parse( decodeURIComponent( cookies.substring( s_idx, e_idx ) ));
  27. }
  28. return result;
  29. }
  30.  
  31. function getBrowserSize() {
  32. var ns = {};
  33. ns['width'] = jQuery(window).width();
  34. ns['height'] = jQuery(window).height();
  35.  
  36. var gc = getJsonCookie("browser_viewport");
  37. if(gc === null) {
  38. //クッキー作成
  39. setJsonCookie("browser_viewport", ns, '/');
  40. //クッキー再読み込み
  41. gc = getJsonCookie("browser_viewport");
  42. if(gc !== null) {
  43. //クッキーが有効ならリロード
  44. window.stop();
  45. window.location.reload(true);
  46. }
  47. }
  48. else if(ns['width'] !== gc['width'] ) {
  49. //クッキー更新
  50. setJsonCookie("browser_viewport", ns, '/');
  51. window.stop();
  52. window.location.reload(true);
  53. }
  54. }
  55.  
  56. getBrowserSize();

参考サイト クッキーの使用方法 – JavaScriptプログラミング解説

参考サイトのコードをベースに json 形式でデータを扱うように変更しました

browser_viwport という名前の cookie にブラウザの width, height データを保存しています

Chrome で確認

私の中では、JavaScript の開発手法がまだ、確率されていないので、とりあえず chrome の開発ツールで javascript の動きを確認します

ブレイクもかけられ、変数も参照できるのですが、PHP開発環境のNetbeansと行ったり来たりで慌ただしいです (^_^;)

SnapCrab_NoName_2013-6-21_18-28-35_No-00

保存した cookie をちゃんと読み出せたようです

Network タブからヘッダー情報を見てみます

cookie: browser_viewport があるのが確認出来ます

SnapCrab_NoName_2013-6-21_18-29-43_No-00

ちなみに、ローカル環境で動作確認を行なっているのですが、chrome の resouces から cookie を確認することもできます。また、ここからマウス右クリックで cookie を個別に削除することが出来ます

SnapCrab_NoName_2013-6-21_18-30-50_No-00

WordPress 側で cookie 取得

WordPress 側では、おなじみの Netbeans を使い、is_mobile_text ウィジェットの widget 関数で $_COOKIE スーパーグローバルから cookie 名 browser_viewport を指定して取得出来ます

  1. function widget( $args, $instance ) {
  2. //連想配列 $args を変数名($before_widget, $before_title, $after_title, $after_widget, ...)に展開
  3. extract($args);
  4.  
  5. //値がない項目に対して引数で指定した初期値を設定
  6. $default = array( 'title' => '', 'cmtext' => '', 'filter'=> FALSE, 'hidetitle'=> FALSE, 'smallest' => 0, 'largest' => 9999 );
  7. $instance = wp_parse_args( (array) $instance, $default);
  8.  
  9. $title = $instance['title'];
  10. $hide = $instance['hidetitle'];
  11. $filter= $instance['filter'];
  12. $cmtext= $instance['cmtext'];
  13. $minpx = $instance['smallest'];
  14. $maxpx = $instance['largest'];
  15.  
  16. echo $before_widget;
  17. if(!empty($_COOKIE['browser_viewport'])){
  18. $bw = json_decode( stripslashes($_COOKIE['browser_viewport']));
  19. $width = $bw->width;
  20. if ( !empty( $title ) && empty( $hide )) {
  21. echo $before_title . $title . $after_title;
  22. }
  23. //ブラウザ幅が有効範囲内かチェック
  24. if($minpx <= $width && $width <= $maxpx ){
  25. if(!empty( $filter ))
  26. $cmtext = wpautop( $cmtext );
  27. }
  28. else
  29. $cmtext = "";
  30.  
  31. ?><div class="textwidget"><?php echo $cmtext; ?></div><?php
  32. }
  33. else {
  34. //JavaScript. cookie が有効になっていないので出力しない
  35. ?><div class="textwidget"></div><?php
  36. }
  37. echo $after_widget;
  38. }

データは、json形式なので、次のようにして取り出します

$bw = json_decode( stripslashes($_COOKIE[‘browser_viewport’]));

取り出したデータは stdClass型なので、$width = $bw->width; こんなふうに要素を取り出すか、あるいは array で型変換してから、連想配列でアクセスすることが出来ます

SnapCrab_NoName_2013-6-21_18-55-49_No-00

以上で、cookie を使いブラウザ情報を wordpress へ渡せることが確認出来ました

但し、cookie は、過去の情報であり、現在と違っているかもしれません。

最近のはやりで言えば、いつやるの? 今でしょ ということで現在の情報と比較して、異なっていたらリロードさせるという荒業で対処します (^_^;)

ただ、むやみにリロードするのは、あまりに乱暴なので、プログラムを少し修正して条件判断を付けていきます では、次回に続きます


まとめ記事紹介

go-to-top