WordPress set_transient()使用方法和实现
像素鱼丸
01-06
237
0

set_transient() 是 WordPress 中用于设置临时数据的函数,它允许你将数据存储在缓存中,这些数据会在指定的时间后自动过期。它是 WordPress 提供的 transient API 的一部分,常用于缓存数据库查询、API 响应或其他计算密集型操作的结果。


一、基本概念

1. 什么是 Transient?

Transient 是 WordPress 中的一种缓存机制,类似于 Redis 或 Memcached 的键值对缓存,但它是基于文件或数据库(取决于 WordPress 配置)的。它适用于短期缓存的数据,比如:

  • API 请求结果
  • 复杂查询的结果
  • 页面生成的输出
  • 一些不经常变化但需要快速访问的数据

2. 与 set_transient() 相关的函数

函数 作用
set_transient($key, $value, $expiration) 设置一个 transient
get_transient($key) 获取一个 transient
delete_transient($key) 删除一个 transient
transient_exists($key) 检查 transient 是否存在

二、set_transient() 函数详解

语法


set_transient( $transient, $value, $expiration );

参数说明

参数 类型 必填 说明
$transient string transient 的名称(键),通常使用唯一标识符,如 'my_cache_key'
$value mixed 要存储的值,可以是字符串、数组、对象等
$expiration int 过期时间(秒),0 表示永不过期(不推荐)

注意:WordPress 5.7 及以上版本中,$expiration0 时,transient 不会过期。建议使用 60 * 60 * 24 等表示天数。


三、使用示例

示例 1:缓存 API 数据


function get_api_data() {
    $cache_key = 'api_data_cache';
    $data = get_transient( $cache_key );
    if ( false === $data ) {
        // 如果缓存不存在,从 API 获取数据
        $response = wp_remote_get( 'https://api.example.com/data' );
        $body = json_decode( wp_remote_retrieve_body( $response ), true );
        $data = $body['data'];
        // 设置缓存,有效期为 1 小时(3600 秒)
        set_transient( $cache_key, $data, 3600 );
    }
    return $data;
}

示例 2:缓存数据库查询结果


function get_user_posts( $user_id ) {
    $cache_key = 'user_posts_' . $user_id;
    $posts = get_transient( $cache_key );
    if ( false === $posts ) {
        global $wpdb;
        $posts = $wpdb->get_results( $wpdb->prepare(
            "SELECT * FROM {$wpdb->prefix}posts WHERE post_author = %d",
            $user_id
        ), OBJECT );
        set_transient( $cache_key, $posts, 60 * 60 * 24 ); // 1天
    }
    return $posts;
}

四、注意事项

  1. Transients 依赖于缓存系统
    • 默认情况下,WordPress 使用文件缓存(wp-content/cache/)。
    • 如果你使用了缓存插件(如 W3 Total Cache、WP Super Cache),可能会影响 transients 的行为。
  2. 不要用作持久化存储
    • Transients 是临时数据,不能替代数据库或选项(option)存储。
  3. 命名规范
    • 建议使用有意义的 key 名称,避免冲突,例如:'myplugin_cache_123'
  4. 过期时间合理设置
    • 过期时间太短可能导致频繁重新获取数据,影响性能;
    • 太长则可能缓存过时数据。

五、删除 Transient


delete_transient( 'api_data_cache' );

六、检查 Transient 是否存在


if ( transient_exists( 'api_data_cache' ) ) {
    // 存在
} else {
    // 不存在
}

七、总结

功能 用途
set_transient() 缓存临时数据
get_transient() 获取缓存数据
delete_transient() 清除缓存
transient_exists() 判断是否存在缓存

如果你有具体的应用场景(比如缓存某个 API 接口、页面内容、数据库查询等),我可以提供更具体的代码示例。

是否需要我帮你写一个完整的例子?

收藏
打赏
WordPress 如何实现付费后才可以查看全文
上一篇
Mirage 主题 v2.89.0 发布
下一篇

发表评论

注册不是必须的

像素鱼丸
152 文章
0 评论
4 喜欢
最新文章

网站的 Cookie 弹窗

在当前的法规环境下(截至2026年4月),一个合规的Cookie弹窗设计必须遵循“透明、公平、明确”的原则,核心是确保用户拥有真正的选择权。 以下是现阶段设计合规Cookie弹窗的关键要点: 现阶段合规设计要点 禁止默认同意 弹窗出现时,所有非必要Cookie的选项都不能被预先勾选。用户必须通过一个明确的、主动的动作(如点击按钮或勾选方框)来表示同意。 提供平等的选择权 “拒绝”按钮必须在视觉上和 […]

网页设计中 banner、jumbotron、hero 都有什么区别

在网页设计和开发中,banner、jumbotron、hero 这些词通常指代页面顶部最引人注目的区域,但它们在具体含义和使用场景上有所区别。 🎯 核心概念辨析 Banner (横幅/条幅广告) 这是一个非常广泛的术语,通常指网页上任何矩形的广告或信息区域,可以出现在页面的顶部、侧边或底部。它更偏向于广告或信息展示的功能。 Jumbotron (巨幕) 这个词源于 Bootstrap 等前端框架, […]

宝塔 Nginx 拦截了 WordPress 返回 404 的状态

REST api 接口中,有段代码返回404,但是没有正常返回错误json: $wp_response = new \WP_REST_Response(array('error'=>'没有找到数据')); $wp_response->set_status(404); return $wp_response; 返回内容是: <html> <head><tit […]

Mirage 主题 v2.93.0 发布

更新内容: refactor 移除图片高宽比开关 refactor 移除全局的TOC生成开关 refactor 优化 header.php 中的seo模块和样式覆盖 feat 主题启用的时候,移除非当前主题注册的小工具 fix 修复分类小工具的bug feat 管理员打开后台,检查最当前设置首页布局的模块,如果缺少最新模块,就添加到隐藏模块列表中 fix 优化链接卡片样式 fix 优化热门文章样式 […]
生成中...
扫描二维码
扫描二维码
用户登录