我有wordpress插件,注册设置如下:
register_settings("myplugin_settings","myplugin_option1");
并在插件激活它添加选项,如:
add_option("myplugin_option1","");
然后,如果我更新选项,如:
update_option("myplugin_option1","something else");
然后尝试从数据库中获取它:
$myoption = get_option("myplugin_option1");
get_option()返回false,偶数选项存在且值更新 .
我知道值已更新并且存在选项,因为当我运行查询以获取选项时,我获得了值:
global $wpdb;
$query = 'SELECT * FROM wp_options WHERE option_name = "myplugin_option1";
$result = $wpdb->get_results($query);
这回报了我的 Value :“别的东西”
例如这段代码:
$option = get_option("myplugin_option1");
if(false == $option){
global $wpdb;
$query = 'SELECT * FROM wp_options WHERE option_name = "myplugin_option1"';
$result = $wpdb->get_results($query);
}
执行此代码后,$ result将包含值:
Array
(
[0] => stdClass Object
(
[option_id] => 11752
[option_name] => myplugin_option1
[option_value] => something else
[autoload] => yes
)
)
因此选项存在并且具有值,但get_option()返回false .
我有这个问题只有3个选项,只在我的插件安装的一个网站上 . 有没有人知道为什么get_option()返回false,即使选项在数据库中,并且值为“其他” .
2 回答
这个问题是我遇到问题的那三个选项在wp缓存中以某种方式缓存了两次 .
因此,一个选项被缓存两次,并且update_options()总是更新这两个中的一个,并且get_option()总是得到另一个用空值缓存的选项 .
不确定这是怎么发生的,但清除缓存解决了我的问题 .
您应该在任何外部文件中包含文件
wp-blog-header.php
,以便能够使用Wordpress功能 . 该文件位于wordpress根文件夹中 .