我们如何将Struts 2与Tiles 3集成? struts2-tiles-plugin目前(2.3.4.1)适用于旧版本的磁贴(版本2.0.6),这可能有点令人讨厌。
这是一个自我回答,帮助其他人进行整合。
答案 0 :(得分:8)
解决方案是添加所需的依赖项,使用适当的侦听器加载切片并创建自定义结果类型。幸运的是,这些步骤非常简单,一旦完成,您可以按照常规图块2示例来了解如何定义模板。
1)依赖关系(从基本的struts项目开始,但在本例中我将使用约定,因此最好添加struts2-conventions-plugin,它将包括struts2-core等):
注意:更高版本的slf4j依赖项可能工作我还没有测试过。
2)使用适当的侦听器加载图块
此示例包含完整的web.xml,对于熟悉struts2的人来说,第3-5行是唯一应该是新手。
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
<listener>
<listener-class>org.apache.tiles.extras.complete.CompleteAutoloadTilesListener</listener-class>
</listener>
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
3)创建自定义结果类型
我们需要定义一个自定义结果类型以用于我们的操作:
package com.quaternion.result;
import com.opensymphony.xwork2.ActionInvocation;
import javax.servlet.ServletContext;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts2.ServletActionContext;
import org.apache.struts2.dispatcher.ServletDispatcherResult;
import org.apache.tiles.TilesContainer;
import org.apache.tiles.access.TilesAccess;
import org.apache.tiles.request.ApplicationContext;
import org.apache.tiles.request.servlet.ServletRequest;
import org.apache.tiles.request.servlet.ServletUtil;
public class TilesResult extends ServletDispatcherResult {
public TilesResult() {
super();
}
public TilesResult(String location) {
super(location);
}
@Override
public void doExecute(String location, ActionInvocation invocation) throws Exception {
//location = "test.definition"; //for test
setLocation(location);
ServletContext context = ServletActionContext.getServletContext();
ApplicationContext applicationContext = ServletUtil.getApplicationContext(context);
TilesContainer container = TilesAccess.getContainer(applicationContext);
HttpServletRequest request = ServletActionContext.getRequest();
HttpServletResponse response = ServletActionContext.getResponse();
ServletRequest servletRequest = new ServletRequest(applicationContext, request, response);
container.render(location, servletRequest);
}
}
4)我们还需要告诉struts2我们的结果类型:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<constant name="struts.devMode" value="true" />
<constant name="struts.ui.theme" value="simple" />
<package name="tiles-package" namespace="" extends="struts-default">
<result-types>
<result-type default="true" name="tiles-result" class="com.quaternion.result.TilesResult"/>
</result-types>
</package>
</struts>
我们现在可以在项目中使用tile,假设我们已经创建了一个名为“test.definition”的tile定义,我们可以通过执行以下操作告诉我们使用该定义的操作:
package com.quaternion.demo.action.test;
import com.opensymphony.xwork2.ActionSupport;
import org.apache.struts2.convention.annotation.ParentPackage;
import org.apache.struts2.convention.annotation.Result;
@ParentPackage("tiles-package")
@Result(type="tiles-result", location="test.definition")
public class QuaternionResultTest extends ActionSupport{}
就是这样,这将允许您使用tile 3+配置任何版本的struts2,请参阅http://tiles.apache.org/framework/index.html以获取更多配置详细信息。
答案 1 :(得分:5)
感谢Ken在Struts 2中添加了一个新的插件以支持Tiles 3结果类型,它应该可用于即将发布的新版本 - Struts 2.3.9
https://cwiki.apache.org/confluence/display/WW/Tiles+3+Plugin
答案 2 :(得分:0)
<!DOCTYPE tiles-definitions PUBLIC "-//Apache Software Foundation//DTD Tiles Configuration 3.0//EN" "http://tiles.apache.org/dtds/tiles-config_3_0.dtd">
在tiles.xml中使用提到的doctype