一点一点学架构(四)—Spring.NET错误Cannot Resolve Type……

背景

  在搭建完项目框架之后,当我利用单元测试来测一条线时,出现了以下错误:

一点一点学架构(四)—Spring.NET错误Cannot Resolve Type……_第1张图片

  Cannot resolve type[……]for object with name ‘ButtonBll’ defined in config.

  看到问题描述之后首先去检查了自己配置文件中的配置:

            <!--B层实现注入-->
            <object id="ButtonBll" type="ITOO.UIQueryProperties.BLL.ButtonBll,ITOO.UIQueryProperties.BLL" singleton="false"/>

  仔细核对了类名,程序集名称,确定配置没有问题。
  这是哪里的问题呢?

原因分析

  这是最初版本的架构图

一点一点学架构(四)—Spring.NET错误Cannot Resolve Type……_第2张图片

  图中红色勾出来的地方是三个工厂,这里用到了设计模式中的抽象工厂+反射+配置文件。

  架构图演变
  去掉了三个工厂,取而代之的是Spring.NET中的IOC容器。我们知道,IOC容器就像是一个对象制造工厂。
  那么说这些有什么用呢?
  还记得在用抽象工厂+反射+配置文件时,有个经常出的错误吗?
  未能加载文件或程序集“DAL”或它的某一个依赖项。系统找不到指定文件。
  当时的解决方案是将DAL层的生成路径改到UI层的bin\Debug文件夹下。具体内容可参考《应用反射+配置文件+抽象工厂时出现的错误和原因分析 》
  所以,虽然这两次错误的提示不一样,但是根源还是一样的:没有把实现层类库的生成路径改到应用程序启动层。

解决

     一点一点学架构(四)—Spring.NET错误Cannot Resolve Type……_第3张图片

  这里需要我们把BLL层和DAL层的生成路径都改到 WCFService层的bin\Debug文件下。(如果要进行单元测试,单元测试层引用的dll文件都来自于WCFService层bin\Debug中的文件即可)

总结

  前后两次问题出现在不同的情景下,形式变了,但是道理没变。无论是学习还是解决问题,我们都应该学会举一反三。

你可能感兴趣的:(IOC,Spring-NET)