您的位置:首页 > 其它

基于Web Service的客户端框架搭建二:数据转换层(FCL)

2014-08-14 09:51 441 查看

引言

  要使用WebService来分离客户端与服务端,必定要使用约定好两者之间的数据契约。Json数据以其完全独立于语言的优势,成为开发者的首选。C# JavaScriptSerializer为Json与Object对象之间的序列化与反序列化提供了良好的方法。

接口设计

  数据转换包含Json反序列化成Object对象和Object序列化成Json数据。在项目中,会有很多实例对象,都需要使用Serialize和Deserialize方法来实现数据转换,我们可以抽象出一个接口IDFC(数据格式转换接口)。因为我们不确定每次从服务端获取的数据对象是单个Object还是List<Object>,因此约定WebService返回的Json字符串中被序列化的对象是List<Object>,客户端Post到WebService的参数也是将List<Object>序列化成Json字符串之后值。

  接口设计如下:

namespace ProjectmsMGT_FCL
{
public interface IDFC
{
string Object2Json(List<Object> models);

List<Object> Json2Object(string json);
}
}


接口实现

  在项目中,我们会设计很多的Model类,User、Order、Product、Project、Stock等等,那么针对项目的实际需求,我们可以针对不同对象实现接口IDFC。

  如下是两个对象的实现类:

namespace ProjectmsMGT_FCL
{
public class DFC_Project : IDFC
{
public static JavaScriptSerializer js = new JavaScriptSerializer();

#region IDFC 成员

public string Object2Json(List<Object> models)
{
return js.Serialize(models);
}

public List<Object> Json2Object(string json)
{
List<Project> objs = js.Deserialize<List<Project>>(json);

List<Object> list = new List<object>();
foreach (var item in objs)
{
list.Add(item);
}
return list;
}

#endregion
}
}


namespace ProjectmsMGT_FCL
{
public class DFC_User : IDFC
{
public static JavaScriptSerializer js = new JavaScriptSerializer();

#region IDFC 成员

public string Object2Json(List<object> models)
{
return js.Serialize(models);
}

public List<object> Json2Object(string json)
{
List<User> objs = js.Deserialize<List<User>>(json);

List<Object> list = new List<object>();
foreach (var item in objs)
{
list.Add(item);
}
return list;
}

#endregion
}
}


总结

  数据转换层的设计相对简单,数据转换层的主要工作是实现Json与数据对象之间的序列化与反序列化。为代理层Proxy提供辅助服务,在调用Web Service代理方法之前,将数据对象参数序列化成Json字符串,在调用之后,将Web Service返回的Json字符串反序列化成数据对象,这整个流程在功能分发层Dispatcher完成。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