我有以下请求体,我需要解析为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/
答案 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\" }}}"