asp.net-mvc – MVC3 – 将字节数组发布到控制器 – Database RowVersion

前端之家收集整理的这篇文章主要介绍了asp.net-mvc – MVC3 – 将字节数组发布到控制器 – Database RowVersion前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在开发一个MVC3应用程序。我的客户端viewmodel包含一个sql Server RowVersion属性,它是一个byte []。它在客户端被渲染为一个Object数组。当我尝试将视图模型发布到控制器时,RowVersion属性始终为空。

我假设Controller serializer(JsonValueProviderFactory)忽略了Object array属性

我看过这个博客,但是这并不适用,因为我发布JSON而不是表单标记
http://thedatafarm.com/blog/data-access/round-tripping-a-timestamp-field-with-ef4-1-code-first-and-mvc-3/

我的观点使我的观点模式如此:

<script type="text/javascript">
  var viewmodel = @Html.Raw( Json.Encode( this.Model ) );
</script>

然后我将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);
        }
    });

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

[HttpPost]
  public JsonResult Save(Contact contact) {
     return this.Json( this._contactService.Save( contact ) );
  }

更新:基于达琳的答案。

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

public byte[] row_version {
     get;
     set;
  }

  public string RowVersion {
     get {

        if( this.row_version != null )
           return Convert.ToBase64String( this.row_version );

        return string.Empty;
     }
     set {

        if( string.IsNullOrEmpty( value ) )
           this.row_version = null;
        else
           this.row_version = Convert.FromBase64String( value );
     }
  }

解决方法

My client side viewmodel contains a sql Server RowVersion property,which is a byte[]

使它不是一个字节[],您的视图模型包含一个字符串属性,这是该字节[]的base64表示。然后,您将不会有任何问题向客户端转发并返回到您将能够从Base64字符串获取原始字节[]的服务器。

猜你在找的asp.Net相关文章