php - 解析/解码响应(Json 格式?) - PHP Curl
问题描述
我正在使用 PHP Curl 将 html 表单数据推送到创建记录的 CRM (Zoho)。
创建记录后的响应(echo $response;):
*记录添加成功*3442526000000497019*2018-09-04 11:32:312018-09-04 11:32:31*
我想解析/解码这个响应($response),以提取记录 ID(3442526000000497019)。
在 CRM API SDK 中,它说明了 json 格式的响应。
因此,我尝试使用 json_decode 函数对响应进行解码:
var_dump(json_decode($responser));
var_dump(json_decode($responser, true));
但是,这会返回 NULL(如果无法解码 json 或编码的数据比递归限制更深,则返回 NULL。)而不是数组。
我将不胜感激任何提示,提示,指向一个好的方向。我是否必须以其他方式对其进行解码?
我的脚本的以下摘录显示了如何插入表单数据(通过 php Curl 作为 XML 数据到 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));
亲切的问候莱奥诺
解决方案
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,因为它现在是公开的!
推荐阅读
- asp.net - Microsoft.AspNet.WebApi 5.2.7 路由问题
- javascript - 在页面加载时隐藏 facebook 客户聊天插件的问候对话框
- sql-server - SQL 列更新解决数据质量问题
- javascript - 如何避免旋转时自动左对齐?
- openvino - 如何为 OpenVino 永久设置环境变量
- c++ - 如何给类添加继承结构,参考“enable_share_on_this”
- c# - UWP NavigationView 防止卸载页面
- ionic-framework - 如何在 ionic 3 pwa 应用程序中禁用 Android 后退按钮
- reactjs - 反应从 DOM 计算的初始状态
- asp.net-mvc - 将 Visual Studio 2017 从移动开发更改回 Web 开发