我正在尝试实施一个网站,每次刷新页面时都会显示一个随机图像。
目前,所有图片都在“/ 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中实现。
答案 0 :(得分:0)
您可以通过执行ORDER BY RAND()
来自行执行mysql查询SELECT * FROM `pngs` ORDER BY RAND( );
这将执行查询并生成结果randomnly row results