ویژگی تصویر

تابع gethostbyaddr() در PHP

  /  PHP   /  تابع gethostbyaddr() در PHP
بنر تبلیغاتی الف
آموزش PHP

تابع gethostbyaddr() در PHP برای گرفتن نام هاست (reverse DNS) مربوط به یک آدرس IP استفاده می‌شود. این تابع یک lookup معکوس روی DNS انجام می‌دهد و در صورتی که رکورد PTR معتبر وجود داشته باشد، نام هاست را برمی‌گرداند؛ در غیر این صورت معمولاً همان رشته IP را بازمی‌گرداند.

چرا و چه زمانی از gethostbyaddr() استفاده کنیم

  • برای نمایش نام دامنه یا میزبان مرتبط با یک IP در لاگ‌ها یا گزارش‌ها.
  • برای بررسی اطلاعات اضافی در سیستم‌های تحلیل ترافیک یا IDS/IPS.
  • برای تبدیل IP به نام کاربرپسند جهت نمایش در رابط کاربری (مثلاً گزارشات وب).

نکات کلیدی و محدودیت‌ها

  • عملیات lookup یک فراخوانی شبکه‌ای و بلاک‌کننده است؛ ممکن است با تأخیر همراه باشد.
  • وجود نام هاست بستگی به رکورد PTR در DNS دارد؛ همه IPها رکورد PTR ندارند.
  • نتیجه معکوس DNS قابل اعتماد برای احراز هویت نیست؛ ممکن است جعلی یا اشتباه باشد.
  • در محیط‌های پشت پراکسی یا NAT، نام برگشتی معمولاً نام میزبان مربوط به آدرس عمومی نیست.
  • در اغلب پیاده‌سازی‌ها، اگر lookup با شکست مواجه شود، تابع همان IP ورودی را بازمی‌گرداند.

امضای تابع و جدول خلاصه

تابعورودیخروجییادداشت
gethostbyaddrstring $ip_addressstring (hostname یا همان IP)انجام reverse DNS (وابسته به رکورد PTR)

نمونه‌های کد و توضیحات

مثال ساده

$ip = '8.8.8.8';
$host = gethostbyaddr($ip);
echo "Host for $ip is: $hostn";

در این مثال، آدرس IP گوگل DNS (8.8.8.8) به تابع داده می‌شود. اگر رکورد PTR برای آن وجود داشته باشد، نام هاست را برمی‌گرداند، در غیر این صورت همان رشته IP نشان داده می‌شود. این کد برای تست سریع مناسب است اما در برنامه‌های عملی باید خطاها و زمان‌بر بودن عملیات را در نظر گرفت.

مثال: استفاده در اپلیکیشن وب با بررسی IP کاربر

// گرفتن IP واقعی کاربر (با احتیاط‌بکارگیری هدرهای پراکسی)
$ip = $_SERVER['REMOTE_ADDR'];
if (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) {
    // معمولاً X-Forwarded-For ممکن است لیستی از IP‌ها باشد
    $forwarded = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']);
    $ip = trim($forwarded[0]);
}

// اعتبارسنجی ساده IP
if (filter_var($ip, FILTER_VALIDATE_IP)) {
    $host = gethostbyaddr($ip);
} else {
    $host = 'Invalid IP';
}
echo "Client IP: $ip, Host: $host";

در این مثال ابتدا سعی می‌کنیم IP کاربر را از هدرها استخراج کنیم، سپس با filter_var بررسی می‌کنیم که IP معتبر است یا خیر. توجه داشته باشید که هدرهایی مانند HTTP_X_FORWARDED_FOR توسط کاربر یا پراکسی قابل تغییر هستند؛ بنابراین نباید برای مقاصد امنیتی به تنهایی اعتماد شوند.

مثال پیشرفته: fallback به dns_get_record و کش ساده

// تابعی برای کش ساده روی فایل
function cached_reverse_lookup($ip, $cache_file = '/tmp/rev_cache.json', $ttl = 3600) {
    $cache = [];
    if (file_exists($cache_file)) {
        $cache = json_decode(file_get_contents($cache_file), true) ?: [];
    }

    if (isset($cache[$ip]) && time() - $cache[$ip]['time']  $host, 'time' => time()];
    file_put_contents($cache_file, json_encode($cache));
    return $host;
}

در این نمونه، از یک کش بسیار ساده مبتنی بر فایل استفاده شده تا تعداد lookupها کاهش یابد. اگر gethostbyaddr نتیجه‌ای مشابه IP بازگرداند، تابع از dns_get_record با نوع DNS_PTR استفاده می‌کند تا رکورد معکوس را مستقیم دریافت کند. این روش می‌تواند قابل‌اطمینان‌تر و کنترل‌پذیرتر باشد، اما برای محیط‌های تولیدی توصیه می‌شود از کش‌های حرفه‌ای‌تر مانند Redis یا Memcached استفاده کنید.

جایگزین‌ها و توابع مرتبط

  • dns_get_record() — برای گرفتن رکوردهای DNS مختلف از جمله PTR.
  • gethostbyname() — برای تبدیل نام میزبان به IP (forward lookup).
  • gethostbynamel() — برای دریافت لیستی از آدرس‌های IP مربوط به یک نام هاست.

نکات عملی و بهترین شیوه‌ها

  • همیشه ورودی IP را اعتبارسنجی کنید تا از تزریق یا خطا جلوگیری شود.
  • برای عملیات‌هایی که در مسیر درخواست‌های کاربر اجرا می‌شوند، از کش استفاده کنید تا کارایی بهبود یابد.
  • برای کاربردهای امنیتی، هرگز تنها به reverse DNS اتکا نکنید؛ از مکانیزم‌های قوی‌تری مثل TLS/SSL، امضای پیام یا احراز هویت چندعاملی استفاده کنید.
  • در صورت نیاز به مقیاس بزرگ، از lookup غیرهمزمان یا صف‌بندی درخواست‌ها استفاده کنید تا بلوکه شدن پردازش‌ها رخ ندهد.

جمع‌بندی

تابع gethostbyaddr() یک ابزار ساده و کاربردی برای انجام reverse DNS در PHP است، اما محدودیت‌های شبکه‌ای و تکیه بر رکورد PTR وجود دارد. با پیاده‌سازی کش، fallback به dns_get_record و رعایت نکات امنیتی می‌توانید از این تابع به شکل بهینه و ایمن در اپلیکیشن‌های خود استفاده کنید.

آیا این مطلب برای شما مفید بود ؟

خیر
بله
موضوعات شما در انجمن: