为什么Spring @Value与@Controller不兼容?

Old*_*Pro 4 java spring annotations aspectj load-time-weaving

我正在寻找一个更好地理解这个问题.解决方法非常简单,即将配置数据移动到另一个没有包含代理/建议的类,但我认为更好地理解它将帮助我避免将来出现其他相关问题,所以我想要任何解释任何人可以提供.

我正在使用Spring 3.1.0.RELEASE与Spring STS和vFabric tc服务器.使用@Controller类实现了一个基本的小型REST服务器.这是所有伟大的(实际上,它是),但@Controller也@Transactional,并且和负载时编织和TC的vFabric服务器之间,它打破@Value.

@Controller
@RequestMapping("/hello")
public class MyAPI {

    @Value("${my.property}")
    private String prop;
    ...

    @Transactional
    handleRequest(...) ...


}
Run Code Online (Sandbox Code Playgroud)

和属性文件app.properties:

my.property = SUCCESS
Run Code Online (Sandbox Code Playgroud)

这在JUnit下工作正常,测试得到一个支持设置为"SUCCESS"的MyAPI对象.但是当应用程序加载到vFabric中时,我猜它会加载时间编织和代理.无论发生什么事情,有创造了两个MyAPI情况下,一个拥有道具=="成功"和另一个(这是很不幸的是处理HTTP请求中的一个),其中有托=="$ {} my.prop".

总而言之,我称之为魔术的失败,这是我使用像AOP这样的东西最大的担忧.即使使用STS,我也不知道如何找出问题背后的原因,或者弄清楚这是否是一个严重的错误.如果它是一个bug,我不知道它是Spring,AspectJ,加载时织入器还是vFabric中的bug,所以我甚至不知道在哪里提交bug报告.

因此,理解这一点的任何帮助将不胜感激.谢谢.

Old*_*Pro 6

我想到了.确实,这太神奇了.

我在STS中使用Spring Roo来生成基本的应用程序框架,然后使用STS将Roo考虑在内,因为我们不想坚持使用它.

Roo作为"最佳实践"做的一件事是创建两个Spring上下文,一个用于整个应用程序,一个仅限于调度程序servlet.究竟为什么,我仍然没有得到,但我想他们希望保持表示层的东西,如控制器,爬进共享的服务层.axtavt 在这里很好地解释了这一点.这一切都被STS隐藏了.

在使用Roo的STS中,WEB-INF源不是我所期望的,在/ src/main/resources下(这是META-INF目录所在的位置),而是在/ src/main/webapp下,这不是Java源目录,因此完全单独显示,在/ target目录上方,所以我把它误认为是输出文件夹.

在applicationContext.xml中,Roo已插入过滤器以防止应用程序上下文构造控制器,如axtavt的帖子中所述,但它还放入了另一个过滤器以消除扫描Roo生成的类.我同时把两个滤镜都拿出去了,不是真的知道他们在那里是什么,而是认为他们只是Roo剩饭.

所以现在我已经解决了控制器被创建两次的问题,如前所述.应用程序上下文中的一个获取分配的属性,因为它使用applicationContext.xml并查找属性文件.但为什么他们都没有获得属性设置?

这让我回到了模糊的webapps文件夹.在WEB-INF文件夹中,Roo放置了web.xml(自然地)和包含webmvc-config.xml文件的spring文件夹.此配置文件设置为仅扫描,创建和设置控制器.web.xml文件设置Web应用程序以使用applicationContext.xml和dispatcherServlet来使用webmvc-config.xml,因此我应该在applicationContext.xml中保留过滤器以避免双重创建.

最后一个难题是这个webmvc-config.xml文件.自认为是其中的控制器设置地图的背景下,有<背景:物业占位符/>需要配置文件,以及使之能找到的属性文件.