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 archivo cabacera.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