繁体   English   中英

如何使用带有WebMatrix环境的C#.net Web-Pages中的AJAX在服务器端传递和访问对象数组?

[英]How can I pass and access an array of objects on the server-side using AJAX in the C#.net Web-Pages with WebMatrix environment?

首先,我已经尝试过自己找到这个答案。 我在这个主题上发现了几页:

http://forums.asp.net/t/1934999.aspx?Convert+any+json+string+to+an+array+or+object+in+c+ (这个使用JSON字符串,所有,但它是一个对象而不是一个对象数组,因此它似乎不适用于此)。

将json转换为C#数组? (这里,它似乎有相关的答案,但它们都没有帮助我[可能是因为我没有在服务器端正确处理这个])。

现在,我在jQuery中有以下简单的$.ajax请求:

$("#savePageBtn").click(function () {
    $.ajax({
        url: "/AJAX Pages/Compute_Save_Edit_Page.cshtml",
        async: false,
        type: "POST",
        data: { "objectArr": jsonArr }, //more on exactly what jsonArr contains below...
        success: function (response) {
            console.log(response);
        },
        error: function (jqXHR, textStatus, error) {
            alert("Oops! It appears there has been an AJAX error.\n\nPlease check the page you were attempting to edit.\n\n Error: " + textStatus + ".\n\nError Type: " + error + ".");
        }
    });
});

我也试过: data: JSON.stringify(jsonArr),用于数据行,但是当我尝试访问给定对象的属性时,它们都给出了代码500的内部服务器错误。 阅读这些错误,我可以看出数据是“字符串”格式(使用JSON语法,我确定)所以我无法按照我的意愿访问数据。 甚至在我尝试使用C#的Json.Decode方法之后。

这是我到目前为止的服务器端代码(Compute_Save_Edit_Page.cshtml):

@{
    Layout = "";

    if (IsAjax)
    {
        var reader = new StreamReader(Request.InputStream);
        var json = reader.ReadToEnd();
        var objectArr = Json.Decode(json);

        for (var i = 0; i < objectArr.Length; i++)
        {
<!--      -->@:@objectArr[i].objectName;
<!--      --><br/>
        }
    }
    else
    {
        Context.RedirectLocal("~/");
    }
}

我想我知道我需要什么,但我似乎无法将JSON字符串转换回对象数组,就像我想要的那样。

在jQuery中,我一直在访问它,就像你期望的那样。 例如,要在第一个索引处获取对象的对象名,我将键入: jsonArr[0].objectName

一旦我在服务器端拥有它,我希望能够以相同的方式访问它,但我尝试的任何工作都没有。

附加信息:

值得一提的是,对象数组包含的对象并不都具有相同的属性(这就是为什么在我提供的第二个链接中尝试顶部答案不起作用,如果我甚至正确理解它的话)。

以下是对象数组中的一些对象的示例(没有真正的特定语法):

Object { 
    caption: "", 
    fileName: "Okmulgee_Library.jpg",
    objectID: "176",
    objectName: "Image",
    pageOrder: "1",
    size: "medium"
}

Object {
    alignment: "center",
    bold: false,
    italic: false,
    objectID: "177",
    objectName: "Paragraph",
    pageOrder: "2",
    underline: false,
    value: "For more information about the Okmulgee Public Library, call (918)-756-1448."
}

Object {
    bold: false,
    italic: false,
    objectID: "179",
    objectName: "Text",
    pageOrder: "3",
    underline: false,
    value: "Or visit their website at"
}

来自CHROME网络的更新>标题

