2

我是 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

4

1 回答 1

3

发现了问题。留下这篇文章以防其他人遇到问题。我错过了配置文件中设置 InternalResourceViewResolver 的更高配置。不幸的是,Spring 只能处理链中的一个 UrlViewResolver 或 InternalResourceViewResolver。在没有指定顺序首选项的情况下,Spring 尝试使用 InternalResourceViewResolver (JstlView) 并完全跳过 Tiles 视图解析器。

删除了另一个视图解析器,并且所有工作都按预期工作。

于 2013-10-25T18:35:48.173 回答