Gar*_*ish 26 asp.net-mvc serialization byte rowversion razor
我正在研究MVC3应用程序.我的客户端ViewModel包含一个SQL Server RowVersion属性,它是一个byte [].它在客户端呈现为Object数组.当我尝试将我的视图模型发布到控制器时,RowVersion属性始终为null.
我假设Controller序列化程序(JsonValueProviderFactory)忽略了Object数组属性.
我看过这个博客,但这不适用,因为我发布的是JSON而不是表单标记:http: //thedatafarm.com/blog/data-access/round-tripping-a-timestamp-field-with-ef4 -1-代码先和-MVC-3 /
我的视图呈现我的viewmodel:
<script type="text/javascript">
var viewModel = @Html.Raw( Json.Encode( this.Model ) );
</script>
Run Code Online (Sandbox Code Playgroud)
然后我将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);
}
});
Run Code Online (Sandbox Code Playgroud)
这是我在控制器中的动作:
[HttpPost]
public JsonResult Save(Contact contact) {
return this.Json( this._contactService.Save( contact ) );
}
Run Code Online (Sandbox Code Playgroud)
更新:基于达林的答案.
我希望有一个更清晰的解决方案,但由于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 );
}
}
Run Code Online (Sandbox Code Playgroud)
Dar*_*rov 38
我的客户端ViewModel包含一个SQL Server RowVersion属性,它是一个byte []
这样做是为了代替byte[]
您的视图模型包含一个string
属性,该属性是this64的base64表示byte[]
.然后,您将没有任何问题将其转发到客户端并返回到服务器,在那里您将能够byte[]
从Base64字符串中获取原始数据.
归档时间: |
|
查看次数: |
14305 次 |
最近记录: |