我正在使用带有DDD方法的Silverlight.我有一个Person域对象,它具有FirstName,LastName,Address等属性.Persice需要有一个Image.
处理这个问题的最佳方法是什么?
我真的不想在Person对象上放置一个Windows.Controls.Image属性,因为它将耦合到Silverlight/WPF,我可能希望将来使用此对象与其他技术(ASP,WinForms,下一件新事物等).
我还需要能够在某处保存并加载图像.将图像保存到数据库或文件系统是最佳做法吗?我目前正在使用nHibernate与Microsoft SQL Server,但我也希望能够支持nHibernate与mySql以及可能的其他一些数据库.我有可能有一天想用实体框架或其他技术替换nHibernate(我使用存储库将其抽象出来).
鉴于此信息,我应该如何为我的人处理图像?
好吧,byte[]
(或者包装一些东西byte[]
)是相当便携的......大多数其他东西都是特定于实现的.
Re database vs file ...出于客户端应用程序的目的(Silverlight,WPF等),我可能会通过网页而不是WCF(等)调用来公开它们 - 即一些ASP.NET处理程序(或ASP.NET) MVC路由)通过http调用返回图像.然后,客户端实际需要的只是图像的路径(/people/images/12345
或其他).
对于存储 - 要么通常很好......在SQL Server 2008中,您可以使用文件流类型同时执行这两项操作.将BLOB存储在数据库中的一个问题是增加了大小,但是一些(小)图像通常不会受到影响(除非您使用SQL Express并且具有上限数据库大小).但是使用数据库的优点是单个备份包含所有内容.
尽管如此:几乎我所做的每一个实现都使用了文件.