解析/解码响应(Json格式?)-PHP Curl

时间:2018-09-04 10:15:17

标签: php json parsing curl zoho

我正在使用PHP Curl将html表单数据推送到创建记录的CRM(Zoho)。

创建记录后的响应(回显$ response;):

*已成功添加记录* 3442526000000497019 * 2018-09-04 11:32:312018-09-04 11:32:31 *

我想解析/解码此响应($ response),以提取记录ID( 3442526000000497019 )。

在CRM CRM SDK中,它说明了响应采用json格式。

因此,我尝试使用json_decode功能解码响应:

var_dump(json_decode($responser));
var_dump(json_decode($responser, true));

但是,这将返回NULL(如果无法解码json或编码数据的深度大于递归限制,则返回NULL。),而不是数组。

任何提示,暗示,指点指向正确的方向,我将不胜感激。我是否必须以其他方式对其进行解码?

我的脚本的以下摘录显示了如何插入表单数据(作为XML数据通过php Curl发送到CRM):

<?php

$xml =  "<?xml version=\"1.0\" encoding=\"UTF-8\"?>
    <Leads>
        <row no=\"1\">
            <FL val=\"Uhrzeit\">".$uhrzeit."</FL>       
            <FL val=\"Datum\">".$datum."</FL>
            <FL val=\"First Name\">'Mad'</FL>
            <FL val=\"Last Name\">'Dog'</FL>
            <FL val=\"Phone\">".$phone."</FL>
            <FL val=\"Email\">".$email."</FL>
            <FL val=\"Zip Code\">".$postcode."</FL>
            <FL val=\"fuerwen\">".$fuerwen."</FL>
            <FL val=\"pflegegrad\">".$pflegegrad."</FL>
            <FL val=\"mobilitaet\">".$mobilitaet."</FL>
            <FL val=\"sprache\">".$sprache."</FL>
            <FL val=\"betreuungsbeginn\">".$zeitpunkt."</FL>
        </row>
    </Leads>";
$auth="fewfwefwe";
    $url ="https://crm.zoho.com/crm/private/xml/Leads/insertRecords";
    $query="authtoken=".$auth."&scope=crmapi&newFormat=1&xmlData=".$xml;
    $ch = curl_init();
    /* set url to send post request */
    curl_setopt($ch, CURLOPT_URL, $url);
    /* allow redirects */
    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
    /* return a response into a variable */
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    /* times out after 30s */
    curl_setopt($ch, CURLOPT_TIMEOUT, 30);
    /* set POST method */
    curl_setopt($ch, CURLOPT_POST, 1);
    /* add POST fields parameters */
    curl_setopt($ch, CURLOPT_POSTFIELDS, $query);// Set the request as a POST FIELD for curl.

    //Execute cUrl session
    $responser = curl_exec($ch);
    curl_close($ch);
    echo $responser;

    var_dump(json_decode($responser));
    var_dump(json_decode($responser, true));

亲切的问候 莱昂诺尔

1 个答案:

答案 0 :(得分:0)

实施CRM API SDK是为了处理ZOHO CRM API版本2,并且您引用的代码称为API版本1。

您要发布到XML API,因此,您应该期望收到XML响应。

如果您希望获得json响应,请考虑将API URL中的XML部分更改为JSON,例如:https://crm.zoho.com/crm/private/json/Leads/insertRecords,并且它应该接受与XML API完全相同的参数。

以下是示例回复:

{"response":{"result":{"recorddetail":{"FL":[{"val":"Id","content":"3442526888888888888"},{"val":"Created Time","content":"2018-09-11 14:21:31"},{"val":"Modified Time","content":"2018-09-11 14:21:31"},{"val":"Created By","content":"Jon Deo"},{"val":"Modified By","content":"Jon Deo"}]},"message":"Record(s) added successfully"},"uri":"/crm/private/json/Leads/insertRecords"}}

请考虑从您的问题中删除authtoken,因为它现在是公开的!