我正在开发一个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 );
- }
- }