我找不到简洁的方式来总结标题中的问题,请允许我详细说明:
我有一个使用 PHP 脚本“getImg.php”的网站,该脚本从我的数据库中获取图像二进制对象,并在单独页面上的 HTML img 标记调用时显示它。
我想记录人们查看图像的次数,所以我添加了一个简单的行来增加适当图像的“视图”属性。
我认为这很简单,但事实证明它增加了两次。我解决这个问题的方法是使“视图”列浮动并增加 0.5 以增加 1。但是,我今天查看了我的数据库,在一些图像中找到了 0.5!
当我注释掉最后的打印时,它可以正常工作。我假设来自 HTML 标记的调用加上脚本本身算作两次调用?但其他人似乎并非如此。
这只是我的设置吗?
<?php
# Connect to db
include('db.php');
# Get ID
$id = $_GET['id'];
if(!is_numeric($id)) exit;
$q = $db->prepare("SELECT tNail,image,format FROM gallery WHERE id = '$id'");
$q->execute();
$row = $q->fetch(PDO::FETCH_ASSOC);
if(array_key_exists("thumb", $_GET))
$img = base64_decode($row["tNail"]);
else
{
$img = base64_decode($row["image"]);
# Add to views if not thumb
// 0.5 because script called twice due to print?
$db->query("UPDATE gallery SET views = (views + 0.5) WHERE id = '$id'");
}
switch($row["format"])
{
case ".jpg":
header("Content-type: image/jpeg");
break;
case ".png":
header("Content-type: image/png");
break;
}
print $img;
?>
谢谢你的帮助。