Class wwSession

Tracking users through a site by keeping state information in a Session table.

wwSession provides a server centric user state tracking mechanism that is backed by generic data storage mechanism. Essentially you tie an Id (typically an HTTP Cookie) to a Session record which can contain any number of values that are stored in the session table as XML encoded data.

A session object allows your application to maintain a visitors state throughout a visit through your site. Through the unique ID that identifies this user you can store user specific information in the session store and retrieve on subsequent hit. You can think of this object of a generic data record for the user without having to create a specific table and field for each value to store temporarily.

Session can automatically be enabled in Web Connection using wwProcess::InitSession() which enables session management for one or all requests depending on where it is called.

wwSession uses a table to track user session information and can use either Fox tables or SQL server. Because of the table format Web Connection Sessions can work across machines although SQL Server sessions are recommended for this scenario for performance reasons.

Class Members

MemberDescription
CreateTable This method creates a new session table if one doesn't exist yet or if you want to create a new one manually. This method is called automatically when a session is accessed. The Session table is…
o.CreateTable()
DeleteSession Physically removes a Session record from the session table. Note that this behavior is different than EndSession() which times out a session record. This method should be used sparingly.
o.DeleteSession(lcId)
EndSession Shuts down the current session for the user.
o.EndSession(lcSessionId)
GetField Retrieves a value from a field in the session table. This method mainly exists for your own custom fields that you might add to the session table for performance or query purposes. Since fields can…
o.GetField(lcFieldName)
GetSessionId Retrieves the user's current SessionId. This value is valid only after you've made a call to IsValidSession, NewSession or LocateSession.
o.GetSessionId()
GetSessionVar Returns a session variable from the Session object.
o.GetSessionVar(lcVarName)
GetUserId Returns the value from the UserID field of the current session. Note, a user ID is a manually assigned value, which typically is used to cross reference an application key such as a PK into a…
o.GetUserId()
IsValidSession This method is responsible for verifying a session id. It looks for the ID in the Session table and if found returns .T. other .F. It also loads the oData member with the content of the session…
o.IsValidSession(lcSessionId)
LocateSession Low level method that tries to load a session and set the oData member. If found the oData member is set. If not found the oData member is set to a blank record. This is a low level method and it…
o.LocateSession(lcID)
NewSession This method creates a new Session record for the current user. New sessions should be created when the session doesn't already exist. The following example demonstrates: ```foxpro lcID =…
o.NewSession(lcUserId)
OpenTable Low level method used to open the session table.
o.OpenTable()
Reindex
o.Reindex(ltPurgeDateTime)
SetField Sets the value of a custom field in the Session table.
o.SetField(lcFieldName, lvValue)
SetSessionID Overrides the current SessionID's value to a new value.
o.SetSessionID(lcID)
SetSessionVar Sets a Session variable to a specified value. All values must be passed in as strings.
o.SetSessionVar(lcVarName, lcValue)
SetUserId Note, a user ID is a manually assigned value, which typically is used to cross reference an application key such as a PK into a customer table. The Session ID is a random generated key while the user…
o.SetUserId(lcUserId)
TimeoutSessions Deletes all sessions that have timed out.
o.TimeoutSessions(lnSeconds)
cDataPath Name of the path where the table lives. * Default:* .\ (current path)
cSessionID The Session ID of the currently accessed session.
cTableName Name of the table. Note this should be just the table name. Use cDataPath for explicit pathing on the table.
lDontSaveSession You can set this flag to cause an active Session not write out the session content when the object goes out of scope. This method is provided for performance enhancement features on applications…
lNoFileCheck Performance operation that skips the check for the file's existence before opening it when set to .T. Since sessions are accessed on every hit, if you know you have the table already in place there's…
nSessionTimeout The timeout value in seconds for a user's session. If the session is idle for this amount of seconds the session is deleted. * Default:* 1800 - 1/2 hour
oRequest * Optional:* An instance of the wwRequest object. This object is used when creating a new session to retrieve the client's IP address and browser and store it in the IP and Browser fields…

See also

Class wwSession
Configuring Web Connection for use with SQL Server
wwProcess::InitSession

© West Wind Technologies, 2025 • Updated: 2025-03-12
Comment or report problem with topic