首页 > 解决方案 > 使用 php 将谷歌分析数据传输到 mysqli 数据库

问题描述

我想从访问者那里收集一些数据,但这会减慢我的网站速度我创建了一个名为 tracker.php 的文件,其中包含以下代码

<?php


// get address using ip
function ip_info($ip = NULL, $purpose = "location", $deep_detect = TRUE) {
    $output = NULL;
    if (filter_var($ip, FILTER_VALIDATE_IP) === FALSE) {
        $ip = $_SERVER["REMOTE_ADDR"];
        if ($deep_detect) {
            if (filter_var(@$_SERVER['HTTP_X_FORWARDED_FOR'], FILTER_VALIDATE_IP))
                $ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
            if (filter_var(@$_SERVER['HTTP_CLIENT_IP'], FILTER_VALIDATE_IP))
                $ip = $_SERVER['HTTP_CLIENT_IP'];
        }
    }
    $purpose    = str_replace(array("name", "\n", "\t", " ", "-", "_"), NULL, strtolower(trim($purpose)));
    $support    = array("country", "countrycode", "state", "region", "city", "location", "address");
    $continents = array(
        "AF" => "Africa",
        "AN" => "Antarctica",
        "AS" => "Asia",
        "EU" => "Europe",
        "OC" => "Australia (Oceania)",
        "NA" => "North America",
        "SA" => "South America"
    );
    if (filter_var($ip, FILTER_VALIDATE_IP) && in_array($purpose, $support)) {
        $ipdat = @json_decode(file_get_contents("http://www.geoplugin.net/json.gp?ip=" . $ip));
        if (@strlen(trim($ipdat->geoplugin_countryCode)) == 2) {
            switch ($purpose) {
                case "location":
                    $output = array(
                        "city"           => @$ipdat->geoplugin_city,
                        "state"          => @$ipdat->geoplugin_regionName,
                        "country"        => @$ipdat->geoplugin_countryName,
                        "country_code"   => @$ipdat->geoplugin_countryCode,
                        "continent"      => @$continents[strtoupper($ipdat->geoplugin_continentCode)],
                        "continent_code" => @$ipdat->geoplugin_continentCode
                    );
                    break;
                case "address":
                    $address = array($ipdat->geoplugin_countryName);
                    if (@strlen($ipdat->geoplugin_regionName) >= 1)
                        $address[] = $ipdat->geoplugin_regionName;
                    if (@strlen($ipdat->geoplugin_city) >= 1)
                        $address[] = $ipdat->geoplugin_city;
                    $output = implode(", ", array_reverse($address));
                    break;
                case "city":
                    $output = @$ipdat->geoplugin_city;
                    break;
                case "state":
                    $output = @$ipdat->geoplugin_regionName;
                    break;
                case "region":
                    $output = @$ipdat->geoplugin_regionName;
                    break;
                case "country":
                    $output = @$ipdat->geoplugin_countryName;
                    break;
                case "countrycode":
                    $output = @$ipdat->geoplugin_countryCode;
                    break;
            }
        }
    }
    return $output;
}

// Function to get the client IP address
function get_client_ip() {
    $ipaddress = '';
    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;
  }
  
  $userIp = get_client_ip($ipaddress);
  $email = $_SESSION['useremail'];

    $v_country =  ip_info("$userIp", "Country"); // India
    $v_country_code =  ip_info("$userIp", "Country Code"); // IN
    $v_state = ip_info("$userIp", "State"); // Andhra Pradesh
    $v_city = ip_info("$userIp", "City"); // Proddatur
    $v_address = ip_info("$userIp", "Address"); // Proddatur, Andhra Pradesh, India


    $actual_link = (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] === 'on' ? "https" : "http") . "://$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";
    date_default_timezone_set("Asia/Kolkata");
    $today = date("F j, Y, g:i a");
    $endtime = microtime(true); // Bottom of page
    $loadTime = $endtime - $starttime;



  if(isset($_SESSION['loggedin']) && $_SESSION['loggedin'] == true){ 
  
    $sql = "sql goes  here";
    $result = mysqli_query($conn, $sql);
  }
  else{
    $sql = "sql goes  here";
    $result = mysqli_query($conn, $sql);
    
  }

?>

如您所见,以下代码使用外部 api 使用 ip 地址收集位置数据,但它会减少网站的加载时间。

我想要一个优化的解决方案来收集数据而不增加网站的加载时间,所以我决定使用谷歌分析来收集数据,但不知道如何提取谷歌分析数据并将其存储到 mysqli 服务器中,请你帮帮我。

标签: phpapimysqliservertransfer

解决方案


首先,您应该将报告从 GA 下载到 .csv 文件中,然后您应该使用 php 读取该数据并将其转换为 JSON。

这是一个教程:https ://thisinterestsme.com/convert-csv-file-json-using-php/

然后您应该能够使用该数据并将其发送到您的数据库引擎。


推荐阅读