wordpress php缓存,wordpress自带的缓存功能使用介绍

用静态化当然可以解决这些问题,不过对于流量不大的博客就没必要了。 wordpress自带有缓存体系,关键的函数你可以在wp-includes/cache.php或 Codex里查找到所有的函数。

你可以使用下列函数来实现添加缓存。

复制代码代码如下:

wp_cache_add($key, $data, $flag = '', $expire = 0)

相反的,要删除缓存数据可以通过下面的方法实现。

复制代码代码如下:

wp_cache_delete($id, $flag = '')

提取缓存数据:

复制代码代码如下:

wp_cache_get($id, $flag = '')

替换缓存数据:

复制代码代码如下:

wp_cache_replace($key, $data, $flag = '', $expire = 0)

举个例子,如果想输出最新评论,可以先从缓存里读取需要输出的HTML,如果没有,请求一次,成功后加入缓存,当然时间可以控制。

我知道有很多最新评论,相关文章免插件输出的方法,原理都一样,可以自行改改,贴个我用的:

config.php里面添加

复制代码代码如下:

define('WP_CACHE', true);

如果你用了其它缓存插件,基本上这个就没效果了。因为这些插件有类似的方法。

复制代码代码如下:

/**

* get recent comments

* @param unknown_type $args

* @return unknown_type

*/

function DeamworkRecentcomments($args='number=5&status=approve'){

$cacheID = md5($args);

//有缓存就直接输出

if($output = wp_cache_get('recentComments_'.$cacheID, 'Winysky')){

echo $output;

return;

}

//$rcms = get_comments($args);

global $wpdb;

$my_email = "'" . get_bloginfo ('admin_email') . "'";

//自动获取博主邮箱

$rcms = $wpdb->get_results("

SELECT ID, post_title, comment_ID, comment_author, comment_author_email, comment_content

FROM $wpdb->comments LEFT OUTER JOIN $wpdb->posts

ON ($wpdb->comments.comment_post_ID = $wpdb->posts.ID)

WHERE comment_approved = '1'

AND comment_type = ''

AND post_password = ''

AND comment_author_email != $my_email

ORDER BY comment_date_gmt

DESC LIMIT 10

");

//print_r($rcms);return;

if(empty($rcms)){

_e('没有数据');

return;

}

//历遍数据

$output = '';

foreach( $rcms as $rcm ){

$author = $rcm->comment_author;

//if($author =='admin'){continue;}

$content = DeamworkStriptags( $rcm->comment_content);

$the_title = get_the_title($rcm->comment_post_ID);

$s_excerpt = convert_smilies( DeamworkSubstr( $content, 200 ) );

$contents = '' . $author . ' on ' . $the_title . '

';

$output .= '

' . $contents . '
' . ' ' . get_avatar($rcm->comment_author_email, 32) . '';

}

//输出后加入缓存

wp_cache_add('recentComments_'.$cacheID,$output, 'Deamwork');

echo $output;

}

最后,试试效果吧~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值