小编Gar*_*ish的帖子

MVC3 - 将字节数组发布到控制器 - Database RowVersion

我正在研究MVC3应用程序.我的客户端ViewModel包含一个SQL Server RowVersion属性,它是一个byte [].它在客户端呈现为Object数组.当我尝试将我的视图模型发布到控制器时,RowVersion属性始终为null.

我假设Controller序列化程序(JsonValueProviderFactory)忽略了Object数组属性.

我看过这个博客,但这不适用,因为我发布的是JSON而不是表单标记:http: //thedatafarm.com/blog/data-access/round-tripping-a-timestamp-field-with-ef4 -1-代码先和-MVC-3 /

我的视图呈现我的viewmodel:

<script type="text/javascript">
  var viewModel = @Html.Raw( Json.Encode( this.Model ) );
</script>
Run Code Online (Sandbox Code Playgroud)

然后我将viewModel发布到控制器,如下所示:

    var data = {
        'contact': viewModel
    };

    $.ajax({
        type: 'POST',
        url: '/Contact/Save',
        contentType: "application/json; charset=utf-8",
        data: JSON.stringify(data),
        dataType: 'json',
        success: function (data) {
            // Success
        },
        error: function (XMLHttpRequest, textStatus, errorThrown) {
            alert(XMLHttpRequest.responseText);
        }
    });
Run Code Online (Sandbox Code Playgroud)

这是我在控制器中的动作:

  [HttpPost]
  public JsonResult Save(Contact contact) {
     return this.Json( this._contactService.Save( contact ) );
  }
Run Code Online (Sandbox Code Playgroud)

更新:基于达林的答案.

我希望有一个更清晰的解决方案,但由于Darin提供了唯一的答案,我将不得不添加一个自定义属性,将我的byte []"row_version"属性序列化为Base64字符串.当Base64字符串设置为新的自定义属性时,它会将字符串转换回byte [].下面是我添加到模型中的自定义"RowVersion"属性:

  public byte[] …
Run Code Online (Sandbox Code Playgroud)

asp.net-mvc serialization byte rowversion razor

26
推荐指数
1
解决办法
1万
查看次数

标签 统计

asp.net-mvc ×1

byte ×1

razor ×1

rowversion ×1

serialization ×1