我有一个循环,显示数据库中许多不同服务器的信息。现在我正在尝试写在线或离线。我试图手动将IP地址和端口写入srcipt,并且工作正常。但是,当我尝试将表放入变量时,它表明所有表均处于脱机状态。他们大多数使用44405端口,因此我暂时将其手动进行检查。
编辑:是的,我知道此mysql代码已准备就绪,正在等待注入:D
<?php //-----loading servers to website-----
error_reporting(E_ALL);
ini_set('display_errors','1');
$connection = //deleted this part coz includes personal info :D
$alldata = mysql_query("SELECT * FROM muonline ORDER BY id DESC;");
while ($loadservers = mysql_fetch_assoc($alldata)) {
echo "<tr>";
echo '<td>'; //-----here starts the online/offline part of script-----
$serwer = $loadservers['serverAddress'];
$port="44405";
$socket=@fsockopen($serwer,$port,$errno,$errstr,2);
if($socket==true)
{
echo "<p>online</p>";
}else{
echo "<p>offline</p>";
}
echo '</td>';
//------- here is being loaded rest of info of the each server-----
echo "<td><p>" .$loadservers['serverName']."</p></td>";
echo "<td><p>". '<a href="' .$loadservers['serverAddress'].'"target="_blank"><p>'.$loadservers['serverAddress']. "</p></a>". "</td>";
echo "<td><p>" .$loadservers['serverExp']. "</p></td>";
echo "<td><p>" .$loadservers['serverDrop']. "</p></td>";
echo "<td><p>" .$loadservers['info']. "</p></td>";
echo "</tr>";
}
mysql_close();
?>
您正在尝试使用fsockopen
以开头的服务器http://
。您需要使用解析URL parse_url
,提取URL的host
一部分并进行检查。像这样:
$parsedUrl = parse_url($loadservers['serverAddress']);
$socket = fsockopen($parsedUrl['host'],$port,$errno,$errstr,2);
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句