jsp
PROPÓSITO
- anotar todo lo relevante sobre jsp
ITERATOR
- ejemplo de uso de iterator en EPNOM
<%-- <s:iterator value="listaResultados">
<tr> <td><s:property value="idSolicitud"/></td> <td>- <s:property value="fechaCreacion"/></td></tr>
</s:iterator>
--%>
DATOS EN JSP
- para sacar datos en un jsp
<!-- esProvinciaCentroAragon <s:property value="esProvinciaCentroAragon" /> -->
esProvinciaCentroAragon <s:property value="convocatoriaPresolicitudPeticionGeneral.getProvincia().getCprov()" />
Número de registros en la lista de vernáculas <s:property value="listaVernaculas.size" />
usuario perfil primaria <s:property value="sesionUsuario.getPerfilUsuario().isPri()?'Si':'No'" />
usuario perfil secundaria <s:property value="sesionUsuario.getPerfilUsuario().isSec()?'Si':'No'" />
<!--
<p>Si ejerce el derecho a concurrencia <s:property value="convocatoriaPresolicitud.ejerceDerechoConcurrencia" /> </p>
<p>Si ejerce el derecho a DPC <s:property value="convocatoriaPresolicitud.ejerceDerechoPreferenteCentro" /> </p>
<p>Si ejerce el derecho a DPL <s:property value="convocatoriaPresolicitud.ejerceDerechoPreferenteLocalidad" /> </p>
<p>Si tiene que pedir forzosas <s:property value="convocatoriaPresolicitud.modalidadPeticionesForzosas" /> </p> -->
PROBLEMAS
- desarrollando EPNOM_ADM con el nuevo diseño
- un fantasma con un error de sintaxis en el
else
en estas líneas del archivocabacera.jsp
<%
if (mostrarMenuLateral)
{
%>
<%@ include file="/jsp/comun/menus/menuLateral.jsp" %>
<div class="page">
<%
}
else
{
%>
<div class="pageSinMenuLateral">
<%
}
%>
- al final se soluciona siguiendo el resto de errores pero no esta claro como
ERRORES NO COHERENTES
- daba bastantes errores como que no estaba una variable mostrarMenuLateral
- era el primer error que salía y me atasco en ese error
- no era el relevante
- empiezo a depurar por los últimos errores y de repente los primeros desaparecen
JAVA.IO.IOEXCEPTION: STREAM CLOSED
- da un error en el index.jsp de presolicitudes en EPNOM
<%--
ESTA PARTE FUNCIONA
<s:iterator value="listaResultados">
<tr> <td><s:property value="idSolicitud"/></td> <td>- <s:property value="fechaCreacion"/></td></tr>
</s:iterator>
--%>
<s:property value="listaNominaPresolicitudes.size" />
<%
for (NominaPresolicitud nominaPresolicitud:listaNominaPresolicitudes)
{
out.println("<tr>");
out.println(" <td>" + nominaPresolicitud.getIdSolicitud() + "</td>");
out.println(" <td>");
out.println(" </td>");
out.println("</tr>");
}
%>
Struts Problem Report
Struts has detected an unhandled exception:
Messages:
Stream closed
File: org/apache/jasper/runtime/JspWriterImpl.java
Line number: 210
Stacktraces
java.io.IOException: Stream closed
org.apache.jasper.runtime.JspWriterImpl.ensureOpen(JspWriterImpl.java:210)
org.apache.jasper.runtime.JspWriterImpl.flushBuffer(JspWriterImpl.java:115)
org.apache.jasper.runtime.JspWriterImpl.flush(JspWriterImpl.java:177)
org.apache.jasper.runtime.JspRuntimeLibrary.include(JspRuntimeLibrary.java:942)
org.apache.jasper.runtime.PageContextImpl.include(PageContextImpl.java:652)
org.apache.struts2.result.ServletDispatcherResult.doExecute(ServletDispatcherResult.java:132)
org.apache.struts2.result.StrutsResultSupport.execute(StrutsResultSupport.java:206)
com.opensymphony.xwork2.DefaultActionInvocation.executeResult(DefaultActionInvocation.java:375)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:279)
es.aragon.epnom.struts.interceptors.LoggerInterceptor.intercept(LoggerInterceptor.java:50)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:249)
es.aragon.epnom.struts.interceptors.AuthenticationInterceptor.intercept(AuthenticationInterceptor.java:46)
com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:249)
org.apache.struts2.factory.StrutsActionProxy.execute(StrutsActionProxy.java:48)
org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:574)
org.apache.struts2.dispatcher.ExecuteOperations.executeAction(ExecuteOperations.java:79)
org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter.doFilter(StrutsPrepareAndExecuteFilter.java:141)
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:225)
org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:169)
org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168)
org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98)
org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:927)
org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:999)
org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:565)
org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:307)
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
java.lang.Thread.run(Thread.java:724)
You are seeing this page because development mode is enabled. Development mode, or devMode, enables extra debugging behaviors and reports to assist developers. To disable this mode, set:
struts.devMode=false
in your WEB-INF/classes/struts.properties file.
-
miro
C:\Servidores\Apache Tomcat 7.0.27\work\Catalina\localhost\epnom\org\apache\jsp\jsp\nominas\gestionNomina\presolicitudes\index_jsp.java
-
la clave esta en el log del Tomcat
C:\Servidores\Apache Tomcat 7.0.27\logs\localhost.2020-06-06.log
java.lang.ClassCastException: es.aragon.epnom.ent.nominas.solicitud.NominaSolicitud cannot be cast to es.aragon.epnom.ent.nominas.presolicitud.NominaPresolicitud
at org.apache.jsp.jsp.nominas.gestionNomina.presolicitudes.index_jsp._jspService(index_jsp.java:1105)
at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
- en el
rowmapper
del DAL estaba definido como que devolvía NominaSolicitud y no NominaPresolicitud