[PHP] 방문로그에 특정 에이전트 제외하고 로그 남기기

iPhone 6s PlusAuto Mode1/1083secf/2.20EV4.2mmISO-252016-05-14 17:20:42

PHP 에서 특정 사용자 에이전트(예: Googlebot 등)를 제외하고 방문로그를 DB에 남기는 코드이다. 방문로그 테이블 구조에 따라 아래 코드는 수정된 후 사용되어야 한다.

<?php
$_AGENT_EXCLUDE = array(
    'mod_pagespeed',
    'bot'
);

if (!isset($_SESSION['ss_visit_log']) || !$_SESSION['ss_visit_log']) {
    if (str_replace($_AGENT_EXCLUDE, '', $_SERVER['HTTP_USER_AGENT']) == $_SERVER['HTTP_USER_AGENT']) {
        $sql = " insert into `{$nt['visit_table']}` ( vi_date, vi_time, vi_referer, vi_agent, vi_ip ) values ( :vi_date, :vi_time, :vi_referer, :vi_agent, :vi_ip ) ";
        $DB->prepare($sql);
        $DB->bindValueArray([
            ':vi_date'    => NT_TIME_YMD,
            ':vi_time'    => NT_TIME_HIS,
            ':vi_referer' => $_SERVER['HTTP_REFERER'] ? $_SERVER['HTTP_REFERER'] : '',
            ':vi_agent'   => $_SERVER['HTTP_USER_AGENT'],
            ':vi_ip'      => $_SERVER['REMOTE_ADDR']
        ]);

        $_SESSION['ss_visit_log'] = $DB->execute();
    }
}
$_AGENT_EXCLUDE 지정된 문자열을 HTTP_USER_AGENT 에 포함하고 있으면 로그를 DB에 남기지 않는다. 제외될 문자열은 배열인데 str_replace 함수를 이용해 치환 후 치환된 문자열과 원래 문자열이 비교해서 같은 경우에만 로그를 남기는 것이다. 코드의 8 라인에 해당된다.

편리

PHP와 MariaDB, jQuery 등을 사용해 게시판, 쇼핑몰 솔루션을 개발합니다. 그누보드5와 영카트5 개발에 참여 했습니다. Linux와 Nginx는 물론 WordPress, Git 등에도 관심이 많습니다. 자전거 타기 및 사진 촬영을 취미로 하고 있습니다.

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.