我正在努力让Web API与POST一起工作,我的控制器中有以下内容:
public class mainGridController : ApiController
{
public class formData
{
public string module { get; set; }
public string group { get; set; }
public string staff { get; set; }
}
public HttpResponseMessage Post([FromBody] formData data)
{
string string_group = "";
string string_staff = "";
if (data.group != null)
{
但我似乎在“if”语句中为data.group获取“对象引用没有设置为对象的实例”。
这是我的路线信息:
protected void Application_Start(object sender, EventArgs e)
{
GlobalConfiguration.Configuration.Routes.MapHttpRoute(
name: "DefaultApi",
routeTemplate: "api/{controller}/{data}",
defaults: new { module = System.Web.Http.RouteParameter.Optional, data = System.Web.Http.RouteParameter.Optional}
);
}
有谁知道造成这种情况的原因是什么?我试图使用jQuery发布。
这是我的jQuery代码:
var url = "api/mainGrid";
var source = {
datatype: 'json',
contentType: 'application/json; charset=utf-8',
url: url,
processData: false,
type: "POST",
id: "SEQUENCE",
root: 'rowsinfo',
cache: false,
columns: [],
datafields: [],
beforeprocessing: function (data) {
var columnsdata = new Array();
var datafieldsdata = new Array();
for (k in data.columnsinfo) {
var col = {};
col.text = data.columnsinfo[k]["DISPLAYNAME"];
col.datafield = data.columnsinfo[k]["DISPLAYNAME"];
var datafields = {};
datafields.name = data.columnsinfo[k]["DISPLAYNAME"];
columnsdata.push(col);
datafieldsdata.push(datafields);
source.columns = columnsdata;
source.datafields = datafieldsdata;
}
$("#jqxgrid").jqxGrid({ columns: source.columns });
},
data: {
group: JSON.stringify(checkedGroups),
staff: JSON.stringify(checkedStaff),
module: selectedModuleSEQ
}
};
由于
答案 0 :(得分:4)
问题是您已将dataType
参数指定为json
,但您传递的是JS 对象 - 当然这不是JSON。
您需要将data
对象转换为实际的JSON才能使其正常工作
data: JSON.stringify({
group: JSON.stringify(checkedGroups),
staff: JSON.stringify(checkedStaff),
module: JSON.stringify(selectedModuleSEQ)
}),