【发布时间】:2017-09-02 18:13:01
【问题描述】:
我正在尝试实现一个每次刷新页面时都会显示随机图像的网站。
目前,所有图像都在目录“/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 中实现。
【问题讨论】:
-
因为事实可以替代,我也想解决方案:) 检查这个SO answer。我更喜欢在不需要时不会打到数据库的任何东西,但是如果用户禁用 js,那么你就有麻烦了......
-
为了尽量减少对数据库的压力,我会先在 PHP 中生成一个随机数,然后只从数据库中加载所需的一个特定图像。使用上面链接中的技巧来防止缓存。