Как использовать JSTL в проекте GWT?
Я строю проект GWT, с GWT-2.0.3 и плагином Eclipse. хорошо, сначала я попробовал, JSTL1.2 и сервлет 2.5,
- я добавляю jstl-1.2.jar к войне /WEB-INF/lib
в web.xml я использую:
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
на странице JSP я использую:
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> <c:forEach var="app" items="${requestScope.apps}"> <tr><td width=20%><c:out value="${app.mapping}"></c:out></td> <td width=40%><c:out value="${app.description}"></c:out></td> ...
Если я удаляю тег foreach, он работает нормально. но если я использую основные теги, я получаю следующее исключение:
HTTP ERROR: 500
javax.servlet.jsp.PageContext.getELContext()Ljavax/el/ELContext;
RequestURI=/system/view/register.html
Caused by:
java.lang.AbstractMethodError: javax.servlet.jsp.PageContext.getELContext()Ljavax/el/ELContext;
at javax.servlet.jsp.jstl.core.LoopTagSupport.unExposeVariables(LoopTagSupport.java:587)
at javax.servlet.jsp.jstl.core.LoopTagSupport.doFinally(LoopTagSupport.java:323)
at org.apache.jsp.system.view_jsp._jspx_meth_c_forEach_0(view_jsp.java:267)
at org.apache.jsp.system.view_jsp._jspx_meth_a_body_0(view_jsp.java:186)
at org.apache.jsp.system.view_jsp._jspService(view_jsp.java:98)
at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:94)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:820)
at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:324)
at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:292)
at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:236)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:820)
at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:487)
at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:362)
at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:181)
at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:729)
at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:405)
at org.mortbay.jetty.servlet.Dispatcher.forward(Dispatcher.java:285)
at org.mortbay.jetty.servlet.Dispatcher.forward(Dispatcher.java:126)
at org.app4j.test.DispatchServlet.doGet(DispatchServlet.java:133)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:707)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:820)
at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:487)
at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:362)
at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:181)
at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:729)
at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:405)
at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
at org.mortbay.jetty.handler.RequestLogHandler.handle(RequestLogHandler.java:49)
at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
at org.mortbay.jetty.Server.handle(Server.java:324)
at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:505)
at org.mortbay.jetty.HttpConnection$RequestHandler.headerComplete(HttpConnection.java:829)
at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:513)
at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:211)
at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:380)
at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:395)
at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:488)
Powered by Jetty://
Если я разверну проект в Tomcat 6, он будет работать нормально. Я ищу в Интернете и нахожу статью "Язык выражений JSP во встроенной в GWT Jetty", поэтому я попробовал jstl-1.1 и servlet2.4, но все равно получаю это исключение.
я считаю, что версия сервера Jetty GWT должна быть 6.1, но я не уверен в этом, если это правда, он должен поддерживать EE5, поэтому кто-нибудь интегрировал GWT и JSTL? пожалуйста помоги! Благодарю.
4 ответа
Я наткнулся на это, пока искал исправление JSTL для своего проекта движка приложений. Я нашел ответ на странице "Будет ли это играть" от Google. Видимо, вы должны добавить
<%@page isElIgnored="false" %>
на ваши страницы JSP, чтобы включить анализ EL.
Я бы порекомендовал просто переключиться на внешний Java-сервер (например, Tomcat, который, кажется, вы установили и который работает с вашей конфигурацией) - гораздо меньше проблем, проще, чем пытаться работать с поврежденной Jetty, которая поставляется с GWT.
Инструкции можно найти в документации. Если вы будете придерживаться GWT Jetty, в будущем у вас будут только другие проблемы.
Обновление, см. Комментарий Паскаля Thivent ниже:
@Pascal: извините за это, я не хотел просто сказать "Переключиться на внешний сервер, не разговаривать", просто я видел много людей на SO и в GWT в Google Group, у которых есть проблемы с настройкой Jetty, который приходит с GWT - в некоторых случаях это потому, что конфигурация несколько отличается от стандартной, потому что команда GWT включила более старую / измененную (я не могу получить точную информацию об этом) версию Jetty, например, см. этот пост и комментарии там, некоторые цитаты:
ПРИМЕЧАНИЕ: я считаю, что версия пристани, поставляемая с GWT, ниже 6.1.12, и поэтому вы должны пропустить первый параметр в примерах документации, как он был добавлен в пристани 6.1.12rc3. См. Примечание в верхней части страницы документов Jetty.
Предположительно, Jetty поддерживает спецификацию сервлета 2.5 и внедрение ресурсов через запись web.xml или аннотацию @resource. Однако мне еще предстоит выяснить, поддерживается ли это версией Jetty, поставляемой с GWT. Если кто-нибудь выяснил, работает ли это или нет, и если да, то как это сделать, пожалуйста, дайте мне знать.
Другие проблемы возникают, когда кто-то хочет использовать EJB.
Все это (может быть, более сжатым / загадочным образом) написано в документации GWT - для чего я предоставил ссылку выше на точный параграф, посвященный этой проблеме.
Надеемся, что это прояснило некоторые вещи - переход на внешний сервер кажется самым простым, простым и лучшим решением - нет "специальной конфигурации GWT", а это означает, что вы можете использовать ту же конфигурацию / сервер, который вы будете использовать в работе, нет необходимо перенести вашу конфигурацию, например, в Tomcat, без неожиданных ошибок после миграции и т. д.
Я тоже получаю эту ошибку.
Я обнаружил, что могу это исправить, переместив GWT SDK в конец пути к классам в диалоговом окне Eclipse Java Build Path -> Order and Export.
Однако это нарушает сериализацию GWT с этим сообщением:
Mar 3, 2011 3:31:23 PM sun.reflect.NativeMethodAccessorImpl invoke0
WARNING: Exception while dispatching incoming RPC call
com.google.gwt.user.client.rpc.SerializationException: java.lang.reflect.InvocationTargetException
at com.google.gwt.user.server.rpc.impl.ServerSerializationStreamWriter.serializeWithCustomSerializer(ServerSerializationStreamWriter.java:764)
at com.google.gwt.user.server.rpc.impl.ServerSerializationStreamWriter.serializeImpl(ServerSerializationStreamWriter.java:727)
Вы можете исправить это, переместив библиотеку GWT обратно по пути к классам, что заставляет ее выглядеть так, как будто вы можете использовать сериализацию JSTL или GWT в Jetty, но не то и другое одновременно.
(GWT 2.1, JSTL1.2 и сервлет 2.5.)
java.lang.AbstractMethodError: javax.servlet.jsp.PageContext.getELContext()Ljavax/el/ELContext;
Путь к классу времени выполнения веб-приложения, вероятно, загроможден другой версией файла EL JAR (либо более старой версии, либо версии другого сервера приложений), в которой отсутствует упомянутый метод исключения. Я подозреваю /WEB-INF/lib
, Избавьтесь от него, обычно он уже предоставляется соответствующим сервером приложений, вам не нужно включать его в ваше веб-приложение. Это относится ко всем библиотекам приложений, таких как servlet-api.jar
а супруги кстати. Вы никогда не должны копировать его в веб-приложение /WEB-INF/lib
, Это требует проблем с переносимостью.