我有一个关于从JQuery创建JSON的问题,通过Ajax将其发送到.NET中的Web服务,以及如何在.NET中反序列化并保存到数据库。
也许有人可以帮我看看我错在哪里!
var myObject = {};
//** BusinessPartner **
//function BusinessPartner(prefix) {
// this.bpCodigo = $(prefix + " option:selected").val();
// this.bpNombre = $(prefix + "-infonombre").text();
//
//** Locations **
//function Locations(prefix) {
// this.locCode = $(prefix + " option:selected").val();
// this.locName = $(prefix + "-name").text();
var oNewObject = new BusinessPartner("#bp-01");
var oNewObject2 = new BusinessPartner("#bp-02");
var myLocation = [];
var oOrigin = new Locations("#receipt");
myLocation.push(oOrigin);
var oDestination = new Locations("#portloading");
myLocation.push(oOrigin);
myObject["Agent1"] = oNewObject;
myObject["Agent2"] = oNewObject;
myObject["Locations"] = myLocation;
$.ajax({
type: "POST",
url: "Services/ActionsDb.asmx/saveData",
contentType: "application/json; charset=utf-8",
data: JSON.stringify(myObject),
datatype: "json",
success: function (response) {
// After correct save send OK message.
},
error: function (xhr, status) {
alert("An error occurred: " + status);
}
});
据我所知,它应该与Web服务收到的JSON格式完全相同。
public class Agent
{
public string bpCodigo { get; set; }
public string bpNombre { get; set; }
}
public class Location
{
public string locCode { get; set; }
public string locName { get; set; }
}
public class oGet
{
public Agent oCliente { get; set; }
public Agent oCliente2 { get; set; }
public List<Location> oLocations { get; set; }
}
好,现在要求将数据保存在数据库中的WebService ActionsDb.asmx / savedata。
[WebMethod(EnableSession = true)]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
public string saveData(oGet myObject)
{
try
{
string sClienteName = myObject.oCliente.bpNombre.ToString();
return sClienteName.ToString();
}
catch (System.Exception ex)
{
return ex.Message.ToString();
}
}
我得到的错误如下:
POST http://localhost:8869/Services/WebtoolActionsDb.asmx/saveBLData 500 (Internal Server Error)
{"Message":"Service call not valid. Parameter missing: \u0027myObject\u0027.","StackTrace":"
en System.Web.Script.Services.WebServiceMethodData.CallMethod(Object target, IDictionary`2 parameters)
en System.Web.Script.Services.WebServiceMethodData.CallMethodFromRawParams(Object target, IDictionary`2 parameters)
en System.Web.Script.Services.RestHandler.InvokeMethod(HttpContext context, WebServiceMethodData methodData, IDictionary`2 rawParams)
en System.Web.Script.Services.RestHandler.ExecuteWebServiceCall(HttpContext context, WebServiceMethodData methodData)","ExceptionType":"System.InvalidOperationException"}
答案 0 :(得分:1)
您的JavaScript存在两个问题。您收到500错误的原因是因为您发送的JSON需要有一个&#34; myObject&#34;与saveData
的参数对应的属性。您还需要更改&#34; Agent1&#34; to&#34; oCliente&#34;,&#34; Agent2&#34;到&#34; oCliente2&#34;和&#34;地点&#34; to&#34; oLocations&#34;为了匹配oGet
中的属性。
myObject.oCliente = oNewObject;
myObject.oCliente2 = oNewObject2;
myObject.oLocations = myLocation;
$.ajax({
// ...
data: JSON.stringify({ myObject: myObject }),
// ...
});