Перехват переменных данных Json из json_decode

У меня есть сценарий vxml, который перехватывает параметр записи, чтобы отправить текстовое сообщение пользователю, чтобы собрать его электронную почту.

Вот сценарий

     <?php
header("Content-type: text/xml");
echo "<?xml version=\"1.0\"?>\n";

$PIN = $_GET['pin'];
$CALLER = 1 . $_GET['callID'];
$params['to'] = $CALLER;
$params['from'] = "16172075679";
$params['body'] = "Please Respond To This Text Message With Your Email Address So We Can Better Serve You.";
$params['result_url'] = "http://hubenterprises.com.mx/ParseSMSresponse.php";

//initialize curl
$ch = curl_init();

// set necessary curl options
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $params);
curl_setopt($ch, CURLOPT_URL, "http://hosting.plumgroup.com/ws/sms/queue.json");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_USERPWD, "[email protected]:Huba5474");

$result = curl_exec($ch);
// process the json result body
$json = (json_decode($result, true) !== null) ? json_decode($result, true) : false;
$success = false;
if ($json['status'] == 'success') {
$success = true;
$message_reference = $json['result']['sms_message']['sms_message_id'];//UPLOAD SMS MESSAGE ID
//INSERT HERE// TODO: insert this value into your database with a pin or what have you for the user
}

curl_close($ch);
?>
<vxml version="2.0">
<form>
<block>
<log><? print_r($params) ?></log>
hello  <value expr="'<? echo($CALLER) ?>'"/>
<?
var_dump($json);
var_dump($message_reference);
?>
<return namelist=""/>
</block>
</form>
</vxml>

Когда я var_dump ($ json) выводит это, и текстовое сообщение отправляется.

<?xml version="1.0"?>
<vxml version="2.0">
<form>
<block>
<log>Array
(
[to] => 18159856396
[from] => 16172075679
[body] => Please Respond To This Text Message With Your Email Address So We Can Better Serve You.
[result_url] => http://hubenterprises.com.mx/ParseSMSresponse.php
)
</log>
hello  <value expr="'18159856396'"/>
array(3) {
["status"]=>
string(7) "success"["error"]=>
string(0) ""["result"]=>
array(1) {
["sms_messages"]=>
array(1) {
[0]=>
array(7) {
["sms_message_id"]=>
string(32) "5a6c5c7114a74679861209c27a083542"["to"]=>
string(11) "18159856396"["from"]=>
string(10) "6172075679"["body"]=>
string(87) "Please Respond To This Text Message With Your Email Address So We Can Better Serve You."["result_url"]=>
string(49) "http://hubenterprises.com.mx/ParseSMSresponse.php"["request_timestamp"]=>
int(1472838803)
["status"]=>
string(6) "queued"}
}
}
}
NULL
<return namelist=""/>
</block>
</form>
</vxml>

Я не очень хорошо знаком с json_decode. как мне перехватить параметры, которые он выводит в переменных, чтобы я мог загрузить эту информацию в свою базу данных? Я попытался поймать их в $ message_reference (когда я var_dump ($ message_reference); он возвращает ноль).

Какие-либо предложения?

0

Решение

$ message_reference возвращает null, потому что вы пытаетесь получить доступ к несуществующему свойству. Выходной массив показывает, что ключом является sms_messages, а не sms_message.

В дополнение к этому, sms_messages является массивом. Таким образом, для доступа к сообщению это будет $ json [‘result’] [‘sms_messages’] [0] — это даст вам массив значений сообщения.

Итак, я полагаю, вы могли бы сделать что-то вроде этого:

$message_array = $json['result']['sms_messages'][0];
$message_id = $message_array['sms_message_id'];

И так далее для других значений в этом массиве.

Если вы ожидаете, что этот запрос curl будет возвращать несколько сообщений одновременно, что, по-видимому, вы и делаете, учитывая структуру ответа, вам придется поместить это в цикл foreach. Который пошел бы что-то вроде этого ..

$messages = $json['result']['sms_messages'];
foreach($messages as $message)
{
$message_id = $message['sms_message_id'];
// assign additional keys to variables and do something with the data
// for each message in the array.
}
1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]