Я бы очень неохотно пытался напрямую вызывать тег JSP вне контекста JSP. Как указывает документация , сходство между JSP и Facelets довольно поверхностно.
Одним из способов взлома (я подозреваю, что любое решение будет взломом) может быть включение JSP с помощью API сервлета.
Эта функция включает данный ресурс с использованием RequestDispatcher :
public class Includer {
public static String include(String resource) {
FacesContext context = FacesContext
.getCurrentInstance();
ExternalContext ext = context.getExternalContext();
include(ext.getContext(), ext.getRequest(), ext
.getResponse(), resource);
return "";
}
private static void include(Object context,
Object request, Object response, String resource) {
ServletContext servletContext = (ServletContext) context;
ServletRequest servletRequest = (ServletRequest) request;
ServletResponse servletResponse = (ServletResponse) response;
RequestDispatcher dispatcher = servletContext
.getRequestDispatcher(resource);
try {
dispatcher.include(servletRequest, servletResponse);
} catch (IOException e) {
throw new FacesException(e);
} catch (ServletException e) {
throw new FacesException(e);
}
}
}
Эта функция определена в файле taglib для Facelet WEB-INF / facelets / include.taglib.xml :
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE facelet-taglib PUBLIC
"-//Sun Microsystems, Inc.//DTD Facelet Taglib 1.0//EN"
"http://java.sun.com/dtd/facelet-taglib_1_0.dtd">
<facelet-taglib xmlns="http://java.sun.com/JSF/Facelet">
<namespace>http://demo</namespace>
<function>
<function-name>include</function-name>
<function-class>inc.Includer</function-class>
<function-signature>
java.lang.String include(java.lang.String)
</function-signature>
</function>
</facelet-taglib>
Это указывается как библиотека в WEB-INF / web.xml с использованием параметра контекста :
<context-param>
<param-name>facelets.LIBRARIES</param-name>
<param-value>/WEB-INF/facelets/include.taglib.xml</param-value>
</context-param>
Пример использования
JSP будет включен, includeme.jsp :
<?xml version="1.0" encoding="UTF-8" ?>
<jsp:root xmlns:jsp="http://java.sun.com/JSP/Page" version="2.0">
<jsp:directive.page language="java"
contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" />
<b>Some data: ${foo}</b>
</jsp:root>
Facelet, который включает JSP:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:demo="http://demo">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>JSP include hack</title>
</head>
<body>
<h:form>
<p> ${demo:include('/includeme.jsp')} </p>
<h:inputText type="text" value="#{foo}" />
<h:commandButton type="submit" />
</h:form>
</body>
</html>
Обратите внимание на использование $ {demo: include ('/ includeme.jsp')} для вызова диспетчера запросов (функция возвращает пустую строку). Функция включена в атрибут xmlns: demo = "http://demo". Переменная области запроса foo привязана к текстовому полю и выбрана JSP.
Все, что я могу сказать по этому поводу, это то, что это сработало для меня, и, вероятно, существует дюжина причин, по которым он не будет работать с определенной комбинацией тегов или с определенными комбинациями библиотек JSF. Будьте бдительны.