【问题标题】:Invalid JSON Parser Error无效的 JSON 解析器错误
【发布时间】:2013-04-26 03:54:45
【问题描述】:

我有一个属性包含引号(')、斜杠(/)或 Environmental.NewLine 的对象

我将此对象构造为 JSON 字符串并尝试将其分配给 jQGrid。

但它显示Invalid JSON Parser error

我怎样才能成功解析这个。

 myObj=new {Text=@"Samp'le value"}

在 ASP.Net MVC 中,return JSON(myObj) 用于构造 JSON。

有没有人知道,在解析 JSON 时,我们需要在哪里配置来处理这个 ' / Environmental.NewLine(\n)

我们需要使用任何其他库来处理像Newtosoft JSON

来自服务器的 JSON

     {"total":1 ,"page":1,"records":3,"rows":[{"i":0,"cell":"","1","1","DesSinglApostropAndURLhasEnterKeyChar",
"Samp'le value","http://google.com/Dashboard.aspx?ParcelNbr= {SITE_APN}","False","",""]},"i":1,"cell":"","2","2","DesWithSlashAndURLwithSlash",
 "Sample\value2","http://Googole.com/Dashboard.aspx?ParcelNbr={SITE_APN}&ABC=\XYZ","False","",""]},{"i":2,"cell":["","3","3","DesWithAmpersand","Sample & value3"","http://Googole.com","False","",""]}]}

【问题讨论】:

  • 您能提供样品吗?
  • @Garath 在代码中添加了一个示例 JSON 构造
  • “我怎样才能成功解析这个”?在 JavaScript 中?该对象将被序列化为 json 就好了,并且可以在 js 中使用,无论如何你想要它。你到底在用它给你一个错误的 json 对象做什么?

标签: javascript asp.net-mvc json jqgrid


【解决方案1】:

对应于规范(参见herehere)仅"\ 字符必须转义。其他一些字符可以转义。所以未转义的' 字符不是错误。我认为错误“无效的 JSON 解析器错误”还有另一个原因。

您应该包含更多显示您如何使用 jqGrid 的完整 JavaScript 代码、ASP.NET MVC 控制器操作的代码或更完整的返回服务器的 JSON 响应。一般来说,您可以在不使用 Json.NET (Newtosoft) 或使用它或任何其他库的情况下生成正确的 JSON 响应。

您应该包含autoencode: true 选项以在jqGrid 中正确显示任何文本数据。您应该使用datatype: "json"jsonReader 选项(请参阅the documentation)。因此,仅仅生成格式良好的 JSON 或 XML 数据以在 jqGrid 中正确显示数据是不够的。可能需要包含 jqGrid 选项,该选项提供有关数据确切格式的信息。

已更新:您发布的 JSON 数据确实已损坏。 jsonlint.org 是一个可以验证 JSON 数据的好地方。可能您尝试手动生成 JSON 数据,因为数据绝对错误:

{
    "total": 1,
    "page": 1,
    "records": 3,
    "rows": [
        {
            "i": 0,
            "cell": "", <---- it must be "cell": [""
            "1",
            "1",
            "DesSinglApostropAndURLhasEnterKeyChar",
            "Samp'le value",
            "http://google.com/Dashboard.aspx?ParcelNbr= {SITE_APN}",
            "False",
            "",
            ""
        ]
    },
    "i": 1, <--- it must be {"i": 1
    "cell": "",
    "2",
    "2",
    "DesWithSlashAndURLwithSlash",
    "Sample\value2",  <--- it must be "Sample\\value2" or "Sample value2"
    "http://Googole.com/Dashboard.aspx?ParcelNbr={SITE_APN}&ABC=\XYZ", <--- \XYZ is WRONG
    "False",
    "",
    ""
]
},
{
"i": 2,
"cell": [
    "",
    "3",
    "3",
    "DesWithAmpersand",
    "Sample & value3"","http: //Googole.com","False","",""]}]} <-- "Sample & value3"" is WRONG

数据包含5个语法错误:

  • 使用"cell": "" 而不是"cell": [""
  • 使用}, "i": 1, 而不是}, {"i": 1,
  • 使用"Sample\value2" 而不是"Sample value2""Sample\\value2"
  • 使用"http://Googole.com/Dashboard.aspx?ParcelNbr={SITE_APN}&amp;ABC=\XYZ" 而不是"http://Googole.com/Dashboard.aspx?ParcelNbr={SITE_APN}&amp;ABC=XYZ""http://Googole.com/Dashboard.aspx?ParcelNbr={SITE_APN}&amp;ABC=\\XYZ"
  • 使用"Sample &amp; value3"" 而不是"Sample &amp; value3""Sample &amp; value3\""

此外,您使用了i 属性而不是id"i": 1 必须固定为"id": 1)。这不是 JSON 中的错误,但您应该为 jqGrid 生成数据,因此您应该保持 jqGrid 预期的格式。见the documentation。固定的 JSON 响应应该类似于

{
    "total": 1,
    "page": 1,
    "records": 3,
    "rows": [
        {
            "id": 0,
            "cell": [
                "",
                "1",
                "1",
                "DesSinglApostropAndURLhasEnterKeyChar",
                "Samp'le value",
                "http://google.com/Dashboard.aspx?ParcelNbr= {SITE_APN}",
                "False",
                "",
                ""
            ]
        },
        {
            "id": 1,
            "cell": [
                "",
                "2",
                "2",
                "DesWithSlashAndURLwithSlash",
                "Sample value2",
                "http://Googole.com/Dashboard.aspx?ParcelNbr={SITE_APN}&ABC=XYZ",
                "False",
                "",
                ""
            ]
        },
        {
            "id": 2,
            "cell": [
                "",
                "3",
                "3",
                "DesWithAmpersand",
                "Sample & value3",
                "http: //Googole.com",
                "False",
                "",
                ""
            ]
        }
    ]
}

我建议您使用 jqGrid 分析使用 ASP.NET MVC 的示例代码(例如参见 here)并修复您的服务器代码。

【讨论】:

  • 感谢伟大的奥列格!如果我无法解决,我会再次查看我的代码并回复您。
  • @Billa:您发布的 JSON 数据完全错误。你永远不应该对 JSON 进行手动序列化。有关详细信息,请参阅我的答案的已更新部分。
猜你喜欢
  • 1970-01-01
  • 2019-04-02
  • 2016-09-10
  • 1970-01-01
  • 2021-04-30
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多