Merge branch 'master' of gitee.com:hainatravel/information-system

feature/trippest
尹诚诚 6 years ago
commit c392462857

@ -16,7 +16,7 @@ class Gaapi extends CI_Controller
public function user_track() public function user_track()
{ {
$cid = $this->input->get_post('cid'); $cid = $this->input->get_post('cid');
$analytics = $this->initializeAnalytics(); $analytics = $this->initializeAnalytics();
$response = $this->getReport($analytics, $cid); $response = $this->getReport($analytics, $cid);
$this->printResults($response); $this->printResults($response);
@ -24,17 +24,17 @@ class Gaapi extends CI_Controller
/** /**
* Initializes an Analytics Reporting API V4 service object. * Initializes an Analytics Reporting API V4 service object.
* *
* @return An authorized Analytics Reporting API V4 service object. * @return An authorized Analytics Reporting API V4 service object.
*/ */
function initializeAnalytics() function initializeAnalytics()
{ {
// Use the developers console and download your service account // Use the developers console and download your service account
// credentials in JSON format. Place them in this directory or // credentials in JSON format. Place them in this directory or
// change the key file location if necessary. // change the key file location if necessary.
$KEY_FILE_LOCATION = __DIR__ . '/gaapi_json/sylvan-box-234910-357cb59e6bf0.json'; $KEY_FILE_LOCATION = 'c:/gaapi_json/sylvan-box-234910-357cb59e6bf0.json';
// Create and configure a new client object. // Create and configure a new client object.
$client = new Google_Client(); $client = new Google_Client();
@ -48,14 +48,14 @@ class Gaapi extends CI_Controller
/** /**
* Queries the Analytics Reporting API V4. * Queries the Analytics Reporting API V4.
* *
* @param service An authorized Analytics Reporting API V4 service object. * @param service An authorized Analytics Reporting API V4 service object.
* @return The Analytics Reporting API V4 response. * @return The Analytics Reporting API V4 response.
*/ */
function getReport($analytics, $cid_no) function getReport($analytics, $cid_no)
{ {
//die($cid); //die($cid);
// Replace with your view ID, for example XXXX. // Replace with your view ID, for example XXXX.
$VIEW_ID = "68484932"; $VIEW_ID = "68484932";
@ -77,24 +77,24 @@ class Gaapi extends CI_Controller
$cid->setName("ga:dimension1"); $cid->setName("ga:dimension1");
$hitTime = new Google_Service_AnalyticsReporting_Dimension(); $hitTime = new Google_Service_AnalyticsReporting_Dimension();
$hitTime->setName("ga:dimension3"); $hitTime->setName("ga:dimension3");
$ip = new Google_Service_AnalyticsReporting_Dimension(); $ip = new Google_Service_AnalyticsReporting_Dimension();
$ip->setName("ga:dimension3"); $ip->setName("ga:dimension3");
// Create Dimension Filter 1 // Create Dimension Filter 1
$cidFilter = new Google_Service_AnalyticsReporting_DimensionFilter(); $cidFilter = new Google_Service_AnalyticsReporting_DimensionFilter();
$cidFilter->setDimensionName("ga:dimension1"); $cidFilter->setDimensionName("ga:dimension1");
$cidFilter->setOperator('EXACT'); $cidFilter->setOperator('EXACT');
$cidFilter->setExpressions($cid_no); $cidFilter->setExpressions($cid_no);
// Create the DimensionFilterClauses // Create the DimensionFilterClauses
$dimensionFilterClause = new Google_Service_AnalyticsReporting_DimensionFilterClause(); $dimensionFilterClause = new Google_Service_AnalyticsReporting_DimensionFilterClause();
$dimensionFilterClause->setFilters(array($cidFilter)); $dimensionFilterClause->setFilters(array($cidFilter));
// OrderBy maybe some bugs // OrderBy maybe some bugs
$order = new Google_Service_AnalyticsReporting_OrderBy; $order = new Google_Service_AnalyticsReporting_OrderBy;
$order->setFieldName("ga:dimension3"); $order->setFieldName("ga:dimension3");
$order->setOrderType("VALUE"); $order->setOrderType("VALUE");
$order->setSortOrder("DESCENDING"); $order->setSortOrder("DESCENDING");
// Create the ReportRequest object. // Create the ReportRequest object.
$request = new Google_Service_AnalyticsReporting_ReportRequest(); $request = new Google_Service_AnalyticsReporting_ReportRequest();
@ -102,8 +102,8 @@ class Gaapi extends CI_Controller
$request->setDateRanges($dateRange); $request->setDateRanges($dateRange);
$request->setMetrics(array($pv)); $request->setMetrics(array($pv));
$request->setDimensions(array($pageUrl, $cid, $hitTime)); $request->setDimensions(array($pageUrl, $cid, $hitTime));
$request->setDimensionFilterClauses(array($dimensionFilterClause)); $request->setDimensionFilterClauses(array($dimensionFilterClause));
$request->setOrderBys(array($order)); $request->setOrderBys(array($order));
$body = new Google_Service_AnalyticsReporting_GetReportsRequest(); $body = new Google_Service_AnalyticsReporting_GetReportsRequest();
$body->setReportRequests(array($request)); $body->setReportRequests(array($request));
@ -118,26 +118,26 @@ class Gaapi extends CI_Controller
*/ */
function printResults($reports) function printResults($reports)
{ {
$alais_array = array( $alais_array = array(
"ga:dimension1" => "cid", "ga:dimension1" => "cid",
"ga:dimension3" => "hitTime", "ga:dimension3" => "hitTime",
"ga:pagePath" => "path" "ga:pagePath" => "path"
); );
$rs_array = array(); $rs_array = array();
for ($reportIndex = 0; $reportIndex < count($reports); $reportIndex++) { for ($reportIndex = 0; $reportIndex < count($reports); $reportIndex++) {
$report = $reports[$reportIndex]; $report = $reports[$reportIndex];
$header = $report->getColumnHeader(); $header = $report->getColumnHeader();
$dimensionHeaders = $header->getDimensions(); $dimensionHeaders = $header->getDimensions();
$metricHeaders = $header->getMetricHeader()->getMetricHeaderEntries(); $metricHeaders = $header->getMetricHeader()->getMetricHeaderEntries();
$rows = $report->getData()->getRows(); $rows = $report->getData()->getRows();
$rs_row = array(); $rs_row = array();
for ($rowIndex = 0; $rowIndex < count($rows); $rowIndex++) { for ($rowIndex = 0; $rowIndex < count($rows); $rowIndex++) {
$row = $rows[$rowIndex]; $row = $rows[$rowIndex];
$dimensions = $row->getDimensions(); $dimensions = $row->getDimensions();
$metrics = $row->getMetrics(); $metrics = $row->getMetrics();
for ($i = 0; $i < count($dimensionHeaders) && $i < count($dimensions); $i++) { for ($i = 0; $i < count($dimensionHeaders) && $i < count($dimensions); $i++) {
//print($dimensionHeaders[$i] . ": " . $dimensions[$i] . "\n"); //print($dimensionHeaders[$i] . ": " . $dimensions[$i] . "\n");
$rs_row[$alais_array[$dimensionHeaders[$i]]] = $dimensions[$i]; $rs_row[$alais_array[$dimensionHeaders[$i]]] = $dimensions[$i];
} }
for ($j = 0; $j < count($metrics); $j++) { for ($j = 0; $j < count($metrics); $j++) {
@ -145,14 +145,13 @@ class Gaapi extends CI_Controller
for ($k = 0; $k < count($values); $k++) { for ($k = 0; $k < count($values); $k++) {
$entry = $metricHeaders[$k]; $entry = $metricHeaders[$k];
//print($entry->getName() . ": " . $values[$k] . "\n"); //print($entry->getName() . ": " . $values[$k] . "\n");
$rs_row[$entry->getName()] = $values[$k]; $rs_row[$entry->getName()] = $values[$k];
} }
} }
array_push($rs_array, $rs_row); array_push($rs_array, $rs_row);
} }
} }
echo(json_encode($rs_array)); echo (json_encode($rs_array));
} }
} }
//end of gaapi //end of gaapi

@ -1,12 +0,0 @@
{
"type": "service_account",
"project_id": "sylvan-box-234910",
"private_key_id": "357cb59e6bf066231fe9d421a1cada76b6af29ef",
"private_key": "-----BEGIN PRIVATE KEY-----\nMIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQDSNl/aj3hQf6bf\naPBHuGTLemiUl2OborE8MNvl5brhJMncTSslS1Q5CQRPk4K6nW1gAq2/gQ5KZ7Sd\nh9gdtWzIDoUS1DBDaZiPB8vVN6YOjIWpRSylIXTewQ6YYuw9kt7vW0orfDSsaWrE\nc2Yb5YN+6GTxVBjFEb19IYg5/8zfmvaUCOinDwO+F8mh6fCS9FyhiN5omKD+ixiQ\nYFIo1CM1SCpT3eH67JIF+hzuGAVWhF7YmdNTBdfrM0/1PBM8HRry0jD1VaDeyv+e\n4lTnPCtvUgc5SJOaLv/UR06X1FpIYikK0RHJ04fTslQxu7hTLqbhg/7d/+aj95K0\nAwaGERvdAgMBAAECggEAAOQZHFdoDVxwlSJEqeNyIDZh+GIfmnYQAUFhMKkOsPCc\nw9rtTxrNRxace0fd2sXtVkF8pp5dWTasmmIMPGNt+dLR7pP/z4Of2o9ZQcJR1vCp\nZc195rz/EL+AmGgLgZXg/5lxGhyDKhJ9vpORNt/FPiFALyOueJ/wslEnkZfwDANv\n0C+uIv2L3g0mrgTqXVwU/dVdYi9UK7hhn0YMgtlbdpxRHV0cIiilb23Cyy0QsFXN\n2MsoHPQWf+72nE+5jNnysXcR8AjAthzOvP/jIcqqBguid1w9F3goH4adLTa1aPIL\ndNGI/z9mwuqGQg5C78ZfmZMb3YIRwV4nmUia7kzrowKBgQDr2h14VyEGAypCjo+r\nXRvDti55PY+jKUnUzbseJca7Z1Z2snvGXWgkoasZc8ozsQjoH7wJJnRoJOGnAJdF\ntyZxtJV5W0pefB6Pfqy6k5MlJJhMy6lGpkQo96iPOBqfowHa1r/S55USHjQAMXG2\nKrX6oq1IWmEmFYMFZnQo7+SPqwKBgQDkK4rnCbirwHC0Z6eXkbk0Fb8KrS0huq3C\nupaoBtwkfkyISBzcXx6Bup/Gg7czSxvY6U/Bg93WtTzzJwVuqKSqcTUrwW4rAmrh\nZNEYjJc5YLKK1xXVOEeisMIsWCEpF8JHvyrCRsoBCOVRbQROFqz9IOSGrplw1Rq6\ntuPp2fsalwKBgQDgbfabG/X9vadKHFSUUY5pBwRkNHNpZJGwIXEMeBALJoN9gcwM\nb7f5G6owFyHzXGRIVmJdJq2gqG/dtc889NJtYtTV3UwAawW9sGH3TRS5RIB0m1xi\nMTcs8LYCSvXysG/EaZOxwtL0oa8D/AjjuvLeJEzWS8KkNdYunlas2dJZ7wKBgEAO\nlWV9jjHxyfJr81oTGDquLD80FSqV/ThhJ/CuVFmOd6//BtM7hRYIrdiOm/0zhfLk\ntXZvrfUcVqsw9k513BzZwYKyQFqkyBrVMfrBZac/JYDjF4cP0NS06R6H829U8z8v\nRTLbqtSVicPNZlsB9Ljv5hiFpiBOQ73NoLjDcMKrAoGAC+mrH9aOBeQuikQllpWJ\naZ7XoDdZcmh3j+o7OZWHAP3mpQ6q6/1iPW4lhG/q6l+syjsYRmQuzYICtSJ6xQlC\nM+AYPjD+O6sW3MWGz469cqrym8o+Bm24emxJNvilo/U/N2Yif2gUGWgw8qXLEGsu\nUedwiH6aWGBFnlVuPz6CZ6s=\n-----END PRIVATE KEY-----\n",
"client_email": "gaapi-904@sylvan-box-234910.iam.gserviceaccount.com",
"client_id": "112785767675412711830",
"auth_uri": "https://accounts.google.com/o/oauth2/auth",
"token_uri": "https://oauth2.googleapis.com/token",
"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
"client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/gaapi-904%40sylvan-box-234910.iam.gserviceaccount.com"
}
Loading…
Cancel
Save