WordPress 会话管理

更新于 2025年4月19日 WordPress 教程

WordPress 会话管理

我正在使用 WordPress 建立一个网站,我想利用它的session。 但我没有找到任何插件,甚至没有找到文档。 在我开始破解它之前有什么建议或参考吗?

注意:我问的是 WP 是否以及如何使用标准 PHP session本身,而不是如何添加 PHP session,例如使用 session_start()。 显然,WP 维护的任何状态都是通过其他方式实现的。 所以如果我想使用 PHP session,我需要完全自己添加和维护它,使用类似线程中的技术。

谢谢大家!

解决方案

为了使用会话的能力而修改WP Core文件是一个非常糟糕的主意。 我发现的最好方法是从init动作挂钩调用session_start()

function kana_init_session() {
  session_start();
}

add_action('init', 'kana_init_session', 1);

你可以把它放在你的主题的functions.php文件中。

WordPress 似乎没有调用session_start()因为它想要无状态,如果register_globals被定义,它会自动破坏你的$_SESSION

考虑使用WordPress Transient API

使用 Transient API 存储的值对所有用户都是可见的,而不仅仅是当前用户,根据用于检索瞬态的唯一标识符,您可以为每个用户分配一个唯一标识符,本质上使瞬态表现得非常像会话。

进一步的考虑:

  • 根据用户设置的对象缓存等,瞬态可能并不总是存储在数据库中(例如 memcached),对会话使用瞬态可能意味着数据可能会变得庞大并迅速填满内存(在使用 memcached 时)。
  • 此外,似乎 WP 不会对瞬态进行自动垃圾收集

对于我需要做的事情,最佳答案包括:

  1. 要允许 wordpress 的 cookie 跨子域持续存在,请安装 Root Cookie插件
  2. sub1.domain.com有 wordpress; sub2.domain.com是另一个站点。 我从另一个站点 ( sub2 ) 读取 cookie 以识别用户是谁以及用户是否已登录。

我的饼干如下:

[wordpress_909bb230b32f5f0473202684d863b2e0] => mshaffer|1255298821|d0249fced9c323835c5bf7e84ad3ffea
[wordpress_logged_in_909bb230b32f5f0473202684d863b2e0] => mshaffer|1255298821|56e9c19541ecb596a1fa0995da935700

使用 PHP,我可以遍历 cookie,解析key=>value对。 这些 cookie 让我知道[mshaffer]有一个存储在 wordpress 上的 cookie,并且也被认证为logged_in 。 cookie 的有效期为1255298821

sub2 中,我可以查询 wordpress 的数据库并获取用户信息:

SELECT * FROM `wp_users` WHERE user_login = 'mshaffer' ...从这个查询中获取user_id , user_email

SELECT * FROM `wp_usermeta` WHERE user_id = '$user_id' ...从 wp 中获取大量其他数据

有了这些信息,我就可以添加到我的sub2会话变量/cookie 中,并对数据执行我想要的操作。 我可以识别我是否已登录,以及我的用户名……这让我可以获取许多不同的数据。 我现在可以在sub2.domain.com 中使用 WordPress 身份验证并相应地重定向。

WordPress 似乎不使用任何会话。

最好的方法是使用它提供的动作钩子。

您是否检查过此处的解决方案,这可能适用于此处,并且方法简单。

在这种情况下,在wp_loaded上使用session_start()挂钩函数似乎有效。

将此代码放在 wp-config.php 的第一行:

if (!session_id()) {
    session_start();
}

将此代码放在主题的 header.php 中的第一行:

session_start();

然后它将维护所有会话变量。

如果您想使用自己的会话值, WordPress 确实支持它

您需要在wp-config.php的顶部添加以下几行

if (!session_id()) {
    session_start();
}

然后在header.php的顶部添加以下行

session_start();

你可能还喜欢下面这些文章

怎样优化WordPress数据库提高性能怎样优化WordPress数据库提高性能

WordPress网站随着内容积累会出现数据库臃肿问题,导致查询效率下降。本文提供无需编程的数据库优化方案:首先通过phpMyAdmin检查"开销"数值,利用WP-Sweep清理冗余文章修订版和自动草稿;使用Advanced Database

WordPress数据库中存储 wp_cron 任务的字段是什么WordPress数据库中存储 wp_cron 任务的字段是什么

任务设置为:或者它存储在wordpress的某个txt文件中。//core.trac.wordpress.org/browser/trunk/wp-includes/cron.php。

为什么WordPress多站点网络会出现数据库连接错误为什么WordPress多站点网络会出现数据库连接错误

WordPress多站点网络出现数据库连接错误时,可能导致整个网络瘫痪,因其共享数据库的特性。常见原因包括:1. **wp-config.php配置错误**(如数据库凭证不匹配或迁移后未更新);2. **表前缀冲突**(多站点启用时未正确配置

如何优化WordPress网站数据库表结构如何优化WordPress网站数据库表结构

本文详细介绍了优化WordPress数据库表结构的方法与重要性。随着网站运行时间增长,数据库会积累冗余数据,导致查询变慢、后台卡顿。文章首先强调备份数据库的必要性,随后指导读者通过phpMyAdmin分析表状态,重点清理修订版本、孤立元数据和

wordpress怎么获取某个栏目链接地址wordpress怎么获取某个栏目链接地址

php$cat=get_category_by_slug('分类名称');。$cat_links=get_category_link($cat->term_id);。

WordPress多站点网络配置与管理教程WordPress多站点网络配置与管理教程

WordPress多站点网络配置与管理教程 本文详细指导如何利用WordPress多站点功能集中管理多个网站。通过修改`wp-config.php`文件启用多站点模式,配置服务器环境(PHP 7.4+、数据库优化),并完成网络设置。多站点支

如何优化WordPress数据库提升加载速度如何优化WordPress数据库提升加载速度

WordPress数据库优化是提升网站性能的关键。长期运行会积累冗余数据(如修订版本、自动草稿、垃圾评论),导致查询变慢、加载延迟。本文提供系统优化方案:首先强调备份重要性,推荐使用UpdraftPlus或phpMyAdmin;其次通过WP-

WordPress数据库优化技巧终极指南WordPress数据库优化技巧终极指南

WordPress数据库优化技巧终极指南:针对网站卡顿、数据库连接错误等问题,本文提供从基础到高级的全面解决方案。首先强调数据库清理的必要性——冗余数据会显著拖慢网站速度并增加安全风险。指南详细讲解手动优化步骤:通过phpMyAdmin清理文