0

当我尝试从 javascript 访问 json 中的元素时,我遇到了这个奇怪的问题。我从这样的 url 中检索一个 json 字符串,

        // Create Request
        HttpWebRequest req = (HttpWebRequest)WebRequest.Create(@"www.someurl.com");

        // Create Client
        WebClient client = new WebClient();

        // Assign Credentials
        client.Credentials = new NetworkCredential("username", "pass");

        // Grab Data
        sjson = client.DownloadString(@"www.someurl.com");
        System.Web.Script.Serialization.JavaScriptSerializer oSerializer = new System.Web.Script.Serialization.JavaScriptSerializer();
        oSerializer.MaxJsonLength = Int32.MaxValue;
        sjson = oSerializer.Serialize(sjson);

但是当我在 html 代码中从 javascript 访问这个 sjson 变量时,它不会返回任何东西,但是如果我对其进行硬编码,它会返回值,请帮助解决这个问题。我尝试了很多东西,但没有奏效。我还尝试只传递检索到的 json 字符串而不进行序列化,当我这样做时,javascript 停止工作。:(以下是javascript代码,

    <script type="text/javascript">
    var jsons = JSON.parse('<%=sjson%>');


    function initialize() {
        alert("hahahahaaa");
        document.writeln(jsons.Body[0].RowId.SensorIdValue);
        //document.writeln(myobject.Body[0].RowId.SensorIdValue);
    }
    </script>

问题是

    document.writeln(myobject.Body[0].RowId.SensorIdValue); 

如果我使用 myobject 变量,则返回一个值,但是

    document.writeln(jsons.Body[0].RowId.SensorIdValue);

当我将它与解析值一起使用时,什么都不返回。:(

以下是我通过 c# 运行序列化程序后得到的 json 输出示例(response.write),

请帮我解决这个问题。我似乎在这里找不到问题。

编辑:

如果它有帮助,下面是我直接从服务器获得的 json 字符串,没有进行任何序列化,

由于所有者的要求,该问题的一些内容已被删除

4

2 回答 2

3

您所看到的是双重 JSON 序列化数据。您从远程服务器检索 JSON,然后使用 JavaScriptSerializer 对其进行第二次 JSON 编码。这是我在 ASMX ScriptServices 的上下文中写的一篇文章,其中更详细地解释了:http: //encosia.com/asp-net-web-services-mistake-manual-json-serialization/。您的情况并不完全相同,但最终结果是。

移除 JavaScriptSerializer 代码并返回您检索到的 JSON 字符串 ( sjson),而不是再次对其进行序列化。

于 2012-09-11T04:16:41.590 回答
0

您不需要使用 Json 序列化程序,因为远程服务器已经返回了一个 JSON 编码的字符串,您可以直接在页面中使用它并避免双重编码。

所以:

public string GetJson()
{
    // Create Client
    using (WebClient client = new WebClient())
    {
        // Assign Credentials
        client.Credentials = new NetworkCredential("username", "pass");

        // Grab Data
        return client.DownloadString(
            @"www.someurl.com"
        );
    }
}

进而:

<script type="text/javascript">
    var jsons = <%= GetJson() %>;
    function initialize() {
        alert("hahahahaaa");
        document.writeln(jsons.Body[0].RowId.SensorIdValue);
        //document.writeln(myobject.Body[0].RowId.SensorIdValue);
    }
</script>
于 2012-09-11T05:05:23.867 回答