我想查找打开后发送邮件的收件人的IP地址。我可以判断他是否打开了我的电子邮件,但没有获得客户端的正确IP地址。
在我的PHP代码中,我创建了一个动态图像路径来跟踪IP地址。
<img border="0" height="150" src="http://www.ogmaconceptions.com/tracking.php?email=<?php echo $client_email?>" width="100" />
在我的tracking.php中,我使用此代码来跟踪IP并动态创建图像。
public function getRealIP() {
$ipaddress = '';
if(isset($_SERVER['HTTP_CF_CONNECTING_IP'])) {
$ipaddress = $_SERVER['HTTP_CF_CONNECTING_IP'];
} else if (isset($_SERVER['HTTP_X_REAL_IP'])) {
$ipaddress = $_SERVER['HTTP_X_REAL_IP'];
}
else if (isset($_SERVER['HTTP_CLIENT_IP']))
$ipaddress = $_SERVER['HTTP_CLIENT_IP'];
else if(isset($_SERVER['HTTP_X_FORWARDED_FOR']))
$ipaddress = $_SERVER['HTTP_X_FORWARDED_FOR'];
else if(isset($_SERVER['HTTP_X_FORWARDED']))
$ipaddress = $_SERVER['HTTP_X_FORWARDED'];
else if(isset($_SERVER['HTTP_FORWARDED_FOR']))
$ipaddress = $_SERVER['HTTP_FORWARDED_FOR'];
else if(isset($_SERVER['HTTP_FORWARDED']))
$ipaddress = $_SERVER['HTTP_FORWARDED'];
else if(isset($_SERVER['REMOTE_ADDR']))
$ipaddress = $_SERVER['REMOTE_ADDR'];
else
$ipaddress = 'UNKNOWN';
return $ipaddress;
}
function LoadJpeg($imgname)
{
/* Attempt to open */
$im = @imagecreatefromjpeg($imgname);
/* See if it failed */
if(!$im)
{
/* Create a black image */
$im = imagecreatetruecolor(150, 30);
$bgc = imagecolorallocate($im, 255, 255, 255);
$tc = imagecolorallocate($im, 0, 0, 0);
imagefilledrectangle($im, 0, 0, 150, 30, $bgc);
/* Output an error message */
imagestring($im, 1, 5, 5, 'Error loading ' . $imgname, $tc);
}
return $im;
}
header('Content-Type: image/jpeg');
$img = LoadJpeg('images/OC-logo.jpg');
imagejpeg($img);
imagedestroy($img);
我收到的是IP但是收件人的电子邮件服务器的IP,而不是收件人的实际IP地址。是否有任何技巧,以便我也可以获得客户端IP。
由于 阿玛尔
答案 0 :(得分:1)
感谢邮件提供商,垃圾邮件发送者无法再跟踪用户IP。 隐私如今并不像过去那样愚蠢。
已在独立和在线邮件客户端中采取预防措施
答案 1 :(得分:0)
哥们
你应该阅读
<?php
$client_ip = getHostByAddr($_SERVER['REMOTE_ADDR']);
?>
并且不要把它放在嵌套的IF中, 这样你就可以获得客户端的IP .. ^ _ ^