0

该应用程序将 gps 位置发送到用户设置的 php 服务器。我有一个 PHP MySQL 模型服务器。我不知道如何接收从应用程序发送到我服务器数据库的 JSON。任何帮助,将不胜感激。提前致谢。代码位于https://github.com/jcs/triptracker/blob/master/src/org/jcs/triptracker/TrackerService.java

POST 参数是一个位置数组,每个元素都是一个哈希值,包括时间(来自位置服务的 Unix 时间戳)、纬度和经度(任意精度的两个浮点值)以及以米/秒为单位的速度。

提前致谢。

4

3 回答 3

0

我花了一些时间来解码格式,但以下代码段正在从应用程序中提取数据。请注意,trip tracker 可能会提交一系列以前无法传输的位置点。

<?php
$locations  = $_REQUEST['locations'];   // Get all POST arrays

i = 0;                                  // Choose first locations array

// Now you can access single fields with:
time      = $locations[i]['time']; 
latitude  = $locations[i]['latitude'];
longitude = $locations[i]['longitude'];
speed     = $locations[i]['speed'];

?>

请注意,“时间”是自纪元以来的 MILLIseconds,对于 unix 时间戳,我们需要除以 1000 为浮点数以允许转换。同样,可以有超过 1 个可用的位置数组,通过在循环中向上计数 i 来访问其他数组。

于 2014-05-29T11:18:26.733 回答
0

您可以使用 json_decode() 从收到的 json 中创建一个对象。

一个例子是:

$data = json_decode($_POST['yourdata']);

假设 JSON 看起来像这样:

{"foo":"bar"}

您现在可以执行以下操作:

echo $data->foo;

在您的 mysql 查询中使用此数据。

于 2012-11-29T13:02:16.360 回答
0

您可以像这样在 php 中获取变量:

$lat = $_REQUEST['lat'];
$lng = $_REQUEST['lng'];

然后你可以在你的数据库中插入 $lat 和 $lng。

例子:

function launchQuery($call)
{
    $link = mysqli_init();
    if (!$link) {
        die('mysqli_init failed');
    }

    if (!mysqli_options($link, MYSQLI_INIT_COMMAND, 'SET AUTOCOMMIT = 1')) {
        die('Setting MYSQLI_INIT_COMMAND failed');
    }

    if (!mysqli_options($link, MYSQLI_OPT_CONNECT_TIMEOUT, 5)) {
        die('Setting MYSQLI_OPT_CONNECT_TIMEOUT failed');
    }

    if (!mysqli_real_connect($link, $dbhost, $dbuser, $dbpassword, $dbname, $dbport)) {
        die('Connect Error (' . mysqli_connect_errno() . ') '  . mysqli_connect_error());
    }       

    mysqli_query($link,"SET NAMES 'utf8'");
    $rs = mysqli_query($link, $call);

    mysqli_close($link);

    return $rs;
} 

launchQuery("insert into whatever_your_table_name_is (latitude, longitude) values (".$lat.",".$lng.");");
于 2012-11-29T13:04:24.230 回答