无法解析节点应用程序中的json

时间:2014-02-12 16:14:45

标签: javascript json node.js hubot

我有以下请求体,我需要解析为json。我需要将payload字段(其中包含大量垃圾的json)解析为正确的JSON对象(它是console.log(req)的结果):

{ payload: '{\\n  \\"taskDueDate\\": \\"No due\\",\\n  \\"oldTaskMilestone\\": null,\\n  \\"isUpdatedTask\\": \\"true\\",\\n  \\"oldTaskAssignee\\": null,\\n  \\"statusType\\": \\"OPEN\\",\\n  \\"oldTaskVisibility\\": null,\\n  \\"isEstimationUpdated\\": \\"false\\",\\n  \\"invokerEmail\\": \\"mike@domain\\",\\n  \\"oldTaskStatus\\": \\"Resolved\\",\\n  \\"projectId\\": \\"61193\\",\\n  \\"taskContent\\": \\"Add god to monit background processes\\",\\n  \\"taskAssignee\\": \\"Mike B.\\",\\n  \\"invokerId\\": \\"38073\\",\\n  \\"isLabelsUpdated\\": \\"false\\",\\n  \\"taskLabels\\": \\"Improvement\\",\\n  \\"isAssignmentUpdated\\": \\"false\\",\\n  \\"oldTaskEstimation\\": null,\\n  \\"isVisibilityUpdated\\": \\"false\\",\\n  \\"isStatusUpdated\\": \\"true\\",\\n  \\"isMilestoneUpdated\\": \\"false\\",\\n  \\"domain\\": \\"xxx\\",\\n  \\"invokerSmallAvatarURL\\": \\"xxx\\",\\n  \\"invoker\\": \\"Mike B.\\",\\n  \\"taskId\\": \\"33\\",\\n  \\"accountURL\\": \\"xx\\",\\n  \\"taskAuthor\\": \\"Mike B.\\",\\n  \\"isTimeEntryAdded\\": \\"false\\",\\n  \\"unsubscribeURL\\": \\"xxx\\",\\n  \\"oldTaskPriority\\": null,\\n  \\"oldTaskDueDate\\": null,\\n  \\"projectURL\\": \\"xxx\\",\\n  \\"taskMilestone\\": \\"Not planned\\",\\n  \\"taskPriority\\": \\"HIGH\\",\\n  \\"taskTitle\\": \\"Start using god gem\\",\\n  \\"oldTaskLabels\\": null,\\n  \\"isPriorityUpdated\\": \\"false\\",\\n  \\"taskURL\\": \\"xxx\\",\\n  \\"taskStatus\\": \\"Open\\",\\n  \\"subdomain\\": \\"xx\\",\\n  \\"invokerProfileURL\\": \\"xx\\",\\n  \\"statusLabel\\": \\"reopened\\",\\n  \\"taskEstimation\\": \\"Not estimated\\",\\n  \\"isNewTask\\": \\"false\\",\\n  \\"isAttachmentsUpdated\\": \\"false\\",\\n  \\"projectName\\": \\"xx\\",\\n  \\"taskVisibility\\": \\"ALL\\",\\n  \\"isDueDateUpdated\\": \\"false\\"\\n}' }

为此,我使用以下代码:

payload = req.body['payload']
JSON.parse(payload)

这样的代码给了我一个错误:

Syntax error: unexpected token \

有趣的是,当我将payload var的内容转储到控制台并使用JSON.parse(my_copied_json_string)在Chrome开发者控制台中将其过去时,它运行正常。

你能告诉我为什么这可能表现得那样,我该怎么做才能理解和解决这个奇怪的问题?


JSFiddle证明了这个问题:http://jsfiddle.net/7PZD9/5/

5 个答案:

答案 0 :(得分:1)

这是一个正在运作的jsfiddle:http://jsfiddle.net/7PZD9/7/

我首先用空白替换所有新行字符,然后用空白替换反斜杠。如果您的字符串中可能有反斜杠,那么您将需要一个我无法编写的更强大的正则表达式。

var fixed_backslashes = string.replace(/\\n/g, "");
fixed_backslashes = fixed_backslashes.replace(/\\/g,"")

答案 1 :(得分:1)

这个确实有效。这不是最美丽的,因为我过滤了几次。事实是你的json字符串有很多垃圾。

