asp.net-mvc – MVC3 – 将字节数组发布到控制器 – Database Ro
我正在开发一个MVC3应用程序。我的客户端ViewModel包含一个SQL Server RowVersion属性,它是一个byte []。它在客户端被渲染为一个Object数组。当我尝试将视图模型发布到控制器时,RowVersion属性始终为空。
我假设Controller serializer(JsonValueProviderFactory)忽略了Object array属性。 我看过这个博客,但是这并不适用,因为我发布JSON而不是表单标记: 我的观点使我的观点模式如此: <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 ); } } 解决方法
使它不是一个字节[],您的视图模型包含一个字符串属性,这是该字节[]的base64表示。然后,您将不会有任何问题向客户端转发并返回到您将能够从Base64字符串获取原始字节[]的服务器。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- asp.net-mvc – 为什么我需要在asp.net mvc中部分视图的下划
- asp.net-mvc-3 – ASP.NET MVC 3/4是否有任何响应模板
- asp.net – HttpContext.Current不解析在MVC 4项目
- ASP.NET Core 认证与授权[7]:动态授权
- 在asp.net中找不到richtext框控件
- entity-framework – ASP.NET MVC 2.0在jqgrid中执行搜索
- 如何在ASP.Net内容页面中添加元标记
- asp.net-core – ASP.NET Core – Swashbuckle没有创建swag
- asp.net – 如何在.net核心框架中使用TransactionScope?我
- asp.net-mvc – 为什么没有参数的POST不返回JSON