php - 使用 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 服务器中,请你帮帮我。
解决方案
首先,您应该将报告从 GA 下载到 .csv 文件中,然后您应该使用 php 读取该数据并将其转换为 JSON。
这是一个教程:https ://thisinterestsme.com/convert-csv-file-json-using-php/
然后您应该能够使用该数据并将其发送到您的数据库引擎。
推荐阅读
- debugging - 为什么 SASM 的调试器不显示存储后更新的“结果”变量的值?
- javascript - 从 POST 请求中获取响应数据后 React JS & Axios Render
- python - 根据输入类型选择行为的最 Pythonic 方式?
- javascript - 无法将函数传递给 Angular 中的其他对象
- blockchain - 2019 年 11 月比特币现金硬分叉后带有数据的比特币脚本
- javascript - 使用变量输入创建嵌套数组/对象的 Javascript 函数
- node.js - 使用 pdf2json 将 pdf 解析为 json 时出现 TypeError
- fullcalendar - Fullcalendar V4:如何将从 ajax 接收到的 json 解析为事件列表
- jquery - 如何处理网关 API 和 Lambda 代理的错误?
- c++ - 检索函数对象的可调用运算符的所有重载的参数类型