Merge branch 'master' of ssh://git.eclipse.org/gitroot/jetty/org.eclipse.jetty.project

This commit is contained in:
Greg Wilkins 2012-03-02 08:07:57 +11:00
commit 68fa3c50b4
4 changed files with 84 additions and 49 deletions

View File

@ -1,7 +1,6 @@
This is a source checkout of the Jetty webserver. This is a source checkout of the Jetty webserver.
To build, use: To build, use:
mvn install mvn install

View File

@ -71,6 +71,7 @@ public class JDBCSessionIdManager extends AbstractSessionIdManager
protected long _lastScavengeTime; protected long _lastScavengeTime;
protected long _scavengeIntervalMs = 1000L * 60 * 10; //10mins protected long _scavengeIntervalMs = 1000L * 60 * 10; //10mins
protected String _blobType; //if not set, is deduced from the type of the database at runtime protected String _blobType; //if not set, is deduced from the type of the database at runtime
protected String _longType; //if not set, is deduced from the type of the database at runtime
protected String _createSessionIdTable; protected String _createSessionIdTable;
protected String _createSessionTable; protected String _createSessionTable;
@ -82,6 +83,13 @@ public class JDBCSessionIdManager extends AbstractSessionIdManager
protected String _deleteId; protected String _deleteId;
protected String _queryId; protected String _queryId;
protected String _insertSession;
protected String _deleteSession;
protected String _selectSession;
protected String _updateSession;
protected String _updateSessionNode;
protected String _updateSessionAccessTime;
protected DatabaseAdaptor _dbAdaptor; protected DatabaseAdaptor _dbAdaptor;
@ -146,6 +154,17 @@ public class JDBCSessionIdManager extends AbstractSessionIdManager
return "blob"; return "blob";
} }
public String getLongType ()
{
if (_longType != null)
return _longType;
if (_dbName.startsWith("oracle"))
return "number(20)";
return "bigint";
}
public InputStream getBlobInputStream (ResultSet result, String columnName) public InputStream getBlobInputStream (ResultSet result, String columnName)
throws SQLException throws SQLException
{ {
@ -158,6 +177,18 @@ public class JDBCSessionIdManager extends AbstractSessionIdManager
Blob blob = result.getBlob(columnName); Blob blob = result.getBlob(columnName);
return blob.getBinaryStream(); return blob.getBinaryStream();
} }
/**
* rowId is a reserved word for Oracle, so change the name of this column
* @return
*/
public String getRowIdColumnName ()
{
if (_dbName != null && _dbName.startsWith("oracle"))
return "srowId";
return "rowId";
}
} }
@ -239,6 +270,18 @@ public class JDBCSessionIdManager extends AbstractSessionIdManager
return _blobType; return _blobType;
} }
public String getLongType()
{
return _longType;
}
public void setLongType(String longType)
{
this._longType = longType;
}
public void setScavengeInterval (long sec) public void setScavengeInterval (long sec)
{ {
if (sec<=0) if (sec<=0)
@ -528,7 +571,7 @@ public class JDBCSessionIdManager extends AbstractSessionIdManager
connection.setAutoCommit(true); connection.setAutoCommit(true);
DatabaseMetaData metaData = connection.getMetaData(); DatabaseMetaData metaData = connection.getMetaData();
_dbAdaptor = new DatabaseAdaptor(metaData); _dbAdaptor = new DatabaseAdaptor(metaData);
_sessionTableRowId = (_dbAdaptor.getDBName() != null && _dbAdaptor.getDBName().contains("oracle") ? "srowId":_sessionTableRowId); _sessionTableRowId = _dbAdaptor.getRowIdColumnName();
//checking for table existence is case-sensitive, but table creation is not //checking for table existence is case-sensitive, but table creation is not
String tableName = _dbAdaptor.convertIdentifier(_sessionIdTable); String tableName = _dbAdaptor.convertIdentifier(_sessionIdTable);
@ -546,10 +589,11 @@ public class JDBCSessionIdManager extends AbstractSessionIdManager
{ {
//table does not exist, so create it //table does not exist, so create it
String blobType = _dbAdaptor.getBlobType(); String blobType = _dbAdaptor.getBlobType();
String longType = _dbAdaptor.getLongType();
_createSessionTable = "create table "+_sessionTable+" ("+_sessionTableRowId+" varchar(120), sessionId varchar(120), "+ _createSessionTable = "create table "+_sessionTable+" ("+_sessionTableRowId+" varchar(120), sessionId varchar(120), "+
" contextPath varchar(60), virtualHost varchar(60), lastNode varchar(60), accessTime bigint, "+ " contextPath varchar(60), virtualHost varchar(60), lastNode varchar(60), accessTime "+longType+", "+
" lastAccessTime bigint, createTime bigint, cookieTime bigint, "+ " lastAccessTime "+longType+", createTime "+longType+", cookieTime "+longType+", "+
" lastSavedTime bigint, expiryTime bigint, map "+blobType+", primary key("+_sessionTableRowId+"))"; " lastSavedTime "+longType+", expiryTime "+longType+", map "+blobType+", primary key("+_sessionTableRowId+"))";
connection.createStatement().executeUpdate(_createSessionTable); connection.createStatement().executeUpdate(_createSessionTable);
} }
@ -576,6 +620,28 @@ public class JDBCSessionIdManager extends AbstractSessionIdManager
if (!index2Exists) if (!index2Exists)
statement.executeUpdate("create index "+index2+" on "+_sessionTable+" (sessionId, contextPath)"); statement.executeUpdate("create index "+index2+" on "+_sessionTable+" (sessionId, contextPath)");
} }
//set up some strings representing the statements for session manipulation
_insertSession = "insert into "+_sessionTable+
" ("+_sessionTableRowId+", sessionId, contextPath, virtualHost, lastNode, accessTime, lastAccessTime, createTime, cookieTime, lastSavedTime, expiryTime, map) "+
" values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)";
_deleteSession = "delete from "+_sessionTable+
" where "+_sessionTableRowId+" = ?";
_selectSession = "select * from "+_sessionTable+
" where sessionId = ? and contextPath = ? and virtualHost = ?";
_updateSession = "update "+_sessionTable+
" set lastNode = ?, accessTime = ?, lastAccessTime = ?, lastSavedTime = ?, expiryTime = ?, map = ? where "+_sessionTableRowId+" = ?";
_updateSessionNode = "update "+_sessionTable+
" set lastNode = ? where "+_sessionTableRowId+" = ?";
_updateSessionAccessTime = "update "+_sessionTable+
" set lastNode = ?, accessTime = ?, lastAccessTime = ?, lastSavedTime = ?, expiryTime = ? where "+_sessionTableRowId+" = ?";
} }
finally finally
{ {

View File

@ -68,15 +68,8 @@ public class JDBCSessionManager extends AbstractSessionManager
{ {
private static final Logger LOG = Log.getLogger(JDBCSessionManager.class); private static final Logger LOG = Log.getLogger(JDBCSessionManager.class);
protected String __insertSession;
protected String __deleteSession;
protected String __selectSession;
protected String __updateSession;
protected String __updateSessionNode;
protected String __updateSessionAccessTime;
protected String __sessionTableRowId;
private ConcurrentHashMap<String, AbstractSession> _sessions; private ConcurrentHashMap<String, AbstractSession> _sessions;
protected JDBCSessionIdManager _jdbcSessionIdMgr = null;
protected long _saveIntervalSec = 60; //only persist changes to session access times every 60 secs protected long _saveIntervalSec = 60; //only persist changes to session access times every 60 secs
/** /**
@ -603,8 +596,8 @@ public class JDBCSessionManager extends AbstractSessionManager
if (_sessionIdManager==null) if (_sessionIdManager==null)
throw new IllegalStateException("No session id manager defined"); throw new IllegalStateException("No session id manager defined");
prepareTables(); _jdbcSessionIdMgr = (JDBCSessionIdManager)_sessionIdManager;
_sessions = new ConcurrentHashMap<String, AbstractSession>(); _sessions = new ConcurrentHashMap<String, AbstractSession>();
super.doStart(); super.doStart();
} }
@ -816,30 +809,6 @@ public class JDBCSessionManager extends AbstractSessionManager
} }
protected void prepareTables ()
{
__sessionTableRowId = ((JDBCSessionIdManager)_sessionIdManager)._sessionTableRowId;
__insertSession = "insert into "+((JDBCSessionIdManager)_sessionIdManager)._sessionTable+
" ("+__sessionTableRowId+", sessionId, contextPath, virtualHost, lastNode, accessTime, lastAccessTime, createTime, cookieTime, lastSavedTime, expiryTime, map) "+
" values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)";
__deleteSession = "delete from "+((JDBCSessionIdManager)_sessionIdManager)._sessionTable+
" where "+__sessionTableRowId+" = ?";
__selectSession = "select * from "+((JDBCSessionIdManager)_sessionIdManager)._sessionTable+
" where sessionId = ? and contextPath = ? and virtualHost = ?";
__updateSession = "update "+((JDBCSessionIdManager)_sessionIdManager)._sessionTable+
" set lastNode = ?, accessTime = ?, lastAccessTime = ?, lastSavedTime = ?, expiryTime = ?, map = ? where "+__sessionTableRowId+" = ?";
__updateSessionNode = "update "+((JDBCSessionIdManager)_sessionIdManager)._sessionTable+
" set lastNode = ? where "+__sessionTableRowId+" = ?";
__updateSessionAccessTime = "update "+((JDBCSessionIdManager)_sessionIdManager)._sessionTable+
" set lastNode = ?, accessTime = ?, lastAccessTime = ?, lastSavedTime = ?, expiryTime = ? where "+__sessionTableRowId+" = ?";
}
/** /**
* Load a session from the database * Load a session from the database
* @param id * @param id
@ -862,7 +831,7 @@ public class JDBCSessionManager extends AbstractSessionManager
try try
{ {
connection = getConnection(); connection = getConnection();
statement = connection.prepareStatement(__selectSession); statement = connection.prepareStatement(_jdbcSessionIdMgr._selectSession);
statement.setString(1, id); statement.setString(1, id);
statement.setString(2, canonicalContextPath); statement.setString(2, canonicalContextPath);
statement.setString(3, vhost); statement.setString(3, vhost);
@ -870,7 +839,7 @@ public class JDBCSessionManager extends AbstractSessionManager
if (result.next()) if (result.next())
{ {
data = new SessionData(id); data = new SessionData(id);
data.setRowId(result.getString(__sessionTableRowId)); data.setRowId(result.getString(_jdbcSessionIdMgr._sessionTableRowId));
data.setCookieSet(result.getLong("cookieTime")); data.setCookieSet(result.getLong("cookieTime"));
data.setLastAccessed(result.getLong("lastAccessTime")); data.setLastAccessed(result.getLong("lastAccessTime"));
data.setAccessed (result.getLong("accessTime")); data.setAccessed (result.getLong("accessTime"));
@ -939,7 +908,7 @@ public class JDBCSessionManager extends AbstractSessionManager
long now = System.currentTimeMillis(); long now = System.currentTimeMillis();
connection.setAutoCommit(true); connection.setAutoCommit(true);
statement = connection.prepareStatement(__insertSession); statement = connection.prepareStatement(_jdbcSessionIdMgr._insertSession);
statement.setString(1, rowId); //rowId statement.setString(1, rowId); //rowId
statement.setString(2, data.getId()); //session id statement.setString(2, data.getId()); //session id
statement.setString(3, data.getCanonicalContext()); //context path statement.setString(3, data.getCanonicalContext()); //context path
@ -994,7 +963,7 @@ public class JDBCSessionManager extends AbstractSessionManager
{ {
long now = System.currentTimeMillis(); long now = System.currentTimeMillis();
connection.setAutoCommit(true); connection.setAutoCommit(true);
statement = connection.prepareStatement(__updateSession); statement = connection.prepareStatement(_jdbcSessionIdMgr._updateSession);
statement.setString(1, getSessionIdManager().getWorkerName());//my node id statement.setString(1, getSessionIdManager().getWorkerName());//my node id
statement.setLong(2, data.getAccessed());//accessTime statement.setLong(2, data.getAccessed());//accessTime
statement.setLong(3, data.getLastAccessed()); //lastAccessTime statement.setLong(3, data.getLastAccessed()); //lastAccessTime
@ -1038,7 +1007,7 @@ public class JDBCSessionManager extends AbstractSessionManager
try try
{ {
connection.setAutoCommit(true); connection.setAutoCommit(true);
statement = connection.prepareStatement(__updateSessionNode); statement = connection.prepareStatement(_jdbcSessionIdMgr._updateSessionNode);
statement.setString(1, nodeId); statement.setString(1, nodeId);
statement.setString(2, data.getRowId()); statement.setString(2, data.getRowId());
statement.executeUpdate(); statement.executeUpdate();
@ -1068,7 +1037,7 @@ public class JDBCSessionManager extends AbstractSessionManager
{ {
long now = System.currentTimeMillis(); long now = System.currentTimeMillis();
connection.setAutoCommit(true); connection.setAutoCommit(true);
statement = connection.prepareStatement(__updateSessionAccessTime); statement = connection.prepareStatement(_jdbcSessionIdMgr._updateSessionAccessTime);
statement.setString(1, getSessionIdManager().getWorkerName()); statement.setString(1, getSessionIdManager().getWorkerName());
statement.setLong(2, data.getAccessed()); statement.setLong(2, data.getAccessed());
statement.setLong(3, data.getLastAccessed()); statement.setLong(3, data.getLastAccessed());
@ -1106,7 +1075,7 @@ public class JDBCSessionManager extends AbstractSessionManager
try try
{ {
connection.setAutoCommit(true); connection.setAutoCommit(true);
statement = connection.prepareStatement(__deleteSession); statement = connection.prepareStatement(_jdbcSessionIdMgr._deleteSession);
statement.setString(1, data.getRowId()); statement.setString(1, data.getRowId());
statement.executeUpdate(); statement.executeUpdate();
if (LOG.isDebugEnabled()) if (LOG.isDebugEnabled())

View File

@ -131,10 +131,11 @@ public abstract class AbstractClientCrossContextSessionTest
{ {
HttpSession session = request.getSession(false); HttpSession session = request.getSession(false);
if (session == null) if (session == null)
{
session = request.getSession(true); session = request.getSession(true);
sessionId = session.getId();
} sessionId = session.getId();
// Add something to the session // Add something to the session
session.setAttribute("B", "B"); session.setAttribute("B", "B");