Wordpress 如何初始化WP插件以使用其类?

Wordpress 如何初始化WP插件以使用其类?,wordpress,plugins,Wordpress,Plugins,我想在我的php页面中使用Wordpress WYSIJA插件中的一个类。我需要如何初始化插件才能访问它的类 我想做的是: <?php require_once(dirname(__FILE__).'/wp-blog-header.php'); require_once(dirname(__FILE__).'/wp-content/plugins/wysija-newsletters/core/base.php'); function display() { $myEmailVariab

我想在我的php页面中使用Wordpress WYSIJA插件中的一个类。我需要如何初始化插件才能访问它的类

我想做的是:

<?php
require_once(dirname(__FILE__).'/wp-blog-header.php');
require_once(dirname(__FILE__).'/wp-content/plugins/wysija-newsletters/core/base.php');
function display()
{

$myEmailVariable=$_POST['usremail']; 
$myListId1='3';
echo($myEmailVariable);
$userData=array(        'email'=>$myEmailVariable,        'firstname'=>'',        'lastname'=>'');
$data=array(      'user'=>$userData,      'user_list'=>array('list_ids'=>array($myListId1))    );
$userHelper=&WYSIJA::get('user','helper');
print_r($data);
$userHelper->addSubscriber($data);
}

add_action('init','display');
我得到一个错误:致命错误:在中找不到类'WYSIJA' 编辑: 现在,我将处理表单的函数移到functions.php并编辑了代码:

    <?php
   require_once(dirname(__FILE__).'/wp-blog-header.php');

   if (isset($_POST['usremail'])) {

    add_subscriber_wys();
}
   else {
       //show form
?>

<body>
    <div class="box_email">
        <p>Секунду, мы перенаправляем Вас на страницу банка</p>
        <div class='email_frame'>
        <form method="post" action="<?php echo($_SERVER['PHP_SELF']) ?>">

        <span class="email_label">Введите e-mail</span>
        <input type="email" name="usremail" size="35" onfocus="stoptimer()" style="line-height: 60px;" >

        <br>
        <span>чтобы получать лучшие предложения от банков-партнеров</span>
        </div>
        <div>
        <img src="http://moscow-kredit.ru/wp-content/themes/arthemia-premium/images/banki.png"></img>
        </div>
        <div class="or">
        или просто нажмите
        </div >
        <div class='button'><input type="image" src="http://moscow-kredit.ru/wp-content/themes/arthemia-premium/images/knopka.png" alt="Далее" name='submit' /></div>

        </form>

<?php

   }

?>  


    </div>

    <script>

var foo;

function redirectme(){
var refarray = new Array();
refarray['homenal'] = "http://test1.ru";
refarray['genal'] = "http://test2.ru";
refarray['domain3.com'] = "http://test3.ru";
for (var i in refarray) {
if (window.location.href.indexOf(i) != -1) window.location.replace(refarray[i]);
}
}
function stoptimer(){
clearTimeout(window.foo);
}

foo=setTimeout("redirectme();", 5000);


    </script>


    </body>
</html>

但它甚至没有显示表单,也没有显示任何错误。

尝试以下操作:

<?php

define( 'WP_USE_THEMES', false );
require( './wp-load.php' );

add_action( 'plugins_loaded', 'display_so_14638257' );

function display_so_14638257() 
{
    // Your stuff
}

为函数名添加前缀或后缀,这样就不会有与其他函数冲突的风险。

感谢您的回答,但这似乎没有帮助。现在看起来很奇怪。当我在表单之前添加require wp_load.php或wp-blog-header.php时,它将完全停止显示表单-只显示空白屏幕。我打开了WP_调试,但它只显示了来自其他插件的一些注释,这些注释似乎与问题无关。现在,我将处理表单的函数移到主题的functions.php中,并编辑了代码:感谢您的时间-我刚刚发现插件已损坏,并最终找到了一种方法。再次感谢!第一件事。使用wp-load.php。确保使用基本测试连接到WP:。这会打印站点url吗?