gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-30 22:01:14 24 4
gpt4 key购买 nike

<分区>

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

目前,所有图像都在目录“/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 基础架构的工作方式...

预期功能:每个页面 View 从 MySQL 数据库返回不同的结果,导致每次刷新时每个用户的图像/文本不同。

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

考虑到我可能已经决定使用错误的基础结构来实现预期结果,现在考虑尝试使用 javascript 实现。

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com