我是 Tiles 的新手,并试图让 Tiles3 与 Spring MVC 3.2.4 一起工作。我以为我已经正确设置/配置了所有内容,但我根本没有显示任何内容。我尝试为 org.apache.tiles 启用 DEBUG 日志记录,但日志中根本没有显示磁贴。
我很困惑。我认为我的路径或配置一定有问题,但我不知道从哪里开始调试 Tiles 以确定它在寻找什么,或者为什么没有找到某些东西。我尝试在 TilesView 中的每个公共方法上设置断点,但是当我尝试访问页面时,没有任何东西被调用。
webmvc-config.xml:
<!-- Tiles page resolver -->
<bean id="viewResolver" class="org.springframework.web.servlet.view.tiles3.TilesViewResolver" >
<property name="viewClass" value="org.springframework.web.servlet.view.tiles3.TilesView" />
</bean>
<bean id="tilesConfigurer" class="org.springframework.web.servlet.view.tiles3.TilesConfigurer">
<property name="definitions">
<value>/WEB-INF/tiles.xml</value>
</property>
</bean>
/WEB-INF/tiles.xml:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE tiles-definitions PUBLIC "-//Apache Software Foundation//DTD Tiles Configuration 3.0//EN" "http://tiles.apache.org/dtds/tiles-config_3_0.dtd">
<tiles-definitions>
<definition name="secure/login" template="/WEB-INF/views/tiles/layouts/default.jsp">
<put-attribute name="body" value="/WEB-INF/views/tiles/secure/login/body.jsp"/>
</definition>
</tiles-definitions>
我可以确认文件 /WEB-INF/views/tiles/layouts/default.jsp 和 /WEB-INF/views/tiles/secure/login/body.jsp 存在。
我希望在日志输出中出现错误消息,或者至少是一些错误消息,这样我就可以开始弄清楚这一点,但我什么也没得到。我在输出日志中看到的唯一相关的瓷砖是:
2013-10-25 13:55:05,034 [localhost-startStop-1] INFO web.servlet.view.tiles3.TilesConfigurer - Found JSP 2.1 ExpressionFactory
2013-10-25 13:55:05,082 [localhost-startStop-1] INFO org.apache.tiles.access.TilesAccess - Publishing TilesContext for context: org.springframework.web.servlet.view.tiles3.SpringWildcardServletTilesApplicationContext
我从哪里/如何开始?
我应该补充一点,我目前已经成功地让应用程序与 Tiles2 一起工作,并且正在尝试升级到 Tiles3 但没有运气。
控制器看起来像:
安全控制器.java
@RequestMapping("/secure/**")
@Controller
public class SecureController {
@RequestMapping(value = "/login", method = RequestMethod.GET)
public String login(ModelMap model) {
return "secure/login";
}
}
我可以确认正在执行“return secure/login”语句。
log4j.xml:
<log4j:configuration xmlns:log4j='http://jakarta.apache.org/log4j/'>
<appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d{ISO8601} [%t] %-5p %c{5} - %m%n" />
</layout>
</appender>
<!-- Some other loggers here too -->
<!-- Apache Tiles -->
<logger name="org.apache.tiles">
<level value="TRACE" />
</logger>
<root>
<level value="INFO" />
<appender-ref ref="STDOUT" />
</root>
</log4j:configuration>
pom.xml 片段:
<!-- Apache Tiles -->
<dependency>
<groupId>org.apache.tiles</groupId>
<artifactId>tiles-extras</artifactId>
<version>3.0.1</version>
</dependency>
正在访问的 URL://localhost:8080/myapp/secure/login