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/

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

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

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

  1. var data = {
  2. 'contact': viewmodel
  3. };
  4.  
  5. $.ajax({
  6. type: 'POST',url: '/Contact/Save',contentType: "application/json; charset=utf-8",data: JSON.stringify(data),dataType: 'json',success: function (data) {
  7. // Success
  8. },error: function (XMLHttpRequest,textStatus,errorThrown) {
  9. alert(XMLHttpRequest.responseText);
  10. }
  11. });

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

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

更新:基于达琳的答案。

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

  1. public byte[] row_version {
  2. get;
  3. set;
  4. }
  5.  
  6. public string RowVersion {
  7. get {
  8.  
  9. if( this.row_version != null )
  10. return Convert.ToBase64String( this.row_version );
  11.  
  12. return string.Empty;
  13. }
  14. set {
  15.  
  16. if( string.IsNullOrEmpty( value ) )
  17. this.row_version = null;
  18. else
  19. this.row_version = Convert.FromBase64String( value );
  20. }
  21. }

解决方法

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

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

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