WordPress操作缓存和cookie示例方法

WordPress Transients API

Transients 是瞬时的意思,WordPress Transients API 是 WordPress 用来缓存一些复杂的 SQL 查询和运算结果的最简单的方法。它给这些需要缓存的数据一个过期时间,并且时间一到就会自动删除,所以如果你在制作 WordPress 插件的时候,需要存储一些有一定生命周期的数据的时候,Transients API 是最好的选择。

WordPress Transients API 缓存的数据存储在哪里

这个取决你的服务器设置,如果你的服务器开启 Memcache 这类对象缓存,那么缓存的数据就存在 Memcached 的内存中。如果没有开启的话,则存储到 WordPress 数据库的 Options 表中。

WordPress Transients API 的函数

上面说到服务器没有开启的时候,数据是存储到 Options 表中的,所以它接口函数和 WordPress 的 Option API (get_option, add_option, update_option, delete_option))基本一样,唯一区别就是 Transients API 有一个过期时间。所以 WordPress Transients API 有类似的以下三个函数:

set_transient() // 保存一个临时数据到缓存中 
get_transient() // 从缓存中获取一个临时数据 
delete_transient() // 从缓存中删除一个临时数据

如果你使用函数 get_transient 去获取一个临时变量,它已经过期或者不存在,则返回 false。另外 Transients API 不会将数据库的 Options 表充满,因为临时变量一旦过期,下次获取的时候就会自动被删除。

//获取标签云集 
function Bing_page_tags(){ 
    if( ( $cache = get_transient( 'page_tags_list' ) ) !== false ) return $cache;//如果有 Transients 缓存则直接返回 
    //如果没有缓存则开始生成 HTML 代码 
    $code = ''; 
    if( $tags = get_tags( 'orderby=count&order=DESC' ) ){ 
        foreach( $tags as $tag ){ 
            $code .= '<li class="tag-box">'; 
                $post = current( get_posts( array( 
                    'tag_id'         => $tag->term_id, 
                    'posts_per_page' => 1 
                ) ) ); 
                $code .= "<p class='tag-name'>$tag->name</p>"; 
                $code .= sprintf( '<a href="%s">%s</a>', esc_url( get_permalink( $post ) ), get_the_title( $post ) ); 
            $code .= '</li>'; 
        } 
        $code .= "<ul id='tags_list'>$code</ul>"; 
    } 
    //建立 Transients 缓存并返回代码 
    set_transient( 'page_tags_list', $code, DAY_IN_SECONDS );//缓存有效 24 小时 
    return $code; 
}

上面的代码用来生成标签云集的 HTML 代码,并且缓存 24 小时(DAY_IN_SECONDS 为时间常量,表示 24 小时的秒数),如果存在缓存则直接返回,不用再次生成,避免大量 SQL 查询。

但这期间修改标签或文章却无法立即显示,所以还需要在特定事件清除缓存:

//清除标签云缓存 
function clear_page_tags_cache(){ 
    delete_transient( 'page_tags_list' );//删除 Transients 缓存 
} 
add_action( 'save_post', 'clear_page_tags_cache' );//创建和编辑文章 
add_action( 'deleted_post', 'clear_page_tags_cache' );//删除文章 
add_action( 'created_post_tag', 'clear_page_tags_cache' );//创建标签 
add_action( 'edited_post_tag', 'clear_page_tags_cache' );//编辑标签 
add_action( 'delete_post_tag', 'clear_page_tags_cache' );//删除标签

使用 WordPress 对象缓存

下面是把把相关日志的数据写入缓存的例子,使用当前 post ID 作为 key,’related_post’ 作为 group,缓存时间为一个小时,即 3600 秒。

global $post; 
$related_posts_data = wp_get_related_posts(); 
wp_cache_set($post->ID,$related_posts_data,'related_posts',3600);

上面只是把数据存到缓存对象中,我们在显示相关日志的时候,就要去调用这个对象缓存来使用,首先检查下是否已经有了缓存,如果你要的信息没有在缓存中,或者已经过期了。wp_cache_get() 会返回 false,如果这样,你就要去数据库中重新获取这些信息。否则就返回在缓存中的信息。

global $post; 
$related_posts_data = wp_cache_get($post->ID,'related_posts'); 
if(false === $related_posts_data){ 
    $related_posts_data = wp_get_related_posts(); 
    wp_cache_set($post->ID,$related_posts_data,'related_posts',3600); 
} 
echo $related_posts_data;

因为设置了一个小时,相关日志的数据就失效,这里一般就无需更新缓存了,如果你在后台更改了设置,需要立即清理缓存,可以使用 wp_cache_delete 进行清理:

wp_cacache_delete($post->ID,'related_posts');

WordPress中如何设置cookie

编写WordPress插件和主题的时候,经常需要用到cookie,比如存取用户状态等,我之前编写的插件Ludou Simple Vote就用cookie来记录用户投票时间,以实现简单的防止重复投票功能。

1、在主题文件functions.php中添加以下代码,以设置cookie:

/** 
 * 函数名称,setcookie的相关参数等可以自行修改 
 */ 
function set_newuser_cookie() { 
    if (!isset($_COOKIE['sitename_newvisitor'])) { 
        setcookie('sitename_newvisitor', 1, time()+1209600, COOKIEPATH, COOKIE_DOMAIN, false); 
    } 
} 
  
add_action( 'init', 'set_newuser_cookie'); 
// 上面一行代码也可以改成下面一行代码 
// add_action('after_setup_theme', 'set_newuser_cookie');

2、然后在需要调用cookie值的地方读取cookie

if (isset($_COOKIE['sitename_newvisitor'])) { 
     echo 'Welcome back!'; 
} 
else { 
     echo 'Hello new visitor!'; 
}


WordPress