在同一台服务器上从另一个页面手动刷新页面

时间:2015-04-13 21:48:37

标签: javascript php mysql cron

我正在尝试使用代码从PHP文件中将MySQL标志设置为true(让我们说A)。我想从另一个已经打开的PHP文件(B)中读取这个MySQL标志。问题是:在更改第一页(A)的标志值后,有没有办法手动刷新此(B)页面?

可能正在使用cron或类似的东西,我真的不想每隔X秒刷新一次页面B,直到它读取新的标志值。

1 个答案:

答案 0 :(得分:0)

使用AJAX。

在B页面内创建一个请求函数来检查MySQL标志的状态。如果该标志设置为true,请刷新页面。

在B程序插入的HTML中:

<head>
...
  <script>
    function enableChecker() {
        setInterval( checkFlag, 10000); // Check each ten seconds
    }

    function checkFlag() {
        xmlhttp = GetXmlHttpObject();
        if ( xmlhttp==null ) return;
        xmlhttp.onreadystatechange = function() {
            if ( xmlhttp.readyState == 4 ) {
                if ( xmlhttp.responseText == "OK" ) {
                    location.reload(); // Refresh the page
                }
            }
        }
        xmlhttp.open( 'GET', 'myCheckProgram.php', true ); // Call php program to check the flag value
        xmlhttp.send( null );
        return false;
    }
  </script>
</head>
<body onload="enableChecker()" >

创建一个名为myCheckProgram.php的程序

<?php

/* Blah blah to connect with database and query for flag */

$flag = // Result of query

echo $flag ? 'OK' : 'NOK' // Return OK if flag is true

?>