string = '{\\n  \\"taskDueDate\\": \\"No due\\",\\n  \\"oldTaskMilestone\\": null,\\n  \\"isUpdatedTask\\": \\"true\\",\\n  \\"oldTaskAssignee\\": null,\\n  \\"statusType\\": \\"OPEN\\",\\n  \\"oldTaskVisibility\\": null,\\n  \\"isEstimationUpdated\\": \\"false\\",\\n  \\"invokerEmail\\": \\"mike@domain\\",\\n  \\"oldTaskStatus\\": \\"Resolved\\",\\n  \\"projectId\\": \\"61193\\",\\n  \\"taskContent\\": \\"Add god to monit background processes\\",\\n  \\"taskAssignee\\": \\"Mike B.\\",\\n  \\"invokerId\\": \\"38073\\",\\n  \\"isLabelsUpdated\\": \\"false\\",\\n  \\"taskLabels\\": \\"Improvement\\",\\n  \\"isAssignmentUpdated\\": \\"false\\",\\n  \\"oldTaskEstimation\\": null,\\n  \\"isVisibilityUpdated\\": \\"false\\",\\n  \\"isStatusUpdated\\": \\"true\\",\\n  \\"isMilestoneUpdated\\": \\"false\\",\\n  \\"domain\\": \\"xxx\\",\\n  \\"invokerSmallAvatarURL\\": \\"xxx\\",\\n  \\"invoker\\": \\"Mike B.\\",\\n  \\"taskId\\": \\"33\\",\\n  \\"accountURL\\": \\"xx\\",\\n  \\"taskAuthor\\": \\"Mike B.\\",\\n  \\"isTimeEntryAdded\\": \\"false\\",\\n  \\"unsubscribeURL\\": \\"xxx\\",\\n  \\"oldTaskPriority\\": null,\\n  \\"oldTaskDueDate\\": null,\\n  \\"projectURL\\": \\"xxx\\",\\n  \\"taskMilestone\\": \\"Not planned\\",\\n  \\"taskPriority\\": \\"HIGH\\",\\n  \\"taskTitle\\": \\"Start using god gem\\",\\n  \\"oldTaskLabels\\": null,\\n  \\"isPriorityUpdated\\": \\"false\\",\\n  \\"taskURL\\": \\"xxx\\",\\n  \\"taskStatus\\": \\"Open\\",\\n  \\"subdomain\\": \\"xx\\",\\n  \\"invokerProfileURL\\": \\"xx\\",\\n  \\"statusLabel\\": \\"reopened\\",\\n  \\"taskEstimation\\": \\"Not estimated\\",\\n  \\"isNewTask\\": \\"false\\",\\n  \\"isAttachmentsUpdated\\": \\"false\\",\\n  \\"projectName\\": \\"xx\\",\\n  \\"taskVisibility\\": \\"ALL\\",\\n  \\"isDueDateUpdated\\": \\"false\\"\\n}'

fixed_backslashes = string.replace(/([^\/])\/([^\/])/g,"$1//$2")
fixed_backslashes = fixed_backslashes.replace(/\\n/g,"")
fixed_backslashes = fixed_backslashes.replace(/\\/g,"")
console.log(fixed_backslashes)

parsed = JSON.parse(fixed_backslashes)
console.log(parsed)

基本上摆脱了所有的反斜杠和换行符。

答案 2 :(得分:1)

你的JSON被转义两次。

如果您确实需要解析数据,可以这样做:

JSON.parse(JSON.parse('"' + payload + '"'))

答案 3 :(得分:0)

它不应该是nodeJS问题; Chrome和nodeJS使用相同的JavaScript引擎,因此如果在chrome上运行,它也应该在nodeJS上运行;

我试图通过命令行在节点中解析上面的JSON字符串,但它确实有效。 我认为在最终到达节点之前,有一些东西可以修改上面的字符串。

答案 4 :(得分:0)

可能你只需要删除“payload”=> (以及最后的对应部分),以便你的字符串

"{\n  \"accountURL\": \"https://domain.com\",\n  \"newCommitsCount\": \"1\",\n  \"pushURL\":\"https://domain.com/project/64249/git/source/compare/revisions/0b6438955f2a5a7981fd25cfa5b48fe3fb4c888d,7771e638d1356a14d1dc46f3f5cfaab858370a5e\",\n  \"unsubscribeURL\": \"https://domain.com:443/unsubscribe?token=receiverToken&type=COMMITS&projectId=64249\",\n  \"invokerEmail\": \"email@email.com\",\n  \"projectURL\": \"https://domain.com/project/64249\",\n  \"projectId\": \"64249\",\n  \"afterPushRevision\": \"7771e638d1356a14d1dc46f3f5cfaab858370a5e\",\n  \"invokerId\": \"38074\",\n  \"pushDate\": \"2014-02-11T15:26:36+0000\",\n  \"beforePushRevision\": \"0b6438955f2a5a7981fd25cfa5b48fe3fb4c888d\",\n  \"repositoryURL\": \"git_url\",\n  \"subdomain\": \"subdomain\",\n  \"domain\": \"domain\",\n  \"branch\": \"develop\",\n  \"invokerProfileURL\": \"url\",\n  \"commitsCount\": \"1\",\n  \"invokerSmallAvatarURL\": \"xx\",\n  \"projectName\": \"NAME\",\n  \"invoker\": \"Invoker Name.\",\n  \"commits\": {\"commit\":   {\n    \"revision\": \"7771e638d1356a14d1dc46f3f5cfaab858370a5e\",\n    \"commitMessage\": \"quickfix\",\n    \"committerId\": \"38074\",\n    \"committerEmail\": \"email\",\n    \"committerName\": \"Name.\",\n    \"commitDate\": \"2014-02-11T15:26:27+0000\",\n    \"commitURL\": \"https://domain.com/project/64249/git/source/commit/develop/7771e638d1356a14d1dc46f3f5cfaab858370a5e\"  }}}"