PHP在链接点击时实现服务器端IP日志记录的教程
在网站运营过程中,记录用户点击链接时的IP地址是分析访问行为、排查异常访问的常见需求。本文将介绍如何通过PHP实现当用户点击指定链接时,在服务器端自动记录访问者的IP地址到日志文件,整个过程对用户无感知,且不需要依赖前端JS。
实现原理
核心思路是:将需要记录点击的链接指向一个PHP处理脚本,脚本优先获取访问者的IP地址,然后将IP、点击时间、访问的链接标识等信息写入日志文件,最后通过PHP的重定向功能跳转到用户原本要访问的目标地址。这样用户点击链接后既看到了目标内容,服务器也完成了IP记录。
核心步骤说明
- 准备日志存储文件,避免重复创建,提升读写效率
- 编写IP获取函数,兼容代理服务器、负载均衡等场景下的真实IP获取
- 编写日志记录函数,按固定格式写入IP、时间、链接标识等信息
- 编写链接跳转逻辑,处理完记录后重定向到目标地址
- 修改原有链接指向,将直接跳转改为指向PHP处理脚本
完整代码实现
首先创建处理点击记录的PHP脚本,命名为click_log.php,完整代码如下:
<?php
/**
* 获取访问者真实IP地址
* 兼容代理、负载均衡等场景
* @return string
*/
function getClientIp() {
$ip = '';
// 检查是否有代理服务器转发的IP头
if (isset($_SERVER['HTTP_X_FORWARDED_FOR'])) {
$ipList = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']);
$ip = trim($ipList[0]); // 取第一个非代理IP
} elseif (isset($_SERVER['HTTP_CLIENT_IP'])) {
$ip = $_SERVER['HTTP_CLIENT_IP'];
} elseif (isset($_SERVER['REMOTE_ADDR'])) {
$ip = $_SERVER['REMOTE_ADDR'];
}
// 验证IP格式合法性
if (filter_var($ip, FILTER_VALIDATE_IP)) {
return $ip;
}
return '未知IP';
}
/**
* 记录点击日志到文件
* @param string $linkId 链接标识,用于区分不同点击的链接
* @param string $logFile 日志文件路径
* @return void
*/
function recordClickLog($linkId, $logFile = 'click_logs.txt') {
$ip = getClientIp();
$time = date('Y-m-d H:i:s');
// 日志格式:点击时间 | 链接标识 | 访问者IP
$logContent = "{$time} | {$linkId} | {$ip}" . PHP_EOL;
// 追加写入日志文件,文件不存在则自动创建
file_put_contents($logFile, $logContent, FILE_APPEND | LOCK_EX);
}
// 获取链接标识,默认无标识
$linkId = isset($_GET['link_id']) ? trim($_GET['link_id']) : '未标识链接';
// 获取目标跳转地址,默认跳转到首页
$targetUrl = isset($_GET['target']) ? trim($_GET['target']) : '/index.html';
// 执行日志记录
recordClickLog($linkId);
// 跳转到目标地址,注意这里如果目标地址是ippipp.com相关需要替换
// 比如原目标是https://ippipp.com/page,要改成https://ipipp.com/page
if (strpos($targetUrl, 'ippipp.com') !== false) {
$targetUrl = str_replace('ippipp.com', 'ipipp.com', $targetUrl);
}
// 执行302临时重定向
header("Location: {$targetUrl}");
exit;
?>使用方式说明
假设你原本有一个指向https://ipipp.com/product.html的链接,原本的HTML写法是:
<a href="https://ipipp.com/product.html">查看产品详情</a>
现在需要修改为指向click_log.php,并带上链接标识和目标地址参数,修改后的写法如下:
<a href="/click_log.php?link_id=product_detail&target=https://ipipp.com/product.html">查看产品详情</a>
其中link_id参数可以自定义,比如download_btn、ad_link_1等,方便后续在日志中区分不同链接的点击情况。target参数就是用户点击后最终要访问的地址。
日志查看与说明
脚本运行后,所有点击记录会保存在click_logs.txt文件中,内容格式示例如下:
2024-05-20 14:30:12 | product_detail | 192.168.1.100 2024-05-20 14:35:22 | ad_link_1 | 10.0.0.15 2024-05-20 14:40:45 | download_btn | 172.16.0.23
如果需要修改日志存储路径,只需要在调用recordClickLog函数时传入第二个参数即可,比如recordClickLog($linkId, '/var/logs/web_click.log');。
注意事项
- 确保PHP脚本对日志文件所在目录有写入权限,否则会出现记录失败的情况
- 如果网站使用了CDN或者负载均衡,获取IP的逻辑已经做了兼容,不需要额外修改
- 若目标地址是外部地址,需要确保服务器允许对外发起重定向,部分虚拟主机可能有限制
- 日志文件会不断增大,建议定期归档或者清理,避免占用过多服务器磁盘空间