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 %>&amp;action=sessionDetail&amp;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]

Reply via email to