我正在开发一个 MVC3 应用程序。我的客户端 ViewModel 包含一个 SQL Server RowVersion 属性,它是一个字节 []。它在客户端呈现为一个 Object 数组。当我尝试将我的 View 模型发布到 Controller 时,RowVersion 属性始终为空。
我假设 Controller 序列化程序 (JsonValueProviderFactory) 忽略了 Object 数组属性。
我看过这个博客,但这并不适用,因为我发布的是 JSON 而不是表单标记:
http://thedatafarm.com/blog/data-access/round-tripping-a-timestamp-field-with-ef4-1-code-first-and-mvc-3/
我的 View 像这样呈现我的 View 模型:
<script type="text/javascript">
var viewModel = @Html.Raw( Json.Encode( this.Model ) );
</script>
然后我将 viewModel 发布到 Controller ,如下所示:
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);
}
});
这是我在 Controller 中的操作:
[HttpPost]
public JsonResult Save(Contact contact) {
return this.Json( this._contactService.Save( contact ) );
}
更新:基于达林的回答。
我希望有一个更干净的解决方案,但由于 Darin 提供了唯一的答案,我将不得不添加一个自定义属性,将我的 byte[] "row_version"属性序列化为 Base64 字符串。当 Base64 字符串设置为新的自定义属性时,它会将字符串转换回 byte[]。下面是我添加到模型中的自定义“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[]
使它而不是
byte[]
您的 View 模型包含 string
属性是 base64此表示 byte[]
.然后,您将它往返于客户端并返回到服务器将不会有任何问题,您将能够在那里获得原始 byte[]
来自 Base64 字符串。
关于asp.net-mvc - MVC3 - 将字节数组发布到 Controller - 数据库 RowVersion,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6754551/