在与wordpress相同的目录中运行PHP脚本,但没有它

时间:2016-03-30 14:49:36

标签: php database cron

我们说我有一个名为import.php的PHP脚本(底部的代码),它存储在与我的wordpress网站相同的目录(root)中。我的问题是当我想通过输入以下命令来运行该脚本:www.mydomain.com/import.php当然它会启动带有404 ERROR的wordpress。

如何在wordpress环境之外以某种方式运行此脚本/将其从wordpress中排除?

我的脚本专门用于数据库更新(通过真正的cron),这就是我不想使用wordpress的原因。

<?php
error_reporting(E_ALL);
ini_set('display_errors', '1');


$mysql_host = 'localhost';
$mysql_username = '';
$mysql_password = '';
$mysql_database = '';

$db = new PDO('mysql:dbname='.$mysql_database.';host='.$mysql_host,$mysql_username,$mysql_password);

// works not with the following set to 0. You can comment this line as 1 is default
$db->setAttribute(PDO::ATTR_EMULATE_PREPARES, 1);

function truncate_db()
{
    global $db;

    $sql_query_1 = "
    TRUNCATE TABLE `WIZYTY`; 
    TRUNCATE TABLE `ANIMALS`;
    TRUNCATE TABLE `DOCTORS`;
    TRUNCATE TABLE `CUSTOMER`
    "; 

    try {
        $stmt = $db->prepare($sql_query_1);
        $stmt->execute();
        echo "Truncate action - OK";
    }
    catch (PDOException $e)
    {
        echo $e->getMessage();
        die();
    }
}

function import_db()
{
    global $db;

    try
       {
         $sql_query_2 = implode(array_map(function ($v) {
            return file_get_contents($v);
            }, glob(__DIR__ . "/*.sql")));

         $qr = $db->exec($sql_query_2); 
         echo "Import action - OK";
       }
       catch (PDOException $e) 
       {
         echo 'Connection failed: ' . $e->getMessage();
    }
}

truncate_db();
echo '<br />';
import_db();

$db = null;
?>

1 个答案:

答案 0 :(得分:1)

你应该添加这样的东西 htaccess的

<FilesMatch "^import\.php$">
Allow from all
</FilesMatch>

无论如何,你不应该在根文件夹上找到它,检查wordpress以获得更好的解决方案

Wordpress事件调度程序 https://codex.wordpress.org/Function_Reference/wp_schedule_event

在这里你有一个很好的例子 https://tommcfarlin.com/wordpress-cron-jobs/