Author: remm Date: Mon Apr 16 16:30:24 2007 New Revision: 529443 URL: http://svn.apache.org/viewvc?view=rev&rev=529443 Log: - Add session browser capabilities in the manager. Let me know if it creates problems (I checked XSS to some extent to, but please double check if you can). - Submitted by Cédrik Lime.
Added: tomcat/tc6.0.x/trunk/webapps/manager/sessionsList.jsp (with props) Added: tomcat/tc6.0.x/trunk/webapps/manager/sessionsList.jsp URL: http://svn.apache.org/viewvc/tomcat/tc6.0.x/trunk/webapps/manager/sessionsList.jsp?view=auto&rev=529443 ============================================================================== --- tomcat/tc6.0.x/trunk/webapps/manager/sessionsList.jsp (added) +++ tomcat/tc6.0.x/trunk/webapps/manager/sessionsList.jsp Mon Apr 16 16:30:24 2007 @@ -0,0 +1,122 @@ +<?xml version="1.0" encoding="ISO-8859-1"?> +<[EMAIL PROTECTED] session="false" contentType="text/html; charset=ISO-8859-1" %> +<[EMAIL PROTECTED] import="java.util.Collection" %> +<[EMAIL PROTECTED] import="java.util.Iterator" %> +<[EMAIL PROTECTED] import="org.apache.catalina.manager.JspHelper" %> +<[EMAIL PROTECTED] import="org.apache.catalina.Session" %> +<!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" xml:lang="en"> +<% String path = (String) request.getAttribute("path"); + String submitUrl = ((HttpServletRequest)pageContext.getRequest()).getRequestURL().append("?path=").append(path).toString(); + Collection activeSessions = (Collection) request.getAttribute("activeSessions"); +%> +<head> + <meta http-equiv="content-type" content="text/html; charset=iso-8859-1"/> + <meta http-equiv="pragma" content="no-cache"/><!-- HTTP 1.0 --> + <meta http-equiv="cache-control" content="no-cache,must-revalidate"/><!-- HTTP 1.1 --> + <meta http-equiv="expires" content="0"/><!-- 0 is an invalid value and should be treated as 'now' --> + <meta http-equiv="content-language" content="en"/> + <meta name="author" content="Cedrik LIME"/> + <meta name="copyright" content="copyright 2005-2007 the Apache Software Foundation"/> + <meta name="robots" content="noindex,nofollow,noarchive"/> + <title>Sessions Administration for <%= path %></title> +</head> +<body> +<h1>Sessions Administration for <%= path %></h1> + +<p>Tips:</p> +<ul> + <li>Click on a column to sort.</li> + <li>To view a session details and/or remove a session attributes, click on its id.</li> +</ul> + +<div class="error"><%= JspHelper.escapeXml(request.getAttribute("error")) %></div> +<div class="message"><%= JspHelper.escapeXml(request.getAttribute("message")) %></div> + +<form action="<%= submitUrl %>" method="post" id="sessionsForm"> + <fieldset><legend>Active HttpSessions informations</legend> + <input type="hidden" name="action" id="sessionsFormAction" value="injectSessions"/> + <input type="hidden" name="sort" id="sessionsFormSort" value="<%= (String) request.getAttribute("sort") %>"/> + <% String order = (String) request.getAttribute("order"); + if (order == null || "".equals(order)) { + order = "ASC"; + } + %> + <input type="hidden" name="order" id="sessionsFormSortOrder" value="<%= order %>"/> + <input type="submit" name="refresh" id="refreshButton" value="Refresh Sessions list" onclick="document.getElementById('sessionsFormAction').value='refreshSessions'; return true;"/> + <%= JspHelper.formatNumber(activeSessions.size()) %> active Sessions<br/> + <table border="1" cellpadding="2" cellspacing="2" width="100%"> + <thead> + <tr> + <th><a onclick="document.getElementById('sessionsFormSort').value='id'; document.getElementById('refreshButton').click(); return true;">Session Id</a></th> + <th><a onclick="document.getElementById('sessionsFormSort').value='locale'; document.getElementById('refreshButton').click(); return true;">Guessed Locale</a></th> + <th><a onclick="document.getElementById('sessionsFormSort').value='user'; document.getElementById('refreshButton').click(); return true;">Guessed User name</a></th> + <th><a onclick="document.getElementById('sessionsFormSort').value='CreationTime'; document.getElementById('refreshButton').click(); return true;">Creation Time</a></th> + <th><a onclick="document.getElementById('sessionsFormSort').value='LastAccessedTime'; document.getElementById('refreshButton').click(); return true;">Last Accessed Time</a></th> + <th><a onclick="document.getElementById('sessionsFormSort').value='UsedTime'; document.getElementById('refreshButton').click(); return true;">Used Time</a></th> + <th><a onclick="document.getElementById('sessionsFormSort').value='InactiveTime'; document.getElementById('refreshButton').click(); return true;">Inactive Time</a></th> + <th><a onclick="document.getElementById('sessionsFormSort').value='TTL'; document.getElementById('refreshButton').click(); return true;"><span title="Time To Live">TTL</span></a></th> + </tr> + </thead> + <% if (activeSessions.size() > 10) { %> + <tfoot><%-- <tfoot> is the same as <thead> --%> + <tr> + <th><a onclick="document.getElementById('sessionsFormSort').value='id'; document.getElementById('refreshButton').click(); return true;">Session Id</a></th> + <th><a onclick="document.getElementById('sessionsFormSort').value='locale'; document.getElementById('refreshButton').click(); return true;">Guessed Locale</a></th> + <th><a onclick="document.getElementById('sessionsFormSort').value='user'; document.getElementById('refreshButton').click(); return true;">Guessed User name</a></th> + <th><a onclick="document.getElementById('sessionsFormSort').value='CreationTime'; document.getElementById('refreshButton').click(); return true;">Creation Time</a></th> + <th><a onclick="document.getElementById('sessionsFormSort').value='LastAccessedTime'; document.getElementById('refreshButton').click(); return true;">Last Accessed Time</a></th> + <th><a onclick="document.getElementById('sessionsFormSort').value='UsedTime'; document.getElementById('refreshButton').click(); return true;">Used Time</a></th> + <th><a onclick="document.getElementById('sessionsFormSort').value='InactiveTime'; document.getElementById('refreshButton').click(); return true;">Inactive Time</a></th> + <th><a onclick="document.getElementById('sessionsFormSort').value='TTL'; document.getElementById('refreshButton').click(); return true;"><span title="Time To Live">TTL</span></a></th> + </tr> + </tfoot> + <% } // end if %> + <tbody> +<% Iterator iter = activeSessions.iterator(); + while (iter.hasNext()) { + Session currentSession = (Session) iter.next(); + String currentSessionId = currentSession.getId(); +%> + <tr> + <td> +<input type="checkbox" name="sessionIds" value="<%= currentSessionId %>" /><a href="<%= submitUrl %>&action=sessionDetail&sessionId=<%= currentSessionId %>" target="_new"><%= JspHelper.escapeXml(currentSessionId) %></a> + </td> + <td style="text-align: center;"><%= JspHelper.guessDisplayLocaleFromSession(currentSession) %></td> + <td style="text-align: center;"><%= JspHelper.guessDisplayUserFromSession(currentSession) %></td> + <td style="text-align: center;"><%= JspHelper.getDisplayCreationTimeForSession(currentSession) %></td> + <td style="text-align: center;"><%= JspHelper.getDisplayLastAccessedTimeForSession(currentSession) %></td> + <td style="text-align: center;"><%= JspHelper.getDisplayUsedTimeForSession(currentSession) %></td> + <td style="text-align: center;"><%= JspHelper.getDisplayInactiveTimeForSession(currentSession) %></td> + <td style="text-align: center;"><%= JspHelper.getDisplayTTLForSession(currentSession) %></td> + </tr> +<% } // end while %> + </tbody> + </table> + <p style="text-align: center;"> + <input type="submit" name="invalidate" value="Invalidate selected Sessions" onclick="document.getElementById('sessionsFormAction').value='invalidateSessions'; return true;"/> + </p> + </fieldset> +</form> + +<p style="text-align: center;"><button type="button" onclick="window.close()">Close window</button></p> + +<%--div style="display: none;"> +<p> + <a href="http://validator.w3.org/check?uri=referer"><img + src="http://www.w3.org/Icons/valid-html401" + alt="Valid HTML 4.01!" height="31" width="88"></a> + <a href="http://validator.w3.org/check?uri=referer"><img + src="http://www.w3.org/Icons/valid-xhtml10" + alt="Valid XHTML 1.0!" height="31" width="88" /></a> + <a href="http://validator.w3.org/check?uri=referer"><img + src="http://www.w3.org/Icons/valid-xhtml11" + alt="Valid XHTML 1.1!" height="31" width="88" /></a> +</p> +</div--%> + +</body> +</html> \ No newline at end of file Propchange: tomcat/tc6.0.x/trunk/webapps/manager/sessionsList.jsp ------------------------------------------------------------------------------ svn:eol-style = native --------------------------------------------------------------------- To unsubscribe, e-mail: [EMAIL PROTECTED] For additional commands, e-mail: [EMAIL PROTECTED]