我一直在尝试从他们的调查猴子帐户中为客户提取调查数据,似乎他们的数据越多,非法字符就越有可能被引入到生成的 JSON 字符串中。
下面是一个错误响应返回的示例,每个响应都是不同的,甚至更短的请求有时会失败,让我一头雾水。
{
"survey_id": "REDACTED",
"title": "REDACTED",
"date_modified": "2014-XX-18 17:59:00",
"num_responses": 0,
"date_created": "�2014-01-21 10:29:00",
"question_count": 102
}
我无法理解为什么会发生这种情况,字段选项中的参数越多,引入的非法字符就越多。这不仅仅是非法的无效字符,有时还会抛出随机字母,这使我无法正确处理数据。
我正在将 Laravel 4 与 oori https://github.com/oori/php-surveymonkey的第三方 Survey Monkey 库一起使用
任何帮助都将在追踪问题时得到帮助,截止日期非常紧迫,如果无法解决,我将不得不求助于要求客户手动导入 CSV 文件,这并不理想并且可能会引入用户错误。
在旁注中,当在 Survey Monkey 控制台上使用相同的参数时,我没有看到这个问题出现。
操作系统:带有 WAMP 服务器的 Windows 8.1
用于执行请求的代码
$Surveys = SurveyMonkey::getSurveyList(array
(
'page_size' => 1000,
'fields' => array
(
'title', 'question_count', 'num_responses', 'date_created', 'date_modified'
)
));
外观是一个自定义包,SurveyMonkey
用于集成位于此处的原始调查猴子库:
https ://github.com/oori/php-surveymonkey/blob/master/SurveyMonkey.class.php
原始 PHP cURL 请求
$header = array('Content-Type: application/json','Authorization: Bearer REDACTED');
$post = json_encode(array(
'fields' => array(
'title', 'question_count', 'num_responses', 'date_created', 'date_modified'
)
));
$post = json_encode($post);
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, "https://api.surveymonkey.net/v2/surveys/get_survey_list?api_key=REDACTED");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
curl_setopt($ch, CURLOPT_HEADER, false);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_ENCODING, 'UTF-8');
curl_setopt($ch, CURLOPT_POSTFIELDS, $post);
$result = curl_exec($ch);
上述请求返回相同的麻烦字符,没有使用其他任何方法来获取响应。
使用以下代码
echo "\n".mb_detect_encoding($result, 'UTF-8', true);
此代码显示响应的字符集,当成功且不存在非法字符(错误位置仍然存在随机字符)时,它返回实际上是 UTF-8,当存在非法字符时,返回 false 所以什么都没有输出。通常情况下,会返回 false。