$ .post总是将空值获取到服务器中

时间:2017-06-16 13:49:16

标签: javascript c# jquery arrays asp.net-mvc

好的,这可能很简单,我有一个简单的$ .post调用服务器发送字符串数组作为参数..

 $.get('/home/ReadCalPacTagValue', data, function (data) {
            data = $.parseJSON(data);
            if (data.length != 0) {
                var ReadFromDb = data[0]["PushToDb"].replace('PushToDb','ReadFromDb');
                var DBAckno = ReadFromDb.replace('ReadFromDb', 'DataAck');
                var FIdTag = ReadFromDb.replace('ReadFromDb', 'FluidTypeId');
                var UserIdTag = ReadFromDb.replace('ReadFromDb', 'UserId');
                var UniqueIdTag = ReadFromDb.replace('ReadFromDb', 'UniqueRecordId');
                var dbconnTag = ReadFromDb.replace('ReadFromDb', 'DatabaseConnectionString');
                updateTags = [dbconnTag,FIdTag,ReadFromDb, UserIdTag,UniqueIdTag];
                actionvalue = ["", fluidtypeid, '1', userid, uniqueID];
                var data_Tags = { updateTags: updateTags, actionvalue: actionvalue }
                $.post('/home/WriteCalPacTagValue', data_Tags, function (response) {
                    //var Path = "Config/16_CalPac/" + FluidType + "/" + metername + "/" + FileName
                    //$.cookie('FileName', FileName, { expires: 7, path: '/' });
                    //$.cookie('FilePath', Path, { expires: 7, path: '/' });
                    //$.cookie('ModuleName', "CalPac", { expires: 7, path: '/' });
                    //window.open('../home/CalPac', '_blank');
                });
            } else {
                    swal("Error !", "Data operation tag not binded for this product", "warning");
            }
        })

我的问题是,每次进行$ .post调用时,服务器都会获得null值的参数...

 public void WriteCalPacTagValue(string[] updateTags, string[] actionValue)
        {
            string[] writetags = { };
            DanpacUIRepository objNewTag = new DanpacUIRepository();

            if (updateTags.Count() > 0)
            {
                actionValue[0] = ConfigurationManager.AppSettings["DBString"].ToString();
                for (int i = 0; i < updateTags.Count(); i++)
                {

                    writetags = updateTags[i].Replace("&lt;", "").Replace("&gt;", ">").Split('>');
                    objNewTag.WriteTag(writetags, actionValue[i]);
                }

            }
        }

我没有得到我在这里做错了什么..而同样的功能是从另一个JS文件中使用一些不同的字符串到数组updateTags。

任何帮助?

1 个答案:

答案 0 :(得分:1)

具有

public class DataTags
{
    public string[] UpdateTags { get; set; }
    public string[] ActionValue { get; set; }
}

在服务器上:将方法更改为此

[HttpPost()]
public void WriteCalPacTagValue([FromBody]DataTags data_Tags)
{

}

在客户端:将其称为

$.ajax({
    type: 'POST',
    url: '/home/WriteCalPacTagValue',
    data: data_Tags,
    success: function (response) { 
    //your code
    }
});

此外,您可以使用data: JSON.stringify(data_Tags)将整个数据作为json字符串发送,在javascript代码中更改WriteCalPacTagValue以接受参数中的单个字符串,并在服务器端的C#代码中对其进行反序列化。

编辑如果您无法更改服务器端代码,则可以按照评论中的说明关注this