Request URL:http://localhost:10226/AJAX%20Pages/Compute_Save_Edit_Page.cshtml
Request Method:POST
Status Code:500 Internal Server Error
Request Headersview source
Accept:application/json, text/javascript, */*; q=0.01
Accept-Encoding:gzip,deflate,sdch
Accept-Language:en-US,en;q=0.8
Connection:keep-alive
Content-Length:0
Cookie:.ASPXAUTH=AEBDE22DCB622D796F8897945434328CECAEB25BF5D24CBA9CB1C32A58D82BC5CF68F33EF2CA7012DECFE87F91C39E7471DE7C2903CE476DF8781E0B0CE862C8AF10A23CD1B52BDFBA9042290426BBD024663A2D95C02A54EBA9E98D3DE25A44415395F5CDAA1E65A0EDDC3D9598F2A7660E3376159D82986E3E4EFEB05F150D02DC788D8F0FC0D62FF8B80708D05A276789A3D54DC79F598D57D19990426F68
Host:localhost:10226
Origin:http://localhost:10226
Referer:http://localhost:10226/CMS%20Interface/EditPages/E-UtilityBilling.cshtml
User-Agent:Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/30.0.1599.101 Safari/537.36
X-Requested-With:XMLHttpRequest
Response Headersview source
Cache-Control:private
Content-Length:5732
Content-Type:text/html; charset=utf-8
Date:Fri, 25 Oct 2013 19:00:34 GMT
Server:Microsoft-IIS/7.5
X-AspNet-Version:4.0.30319
X-Powered-By:ASP.NET
X-SourceFiles:=?UTF-8?B?QzpcVXNlcnNcY3JhZGViYXVnaFxEb2N1bWVudHNcTXkgV2ViIFNpdGVzXE9rbXVsZ2VlIE9ubGluZSA0LjBcQUpBWCBQYWdlc1xDb21wdXRlX1NhdmVfRWRpdF9QYWdlLmNzaHRtbA==?=

我想你会在Request.InputStream找到你的数据。 请尝试以下方法:

var reader = new StreamReader(Request.InputStream);
var json = reader.ReadToEnd();
var objArray= Json.Decode(json);

您需要首先使用JSON.stringify将Javascript对象转换为JSON:

 data: JSON.stringify(jsonArr),

好吧,我想我终于明白了。

我决定尝试以前尝试过发布这个问题的东西:AJAX调用中的JSON.stringify (显然jQuery不会根据contentType自动格式化数据,也不会简单地检测它的数据类型)。

之前的问题是我不知道我能用Request.InputStream在服务器端找到我的数据。 事实上,我仍然不清楚为什么或何时可以以这种方式找到数据,甚至是什么决定它应该存储在那里,而不是可以被Request.Form["objectArr"]调用的东西。等

所以,当我这次尝试使用JSON.stringify时,我将其与Mike在答案中发布的内容结合起来,以了解如何检索此服务器端(即使用Request.InputStream方法)。

一旦我使用了两者(以及删除data:的标识符data: ajax调用的一部分),我开始看到甚至返回相关数据。

简而言之,这就是我现在所拥有的......

jQuery AJAX代码:

$.ajax({
    url: "/AJAX Pages/Compute_Save_Edit_Page.cshtml",
    async: false,
    type: "POST",
    data: JSON.stringify(jsonArr),
    success: function (response) {
        console.log(response);
    },
    error: function (jqXHR, textStatus, error) {
        alert("Oops! It appears there has been an AJAX error.\n\nPlease check the page you were attempting to edit.\n\nError Type: " + error + ".");
    }
});

这里是服务器端(C#)代码,它只返回数组中每个对象的两个属性:

@{
   Layout = "";

    if (IsAjax)
    {
        var reader = new StreamReader(Request.InputStream);
        var json = reader.ReadToEnd();
        var objectArr = Json.Decode(json);

        for (var i = 0; i < objectArr.Length; i++)
        {
@:@objectArr[i].objectName - @objectArr[i].objectID
        }
    }
    else
    {
        Context.RedirectLocal("~/");
    }
}

所以,如果我理解正确(并且如果我错了纠正我),你不能只用AJAX向服务器发送一个对象数组。 事实上,如果你根本不能发送阵列,我也不会感到惊讶。 但你可以发送一个简单的变量像stringint 所以,使用JSON.stringify ,我使用的函数将对象数组转换为一个大的JSON字符串,用C#读取另一端的输入流,然后使用另一个C#方法将JSON字符串解析回一个数组对象,这就是我想要的数据。

感谢所有帮助我完成这一切的人,以及它的价值,我真的觉得我甚至在今天的网络环境中学到了一些关于JSON的目的。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM