Web Servers Are Apache Tomcat Blazix Web
Web Servers Are Apache Tomcat Blazix Web
Web Servers Are Apache Tomcat Blazix Web
Java Expression
<%= and %>
write blocks of Java code inside the JSP, by placing your Java code between <
% and %> characters. This block of code is known as a "scriptlet.
The JSP "request" variable is used to obtain information from the request as sent by
the browse.
A similar variable is "response". This can be used to affect the response being sent
to the browser. For instance, you can call response.sendRedirect( anotherUrl );
to send a response to the browser that it should load a different URL. This response
will actualy go all the way to the browser. The browser will then send a different
request, to "anotherUrl". This is a little different from some other JSP mechanisms
we will come across, for including another page or forwarding the browser to
another page.
JSP Directives
We have been fully qualifying the java.util.Date in the examples in the previous sections.
Perhaps you wondered why we don't just import java.util.*;
It is possible to use "import" statements in JSPs, but the syntax is a little different from normal
Java. Try the following example:
<%@ page import="java.util.*" %>
<HTML>
<BODY>
<%
System.out.println( "Evaluating date now" );
Date date = new Date();
%>
Hello! The time is now <%= date %>
</BODY>
</HTML>
The first line in the above example is called a "directive". A JSP "directive" starts with <%@
characters.
This one is a "page directive". The page directive can contain the list of all imported packages.
To import more than one item, separate the package names by commas, e.g.
<%@ page import="java.util.*,java.text.*" %>
There are a number of JSP directives, besides the page directive. Besides the page directives, the
other most useful directives are include and taglib. We will be covering taglib separately.
The include directive is used to physically include the contents of another file. The included file
can be HTML or JSP or anything else -- the result is as if the original JSP file actually contained
the included text. To see this directive in action, create a new JSP
<HTML>
<BODY>
Going to include hello.jsp...<BR>
<%@ include file="hello.jsp" %>
</BODY>
</HTML>
View this JSP in your browser, and you will see your original hello.jsp get included in the new
JSP.
JSP Declarations
The JSP you write turns into a class definition. All the scriptlets you write are placed inside a
single method of this class.
You can also add variable and method declarations to this class. You can then use these
variables and methods from your scriptlets and expressions.
To add a declaration, you must use the <%! and %> sequences to enclose your declarations, as
shown below.
<%@ page import="java.util.*" %>
<HTML>
<BODY>
<%!
Date theDate = new Date();
Date getDate()
{
System.out.println( "In getDate() method" );
return theDate;
}
%>
Hello! The time is now <%= getDate() %>
</BODY>
</HTML>
The example has been created a little contrived, to show variable and method declarations.
Here we are declaring a Date variable theDate, and the method getDate. Both of these are
available now in our scriptlets and expressions.
But this example no longer works! The date will be the same, no matter how often you reload
the page. This is because these are declarations, and will only be evaluated once when the page
is loaded! (Just as if you were creating a class and had variable initialization declared in it.)
Exercise: Modify the above example to add another function computeDate which re-initializes
theDate. Add a scriptlet that calls computeDate each time.
Note: Now that you know how to do this -- it is in general not a good idea to use variables as
shown here. The JSP usually will run as multiple threads of one single instance. Different
threads would interfere with variable access, because it will be the same variable for all of them.
If you do have to use variables in JSP, you should use synchronized access, but that hurts the
performance. In general, any data you need should go either in the session object or the request
object (these are introduced a little later) if passing data between different JSP pages. Variables
you declare inside scriptlets are fine, e.g. <% int i = 45; %> because these are declared inside the
local scope and are not shared.
JSP Tags
Another important syntax element of JSP are tags. JSP tags do not use <%, but just the <
character. A JSP tag is somewhat like an HTML tag. JSP tags can have a "start tag", a "tag
body" and an "end tag". The start and end tag both use the tag name, enclosed in < and >
characters. The end starts with a / character after the < character. The tag names have an
embedded colon character : in them, the part before the colon describes the type of the tag. For
instance:
<some:tag>
body
</some:tag>
If the tag does not require a body, the start and end can be conveniently merged together, as
<some:tag/>
Here by closing the start tag with a /> instead of > character, we are ending the tag immediately,
and without a body. (This syntax convention is the the same as XML.)
Tags can be of two types: loaded from an external tag library, or predefined tags. Predefined
tags start with jsp: characters. For instance, jsp:include is a predefined tag that is used to
include other pages.
We have already seen the include directive. jsp:include is similar. But instead of loading the
text of the included file in the original file, it actually calls the included target at run-time (the
way a browser would call the included target. In practice, this is actually a simulated request
rather than a full round-trip between the browser and the server). Following is an example of
jsp:include usage
<HTML>
<BODY>
Going to include hello.jsp...<BR>
<jsp:include page="hello.jsp"/>
</BODY>
</HTML>
Try it and see what you get. Now change the "jsp:include" to "jsp:forward" and see what is
the difference. These two predefined tags are frequently very useful.
JSP Sessions
On a typical web site, a visitor might visit several pages and perform several interactions.
If you are programming the site, it is very helpful to be able to associate some data with each
visitor. For this purpose, "session"s can be used in JSP.
A session is an object associated with a visitor. Data can be put in the session and retrieved from
it, much like a Hashtable. A different set of data is kept for each visitor to the site.
Here is a set of pages that put a user's name in the session, and display it elsewhere. Try out
installing and using these.
First we have a form, let us call it GetName.html
<HTML>
<BODY>
<FORM METHOD=POST ACTION="SaveName.jsp">
What's your name? <INPUT TYPE=TEXT NAME=username SIZE=20>
<P><INPUT TYPE=SUBMIT>
</FORM>
</BODY>
</HTML>
The target of the form is "SaveName.jsp", which saves the user's name in the session. Note the
variable "session". This is another variable that is normally made available in JSPs, just like
out and request variables. (In the @page directive, you can indicate that you do not need
sessions, in which case the "session" variable will not be made available.)
<%
String name = request.getParameter( "username" );
session.setAttribute( "theName", name );
%>
<HTML>
<BODY>
<A HREF="NextPage.jsp">Continue</A>
</BODY>
</HTML>
The SaveName.jsp saves the user's name in the session, and puts a link to another page,
NextPage.jsp.
NextPage.jsp shows how to retrieve the saved name.
<HTML>
<BODY>
Hello, <%= session.getAttribute( "theName" ) %>
</BODY>
</HTML>
If you bring up two different browsers (not different windows of the same browser), or run two
browsers from two different machines, you can put one name in one browser and another name
in another browser, and both names will be kept track of.
The session is kept around until a timeout period. Then it is assumed the user is no longer
visiting the site, and the session is discarded.
Exercise: Add another attribute "age" to the above example.