【问题标题】:Randomised content from PHP script not refreshing on reload [duplicate]PHP脚本中的随机内容在重新加载时不刷新[重复]
【发布时间】: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 中生成一个随机数,然后只从数据库中加载所需的一个特定图像。使用上面链接中的技巧来防止缓存。

标签: php html mysql caching


【解决方案1】:

你可以通过执行 ORDER BY RAND() 来自己做 mysql 查询

SELECT * FROM  `pngs` ORDER BY RAND( );

这将执行查询并随机产生结果行结果

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-09-20
    • 1970-01-01
    • 2017-11-18
    • 1970-01-01
    • 1970-01-01
    • 2012-03-24
    相关资源
    最近更新 更多