3

我一直在尝试从他们的调查猴子帐户中为客户提取调查数据,似乎他们的数据越多,非法字符就越有可能被引入到生成的 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。

4

1 回答 1

0

也许我把整个事情过分简化了,如果是这样的话,我很抱歉,但我也有这些有趣的小字符出现在结果中。它们是前导和尾随空格。您可以在检索时修剪数据并查看它是否仍然发生?

于 2014-08-17T13:01:22.063 回答