我想知道如何修改此现有代码以跟踪图像/横幅点击/视图?这甚至可以只用PHP吗,或者你需要使用jQuery(ajax)吗?
我在 MYSQL 表中tblbanners
内部bannerClicks
和bannerViews
。
这是生成图像/横幅的代码:
$query91 = 'SELECT * FROM tblbanners WHERE tblbanners.bannerStatus!='1'';
$result91 = full_query ($query91);
$bannerCounter = 1;
while ($data91 = mysql_fetch_array ($result91))
{
$ID = $data91['ID'];
$bannerName = $data91['bannerName'];
$bannerLocation = $data91['bannerLocation'];
$bannerUrl = $data91['bannerUrl'];
$bannerCode[$bannerCounter] = '<a id="' . $ID . '" class="banner-url" href="' . $bannerUrl . '" target="_blank"><img alt="' . $bannerName . '" src="banners/' . $bannerLocation . '" width="100px" height="200px" /></a>';
$bannerCounter++;
}
$bannerAdTotals = $bannerCounter - 1;
if($bannerAdTotals > 1)
{
mt_srand((double)microtime() * 1234567);
$bannerPicked = mt_rand(1, $bannerAdTotals);
}
else
{
$bannerPicked = 1;
}
$bannerAd = $bannerCode[$bannerPicked];
print $bannerAd;
您可以使用JavaScript,也可以拦截点击。要拦截点击,假设您将横幅 URL 存储在数据库中,您只需设置 PHP 脚本来拦截点击、跟踪点击,然后重定向。简单如下:
<?php
$sql = "SELECT `url` FROM `banners` WHERE `id` = :banner_id LIMIT 1";
$stmt = $db->prepare($sql);
$stmt->bindParam(':banner_id', $_GET['id'], PDO::PARAM_INT);
$stmt->execute();
$banner = $stmt->fetchObject();
$sql = "INSERT INTO `clicks` (`banner_id`) VALUES (1)";
$res = $db->exec($sql);
header('Location: ' . $banner->url);
显然,您需要实例化数据库连接/对象,更改任何数据库表和列名称以及任何验证。
使用此方法,当您显示横幅时,您可以在从数据库中选择横幅时执行此操作:
<a href="track_click.php?id=<?php echo $banner->id; ?>">
<img src="<?php echo $banner->img; ?>" alt="<?php echo $banner->alt; ?>" />
</a>