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!'; }