热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

WCF类型共享的最佳实践

在使用WCF服务时,经常会遇到同一个实体类型在不同服务中被生成为不同版本的问题。本文将介绍几种有效的类型共享方法,以解决这一常见问题。

在使用WCF服务的过程中,开发者可能会遇到这样一个问题:同一个实体类型在不同的服务中被Visual Studio生成为不同的版本。例如,Service1.User 和 Service2.User 虽然表示相同的实体,但在C#中被视为不同的类型,导致无法直接互换。手动属性赋值显然不是一个高效的方法,因此类型共享成为了解决这一问题的关键。

方法一:服务端和客户端共享数据契约程序集

这是最常用且最为人熟知的方法。将WCF的数据契约放在一个独立的类库中,服务端和客户端都引用这个程序集。在生成WCF代理时,选择重新使用引用程序集中的类型即可实现类型共享。

image

这种方法的缺点在于,它只适用于客户端和服务端位于同一Visual Studio解决方案中的情况。如果服务端和客户端不在同一个解决方案中,或者涉及第三方服务,则需要手动更新数据契约程序集,这无疑增加了维护的复杂性。

方法二:使用映射工具进行类型转换

虽然这不是严格意义上的类型共享,但通过使用如AutoMapper或EmitMapper等映射工具,可以快速实现不同类型之间的转换。下面是一个具体的例子:

假设有一个Money类型,包含User实体、Currency枚举和一个数字的Amount。Money类型的定义如下:

[DataContract(Namespace = Consts.Namespace)]
public class Money
{
[DataMember]
public decimal Amount { get; set; }
[DataMember]
public Currency Currency { get; set; }
[DataMember]
public UserInfo User { get; set; }
}

Currency枚举的定义:

[DataContract(Namespace = Consts.Namespace)]
public enum Currency
{
[EnumMember] Euro,
[EnumMember] Usd,
[EnumMember] PoundSterling
}

UserInfo类的定义:

[DataContract(Namespace = Consts.Namespace)]
public class UserInfo
{
[DataMember]
public string FirstName { get; set; }
[DataMember]
public string LastName { get; set; }
[DataMember]
public string Email { get; set; }
[DataMember]
public string Phone { get; set; }
[DataMember]
public string Id { get; set; }
}

对于DepositServiceNoSharp和WithdrawalServiceNoSharp这两个WCF服务版本的Money和User,可以通过添加一些扩展方法来实现类型转换:

using AutoMapper;
using Client.DepositServiceNoSharp;
using Client.WithdrawalServiceNoSharp;
namespace Client
{
public static class Extensions
{
static Extensions()
{
Mapper.CreateMap();
Mapper.CreateMap();
Mapper.CreateMap();
Mapper.CreateMap();
}
public static Money ToWithdrawal(this DepositService.Money money)
{
return Mapper.Map(money);
}
public static DepositService.Money ToDeposit(this Money money)
{
return Mapper.Map(money);
}
}
}

这样,就可以轻松地进行类型转换:

var mOney= new Money
{
Amount = 1,
Currency = Currency.Usd,
User = new UserInfo
{
Email = "zhww@outlook.com",
FirstName = "zhang",
Id = "123",
LastName = "weiwen",
PhOne= "110"
}
};
var depositMOney= money.ToDeposit();

方法三:使用SvcMap实现类型共享

这种方法是本文的重点。首先,生成第一个WCF服务后,点击“显示所有文件”并编辑SvcMap文件:

image

在MetadataSources节点中,原本只有一个元数据源,现在需要将其他要引用的服务添加进来,例如:




然后右击服务,选择“更新服务引用”,所有服务将会生成到同一个命名空间中,从而实现类型共享。

总结

通过上述方法,可以有效地解决WCF服务中类型不一致的问题,提高开发效率和代码可维护性。感谢原作者的分享,希望这些方法能对大家有所帮助。

转载原文:http://www.cnblogs.com/lemontea/archive/2013/01/18/2865686.html

转:https://www.cnblogs.com/xwgli/p/3380132.html


推荐阅读
author-avatar
进出口产地
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有