| Main -> Documentation -> Building Your WebZ Interface -> How the WebZ Interface Works -> Detailed Description of a WebZ Session | 
| Detailed Description of a WebZ Session - continued Start Page, Stage 1, Stage 2, Stage 3 
 In Stage 1, the user sent in a request to begin a new WebZ session. The user did this by clicking the GO! button on the Logon screen of the Out-of-the-Box Interface. In Stage 2, we will discuss the events that take place when WebZ receives the logon request. 
 As presented in Stage 1, the following is the content of the user request sent to WebZ in order to begin a new session: POST /WebZ/Authorize:sessionid=0: \ 
 The following events take place when WebZ receives the user request for a new session. These events are described in detail in the remaining sections in this stage. 
 
 The presence of "sessionid=0" within the user request causes the OpServe component to create a new session id and UserState object for the user. When OpServe detects sessionid=0, it assigns the user to an available JaSSI and gives the user a unique, randomly generated id number identifies the user's session until logoff. The following is an example of a typical session id. We will use this session id throughout the remaining stages of the example WebZ session. 01-37542-1619472257 Description of the Session ID: 
 The UserState object is a memory object (specifically, an extended hashtable) in which the user's session data is stored and retrieved. Throughout the user's session, the UserState object is the storage object for the user's list of databases, the user's interface style, search results, etc. Each user session has its own UserState object. The UserState object makes it possible for WebZ to maintain a stateful session and thus makes it seem as though the user has a dedicated connection from the web browser to the WebZ system. Without the UserState object, a user's session could not occur because there would be no way of maintaining persistent data about the user's activities within the session. 
 When the JaSSI component receives the user request, it creates an Action object and a RequestManager object to process the request. The information contained in the user request is reduced to its essential elements and is stored in the Action object. The RequestManager object uses the information in the Action object for executing all instructions in the user request, and for preparing and sending a response back to the user. The following example shows the information contained in the Action object and RequestManager object for the user request in our example WebZ session. Log File Tip: This information was taken directly from the JaSSI user logfile (with trace level set to TRACE_ALL). Every instance of an Action object or RequestManager object created during a WebZ session is recorded in the JaSSI user log, which is extremely helpful if you are learning about the system or are trying to debug your customized interface. -------------- 
 
 Once the Action object and RequestManager objects are created, the JaSSI is essentially ready to begin processing the instructions contained in the user request. To begin the processing, the RequestManager attempts to execute the instruction contained in the className field of the Action object. In our example WebZ session, the className field contains the following: className = /WebZ/Authorize Class/File Load Order 
 In addition to the document and class root directories, the RequestManager searches the Java packages defined in the [PackageOrder] section of the JaSSIServer.ini configuration file, which is configured at installation to be the following: The search sequence listed above is referred to as the Class/File Load Order, and it is the process by which the JaSSI is able to locate and load Java classes and HTML files. Why does it search in this particular order? The JaSSI is hard-coded to search the WebZ document root and WebZ class root, and both of these locations are user-definable. You can also assign additional locations for the JaSSI to search, such as specific Java class packages. The benefit of being able to specify Java packages is that it allows the JaSSI to locate classes and files faster, and it allows you to use your own, custom Java packages and keep them separate from the WebZ packages. 
 1 [D19990218.T101104.607] [RequestManager.processCommand()] The RequestManager's planned search path for Authorize is in line 5. In line 6, the RequestManager begins the search. It searches the document root (line 8) and the class root (line 9), and then it finds Authorize (line 10) in the ORG.oclc.obi package. When the Authorize class loads, the AccessUserData.get method is executed (lines 11 and 12) and the authorization process is under way. 
 
 When the Authorize class executes, it first checks to see if the user's id and password (supplied in the original user request) are valid. If so, it creates the following data for the user and stores the data (or references to the data) in the user's UserState object. User Data 
 Once this information is created, the user's session is ready to begin. Upon successful completion of the Authorize class, the RequestManager searches the Action object for a next command in the user request. The next command contains instructions for what should occur now that the Authorize class was successfully executed. In our example WebZ session, the user request contains the following next command, which, when processed, will instruct the RequestManager to load the homeframe.html file. next=html%2Fhomeframe.html The RequestManager locates the next command and updates the Action object as follows: 1 --------------- 
 The RequestManager now attempts to execute the instruction contained in the className field of the Action object (line 8 above). To do this, the RequestManager first tries to locate the homeframe.html file using the same Class/File Load Order it used when executing the Authorize class. The following section of the JaSSI user log shows the RequestManager loading the homeframe.html file: 1 Class/file load order: The homeframe.html file is located in the WebZ document root directory, which is defined in the DocumentRoot variable in the JaSSIServer.ini configuration file. In accordance with the Class/File Load Order, the RequestManager searches the document root first and locates homeframe.html (line 6) and begins reading the file (line 7). The homeframe.html file will eventually become the Home screen displayed to the user in the WebZ interface. 
 In Stage 1, the user opened the WebZ logon screen and clicked the GO! button, which sent an HTTP message to WebZ requesting a new user session. In Stage 2, WebZ created a session id and UserState object, created a RequestManager object to handle the request, authorized the user, loaded data about the user, and began reading the homeframe.html in order to build the Home screen of the interface. What Happens Next? | 
| [Main][Documentation][Support][Technical 
      Reference][Community][Glossary][Search] |