来自PHP脚本的随机内容在重新加载时未刷新

时间:2017-04-07 11:15:51

标签: php html mysql caching

我正在尝试实施一个网站,每次刷新页面时都会显示一个随机图像。

目前,所有图片都在“/ pngs /”目录中,我有一个带有索引行的MySQL数据库:

<img src="pngs/000.png">
<img src="pngs/001.png">
<img src="pngs/002.png">
<img src="pngs/003.png">
...

然后,在HTML中:

<div class='img'><?php include('pngs.php');?></div>

参考PHP脚本,它从数据库中选择一个随机行:

<?php
  require_once 'login.php';
  $conn = new mysqli($hn, $un, $pw, $db);
  if ($conn->connect_error) die($conn->connect_error);
  $query  = "SELECT * FROM pngs";
  $result = $conn->query($query);
  if (!$result) die($conn->error);
  $rows = $result->num_rows;
  $r = rand(1,$rows);
  $result->data_seek($r);
  $row = $result->fetch_array(MYSQLI_ASSOC);
  echo $row['png'];
  $result->close();
  $conn->close();
?>

目前,当从本地Apache Web服务器运行时,这完全可以跨浏览器工作。但是,从实际站点上载和运行时,图像在刷新时保持固定。

清除缓存并刷新会产生所需的效果,所以这可能是缓存的问题?我尝试了各种缓存清除和无缓存方法,但都没有。

有人想过,也许PHP脚本只运行一次,然后将结果存储在缓存中?在这种情况下,我将如何强制PHP脚本运行每次刷新?

另一个想法是,或许使用Javascript来显示随机图像会是一种更简单,更好的解决方案吗?如果是这样的话,愿意适应。

非常感谢任何建议,相对新手在这里。

感谢。

修改

感谢您的回复,图片缓存解决方法解决了图片问题。

然而,最初的问题更为普遍,与文本类似。

例如,如果我使用带有索引行文本的MySQL数据库:

"First text to be displayed."
"Second text to be displayed."
"Third text to be displayed."
"Fourth text to be displayed."

如果我使用如上所示的类似PHP脚本,则显示的文本最初是正确随机的,但在刷新页面时保持不变。

所以预期的问题更为通用:如何确保每次刷新都执行PHP / MySQL查询,而不是缓存和重复的第一个结果?

编辑2

为进一步编辑道歉,不知道现在是否要为此开始一个新问题......

所以我似乎误解了PHP / MySQL基础设施的运作方式......

预期功能:每个页面视图都会返回与MySQL数据库不同的结果,从而在每次刷新时为每个用户生成不同的图像/文本。

当前功能:每个页面视图在不同用户之间从MySQL数据库返回相同的结果。显示的结果是随机的,并且会更新,但每隔几分钟而不是每次刷新。显示的结果在用户之间是相同的,这意味着PHP脚本/ MySQL查询发生在服务器端,而不是每个用户唯一的。

认为我可能决定使用错误的基础设施来实现预期结果,现在考虑尝试在javascript中实现。

1 个答案:

答案 0 :(得分:0)

您可以通过执行ORDER BY RAND()

来自行执行mysql查询
SELECT * FROM  `pngs` ORDER BY RAND( );

这将执行查询并生成结果randomnly row results