在独立插件页面中访问WordPress功能


Access WordPress functions in standalone plugin page

如何允许独立页面访问WordPress函数而不包括/需要wp_load或wp_config

我正在开发一个插件,需要允许在独立的php页面上访问WP数据库。这个页面是一个简单的curl请求,它返回一个完整的HTML页面来显示。对于上下文,插件是API中的作业列表,然后需要链接到完整的作业广告(完整的HTML页面)。

我目前拥有的代码是这样的(在jobad.php页面中):

$root = dirname(dirname(dirname(dirname(dirname(__FILE__)))));
if (file_exists($root.'/wp-load.php')) {
  require_once($root.'/wp-load.php');
}

这是我从每一个答案中提取的关于如何实现这一点的代码。包括来自wordpress.org自己的论坛。从这个stackoverflow回答中,例如:在独立脚本中使用WPDB?

它工作得很好,但当我试图将插件提交到WP目录时,该插件被拒绝了,因为它以这种方式包含了WP_load.php。为什么不这样做是有道理的,但我找不到任何其他方法让文件在WordPress中工作。

我需要的结果

从一个由短代码生成的列表中,每个项目都有一个链接,该链接将返回一个完整的HTML页面。这个HTML页面是作为cURL响应返回的,而不是URL(或者我可以让每个链接都驱动一个iframe)。就上下文而言,我正在以这种方式构建链接

$job_ad_link = plugins_url( 'includes/jobad.php' , dirname(__FILE__) );
$job_id = //id from database;
<a href="'.$job_ad_link.'?sgjobid='.$job_id.'">link</a>

因此,调用jobad.php将为正确的job_id运行cURL函数,并显示cURL响应。我可以将cURL作为AJAX运行并避免这个问题,但因为它是一个完整的HTML页面,我不能简单地在div中返回cURL。在iframe中,这很尴尬,也很不确定,我宁愿不使用它(而且尝试没有成功)。

为了澄清,WordPress的回复:

包括wp-config.php、wp-blog-header.php、wp-load.php或几乎任何其他必须通过include直接调用的WordPress>核心文件都不是一个好主意,我们不能>批准这样做的插件,除非它有很好的理由加载文件。它很容易失败,因为不是所有的WordPress安装都有完全相同的文件结构。

我实现了几个提供AJAX响应的插件,因此我还需要能够从PHP脚本访问WordPress函数。我解决了这个问题,包括wp_config.php文件,直到一位核心开发人员指出如何正确解决它。

由于这种方式不仅限于AJAX调用,我还使用它来为Facebook应用程序呈现页面,该应用程序需要访问WordPress功能。以下是您的操作方法(只需将其放入functions.php或一个小插件中):

function full_job_ad_page() {
    global $wpdb; // this is how you get access to the database
    // do what ever you want with the ability to access WordPress functions.
    // asuming that the one item is an option, just get it with get_option
    $value_from_db = get_option( 'curl_value' );
    // asuming that the value is in any other table, use some $wpdb function
    $value_from_db =  $wpdb->get_var( 'SELECT value FROM table' );
    // include the curl file echoing the response
    include( plugin_dir_path( __FILE__ ) . 'curl-script.php' );
    die(); // this is required to return a proper result
}
add_action( 'wp_ajax_full_job_ad_page', 'full_job_ad_page' );
add_action( 'wp_ajax_nopriv_full_job_ad_page', 'full_job_ad_page' );

然后你可以使用这样的URL从函数中获得响应:

http://example.com/wp-admin/admin-ajax.php?action=full_job_ad_page

注意:URL中的操作必须与操作挂钩的第一个参数(wp_ajax_和wp_ajax_nopriv_之后的字符串)的末尾匹配。

我想你会在这些文章中找到答案:

插件中的AJAX

在Wordpress 中使用AJAX的5个技巧

还可以在WordPress Answers上查看这个问题,我在那里找到了链接。

怎么样?

<?php
// Include WordPress
define('WP_USE_THEMES', false);
require('path_to_wp/wp-blog-header.php');
query_posts('page_id=63');
?>
<?php while (have_posts()): the_post(); ?>
  <h2><?php the_title(); ?></h2>
  <?php the_content(); ?>
<?php endwhile; ?>