Remember in the original MVC beer app,the Servlet controller talked to the model (Java class with business
logic),the set an attribute in request scope before forwarding to the JSP view.The JSP had to get the attribute
from the request scope,and use it to render a response to send back to the client.
Servlet(controller)code:
public void do_Post(HttpServletRequest request,HttpServletResponse response)
throws IOException,ServletException{
String name = request.getParameter("userName");
request.setAttribute("name",name);
RequestDispatcher view = request.getRequestDispatcher("/result.jsp");
view.forward(request,response);
}
JSP (view) code:
<html><body>
Hello
<%= request.getAttribute("name") %>
</body></html>
what if the attribute is not a String ,but an instance of Person?
Servlet(controller)code:
public void do_Post(HttpServletRequest request,HttpServletResponse response)
throws IOException,ServletException{
foo.Person p = new foo.Person();//foo.Person has getName()and setName(String) methods
p.setName("Evan");
request.setAttribute("person",p);
RequestDispatcher view = request.getRequestDispatcher("/result.jsp");
view.forward(request,response);
}
JSP (view) code:
<html><body>
<% foo.Person p = (foo.Person) request.getAttribute("person");%>
Person is:<%=p.getName() %>
</body></html>
OR using an expression:
<html><body>
Person is:<%=((foo.Person) request.getAttribute("person")).getName()%>
</body></html>
the way above,we used scripting.Now we 're with standard actions (no scripting)
JSP (view) code:
<html><body>
<jsp:useBean id="person" class="foo.Person" cope="request"/>
Person created by servlet:<jsp:getProperty name="person" property="name">
</body></html>
<jsp:useBean>can have a body!
if you put your setter code (<jsp:setProperty>)inside the body of <jsp:useBean>,the property setting is
conditional!In other words,the property values will be set only if a new beam is created ,If an existing bean
with that scope and id are found,the body of the tag will never run,so the property won't be reset from your
JSP code.If you don't specify a scope in either the <jsp:useBeam>or <jsp:getProperty>tags,the Container uses
the default of "page".
<jsp:useBean id="person" class="foo.Person" scope="page">
<jsp:setProperty name="person" property="name" value="Fred"/>
</jsp:useBean>
You can send a request parameter straight into a bean ,without scripting ,using the param attribute.The param
attribute lets you set the value of a bean property to the value of a request parameter .Just by naming the
request parameter!
<jsp:useBean id="person" type="foo.Person" class="foo.Employee">
<jsp:setProperty name="person" property="name" param="userName"/>
</jsp:useBean>
<html><body>
<form action=”TestBean.jsp”>
name: <input type=”text” name=”userName”>
ID#: <input type=”text” name=”userID”> <input type=”submit”> </form>
</body></html>
It gets even better...
all you have to do is make sure your form input field name (which becomes
the request parameter name) is the same as the property name in your bean. Then
in the <jsp:setProperty> tag, you don’t have to specify the param attribute. If you
name the property but don’t specify a value or param, you’re telling the Container to
get the value from a request parameter with a matching name.
We get to do THIS
<jsp:useBean id=”person” type=”foo.Person” class=”foo.Employee”>
<jsp:setProperty name=”person” property=”name” />
</jsp:useBean>
we change the HTML so that the input field name matches the property name.If the request parameter name matches
the bean property name, you don’t need to specify a value in the <jsp:setProperty> tag for that property.
making ALL the request parameter names match the bean property names.
We get to do this
<jsp:useBean id=”person” type=”foo.Person” class=”foo.Employee”>
<jsp:setProperty name=”person” property=”*” />
</jsp:useBean>
EL makes it easy to print nested properties... in other words, properties of properties!
This:
${person.dog.name}
Replaces this:
<%= ((foo.Person) request.getAttribute(“person”)).getDog().getName() %>
The syntax and range of the EL language are dirt simple. The tricky part is that some of EL looks like Java,
but behaves differently. You’ll see when we get to the [] operator in a moment. So you’ll find things that
wouldn’t work in Java but will work in EL, and vice-versa. Just don’t try to map Java language/syntax rules
onto EL. Think of EL as a way to access Java objects without using Java.
EL expressions are ALWAYS within curly braces, and prefi xed with the dollar sign:${person.name}
The first named variable in the expression is either an implicit object or an attribute.
${firstThing.secondThing}:the firstThing can be:EL implicit object or attribute
EL implicit object:
pageScope //it is map object.
requestScope //it is map object.
sessionScope //it is map object.
applicationScope //it is map object.
param //it is map object.
paramValues //it is map object.
header //it is map object.
headerValues //it is map object.
cookie //it is map object.
initParam //it is map object.
pageContext //of all the implicit objects ,only pageContext is not a map.It's an actual reference to the
pageContext object!pageContext is a JavaBean.
attribute:if the first thing in the EL expression ia an attribute,it can be the name of an attribute stored in
any of the four available scopes:
in page scope
in request scope
in session scope
in application scope
note:EL implicit objects are not the same as the implicit objects available to JSP scripting,except for
pageContext.
A map is a collection that holds key/value pairs ,like Hashtable and HashMap.
Using the dot (.) operator to access properties and map values.The first variable is either an implicit object
or an attribute, and the thing to the right of the dot is either a map key (if the first variable is a map) or
a bean property if the first variable is an attribute that's a JavaBean.
The [] operator is like the dot only way better. The dot operator works only when the thing on the right is a
bean property or map key for the thing on the left. That’s it. But the [ ] operator is a lot more powerful and
flexible...
If the expression has a variable followed by a bracket [ ], the left-hand variable can be a Map, a bean, a
List, or an array.
If the thing inside the brackets is a String literal (i.e., in quotes), it can be a Map key or a bean property,
or an index into a List or array.
Using the [] operator with an array.
In a Servlet:
String[] favoriteMusic = {“Zero 7”, “Tahiti 80”, “BT”, “Frou Frou”};
request.setAttribute(“musicList”, favoriteMusic);
In a JSP:
First song is: ${musicList[0]} //or First song is: ${musicList["0"]} A String index is coerced to an int for
arrays and Lists
The EL for accessing an array is the same as the EL for accessing a List.this is NOT Java. In EL, the [ ]
operator is NOT the array access operator. No, it’s just called the [ ] operator. (We swear, look it up in the
spec—it has no name! Just the symbol [ ]. Like Prince, kind of.) If it DID have a name, it would be the
array/List/Map/bean Property access operator.
Obviously ArrayList has a nice overridden toString().
For beans and Maps you can use either operator,For JavaBeans and Maps, you can use either the [] operator or
the convenient dot operator. Just think of map keys the same way you think of property names in a bean.
You ask for the key or property name, and you get back the value of the key or property.
In a Servlet:
java.util.Map musicMap = new java.util.HashMap();
musicMap.put(“Ambient”, “Zero 7”);
musicMap.put(“Surf”, “Tahiti 80”);
musicMap.put(“DJ”, “BT”);
musicMap.put(“Indie”, “Travis”);
request.setAttribute(“musicMap”, musicMap);
In a JSP:
Ambient is: ${musicMap.Ambient} //or Ambient is: ${musicMap[“Ambient”]}
eg:
In a servlet:
java.util.Map musicMap = new java.util.HashMap();
musicMap.put(“Ambient”, “Zero 7”);
musicMap.put(“Surf”, “Tahiti 80”);
musicMap.put(“DJ”, “BT”);
musicMap.put(“Indie”, “Frou Frou”);
request.setAttribute(“musicMap”, musicMap);
String[] musicTypes = {“Ambient”, “Surf”, “DJ”, “Indie”};
request.setAttribute(“MusicType”, musicTypes);
In a Jsp:
This DOES work in a JSP
Music is ${musicMap[MusicType[0]]}
The param implicit object is fine when you know you have only one parameter for that particular parameter name.
Use paramValues when you might have more than one parameter value for a given parameter name.
In the HTML form:
<form action=”TestBean.jsp”>
Name: <input type=”text” name=”name”>
ID#: <input type=”text” name=”empID”>
First food: <input type=”text” name=”food”>
Second food: <input type=”text” name=”food”>
<input type=”submit”>
</form>
In the JSP:
Request param name is: ${param.name}
Request param empID is: ${param.empID}
Request param food is: ${param.food}
First food request param: ${paramValues.food[0]}
Second food request param: ${paramValues.food[1]}
Request param name: ${paramValues.name[0]}
Getting the “host” header,We know we can do it with scripting
Host is: <%= request.getHeader(“host”) %>
But with EL, we’ve got the header implicit object
Host is: ${header[“host”]}
Host is: ${header.host}
The header implicit object keeps a Map of all the headers. Use either access operator to pass in the header
name and the value of that header will print. (Note: there’s also a headerValues implicit object for headers
with multiple values. It works just like paramValues.)
Getting the HTTP request method,We know we can do it with scripting.
Method is: <%= request.getMethod() %>
Method is: ${request.method} //this will NOT work,There IS no implicit request object!
Method is: ${requestScope.method} //There IS an implicit requestScope, but it’s NOT the request object
itself.The requestScope is NOT the request object.The implicit requestScope is just a Map of the request scope
attributes,not the request object itself!Use pageContext to get to everything else...
Method is: ${pageContext.request.method}//pageContext has a request property,request has a method property
If all you need is to print the name of a person, and you really don’t care what scope the person is in (or,
you do care, but you know there’s only one person out of all four scopes), you just use:${person.name}
Or, if you’re worried about a potential naming conflict, you can be explicit about which person you want:
${requestScope.person.name}
note:if you have a name that’s not in quotes in brackets [ ], that means it MUST adhere to Java naming rules,
right? Here, we’re OK, because person is a perfectly legal Java variable name. But that’s because somewhere,
someone said,
request.setAttribute(“person”, p);
But an attribute name is a String!
Strings don’t follow Java variable name rules!
That means someone could say:
request.setAttribute(“foo.person”, p);
And then you’d be in trouble, because THIS won’t work:
${foo.person.name}//This is certainly legal, but the Container just thinks that “foo” is an attribute
somewhere, with a “person” property. But the Container never finds a “foo” attribute.
But you’ll be so thankful for scope objects, because using a scope object lets you switch to the [ ] operator,
that can take String names that don’t conform to Java naming rules.
request.setAttribute(“foo.person”, p);
{requestScope[“foo.person”].name}
Getting Cookies and init params
We’ve looked at all the implicit objects except cookies and init params, so here we are. the request object
does NOT have a getCookie(cookieName) method! We have to get the whole Cookie array and iterate through it
ourselves.We know we can do it with scripting:
<% Cookie[] cookies = request.getCookies();
for (int i = 0; i < cookies.length; i++) {
if ((cookies[i].getName()).equals(“userName”)) {
out.println(cookies[i].getValue());
}
} %>
But with EL, we’ve got the Cookie implicit object
${ cookie.userName.value}
Printing the value of the “userName” Cookie.Just give it the name, and the value comes back from the Map of
Cookie names/values.this is how you configure context (app-wide) parameters. These are NOT the same as servlet
init params.We have to configure the parameter in the DD:
<context-param>
<param-name>mainEmail</param-name>
<param-value>likewecare@wickedlysmart.com</param-value>
</context-param>
Printing the value of a context init parameter ,We know we can do it with scripting
email is: <%= application.getInitParameter(“mainEmail”) %>
And with EL, it’s even easier:
email is: ${ initParam.mainEmail}
about EL functions:
1.Write a Java class with a public static method.The method MUST be public and static, and it can have
arguments. It should (but isn’t required to) have a non-void return type. After all, the whole point is to
call this from a JSP and get something back that you can use as part of the expression or to print out.
package foo;
public class DiceRoller {
public static int rollDice() {
return (int) ((Math.random() * 6) + 1);
}
}
2.Write a Tag Library Descriptor (TLD) file.For an EL function, the TLD provides a mapping between the Java
class that defines the function and the JSP that calls the function.That way, the function name and the actual
method name can be different.Put the TLD file inside the /WEB-INF directory. Name it with a .tld xtension.maybe
you want to provide a more obvious or intuitive name to page designers using EL. No problem—the TLD says,
“This is the Java class, this is the method signature for the function (including return type) and this is the
name we’ll use in EL expressions”.
The Tag Library Descriptor (TLD) file:
<?xml version=”1.0” encoding=”ISO-8859-1” ?>
< taglib xmlns=”http://java.sun.com/xml/ns/j2ee”
xmlns:xsi=”http://www.w3.org/2001/XMLSchema-instance”
xsi:schemaLocation=”http://java.sun.com/xml/ns/j2ee/web-
jsptaglibrary_2_0.xsd” version=”2.0”>
<tlib-version>1.2</tlib-version>
<uri>DiceFunctions</uri>
<function>
<name>rollIt</name>
<function-class>foo.DiceRoller</function-class>
<function-signature>
int rollDice()
</function-signature>
</function>
</taglib>
3.Put a taglib directive in your JSP.The taglib directive tells the Container, “I’m going to use this TLD,
and in the JSP, when I want to use a function from this TLD, I’m going to prefix it with this name...” In
other words, it lets you define the namespace. You can use functions from more than one TLD, and even if the
functions have the same name, that’s OK. The taglib directive is kind of like giving all your functions
fully-qualified names. You invoke the function by giving both the function name AND the TLD prefix. The prefix
can be anything you like.
The JSP
<%@ taglib prefix=”mine” uri=”DiceFunctions”%>
<html><body>
${mine:rollIt()}
</body></html>
4.Use EL to invoke the function.
EL artithmetic, relational, and logical operators:
Addition: +
Subtraction: -
Multiplication: *
Division: / and div
Remainder: % and mod
Logical (3)
AND: && and and
OR: || and or
NOT: ! and not
Relational (6)
Equals: == and eq
Not equals: != and ne
Less than: < and lt
Greater than: > and gt
Less than or equal to: <= and le
Greater than or equal to: >= and ge
${num > 3}
logic),the set an attribute in request scope before forwarding to the JSP view.The JSP had to get the attribute
from the request scope,and use it to render a response to send back to the client.
Servlet(controller)code:
public void do_Post(HttpServletRequest request,HttpServletResponse response)
throws IOException,ServletException{
String name = request.getParameter("userName");
request.setAttribute("name",name);
RequestDispatcher view = request.getRequestDispatcher("/result.jsp");
view.forward(request,response);
}
JSP (view) code:
<html><body>
Hello
<%= request.getAttribute("name") %>
</body></html>
what if the attribute is not a String ,but an instance of Person?
Servlet(controller)code:
public void do_Post(HttpServletRequest request,HttpServletResponse response)
throws IOException,ServletException{
foo.Person p = new foo.Person();//foo.Person has getName()and setName(String) methods
p.setName("Evan");
request.setAttribute("person",p);
RequestDispatcher view = request.getRequestDispatcher("/result.jsp");
view.forward(request,response);
}
JSP (view) code:
<html><body>
<% foo.Person p = (foo.Person) request.getAttribute("person");%>
Person is:<%=p.getName() %>
</body></html>
OR using an expression:
<html><body>
Person is:<%=((foo.Person) request.getAttribute("person")).getName()%>
</body></html>
the way above,we used scripting.Now we 're with standard actions (no scripting)
JSP (view) code:
<html><body>
<jsp:useBean id="person" class="foo.Person" cope="request"/>
Person created by servlet:<jsp:getProperty name="person" property="name">
</body></html>
<jsp:useBean>can have a body!
if you put your setter code (<jsp:setProperty>)inside the body of <jsp:useBean>,the property setting is
conditional!In other words,the property values will be set only if a new beam is created ,If an existing bean
with that scope and id are found,the body of the tag will never run,so the property won't be reset from your
JSP code.If you don't specify a scope in either the <jsp:useBeam>or <jsp:getProperty>tags,the Container uses
the default of "page".
<jsp:useBean id="person" class="foo.Person" scope="page">
<jsp:setProperty name="person" property="name" value="Fred"/>
</jsp:useBean>
You can send a request parameter straight into a bean ,without scripting ,using the param attribute.The param
attribute lets you set the value of a bean property to the value of a request parameter .Just by naming the
request parameter!
<jsp:useBean id="person" type="foo.Person" class="foo.Employee">
<jsp:setProperty name="person" property="name" param="userName"/>
</jsp:useBean>
<html><body>
<form action=”TestBean.jsp”>
name: <input type=”text” name=”userName”>
ID#: <input type=”text” name=”userID”> <input type=”submit”> </form>
</body></html>
It gets even better...
all you have to do is make sure your form input field name (which becomes
the request parameter name) is the same as the property name in your bean. Then
in the <jsp:setProperty> tag, you don’t have to specify the param attribute. If you
name the property but don’t specify a value or param, you’re telling the Container to
get the value from a request parameter with a matching name.
We get to do THIS
<jsp:useBean id=”person” type=”foo.Person” class=”foo.Employee”>
<jsp:setProperty name=”person” property=”name” />
</jsp:useBean>
we change the HTML so that the input field name matches the property name.If the request parameter name matches
the bean property name, you don’t need to specify a value in the <jsp:setProperty> tag for that property.
making ALL the request parameter names match the bean property names.
We get to do this
<jsp:useBean id=”person” type=”foo.Person” class=”foo.Employee”>
<jsp:setProperty name=”person” property=”*” />
</jsp:useBean>
EL makes it easy to print nested properties... in other words, properties of properties!
This:
${person.dog.name}
Replaces this:
<%= ((foo.Person) request.getAttribute(“person”)).getDog().getName() %>
The syntax and range of the EL language are dirt simple. The tricky part is that some of EL looks like Java,
but behaves differently. You’ll see when we get to the [] operator in a moment. So you’ll find things that
wouldn’t work in Java but will work in EL, and vice-versa. Just don’t try to map Java language/syntax rules
onto EL. Think of EL as a way to access Java objects without using Java.
EL expressions are ALWAYS within curly braces, and prefi xed with the dollar sign:${person.name}
The first named variable in the expression is either an implicit object or an attribute.
${firstThing.secondThing}:the firstThing can be:EL implicit object or attribute
EL implicit object:
pageScope //it is map object.
requestScope //it is map object.
sessionScope //it is map object.
applicationScope //it is map object.
param //it is map object.
paramValues //it is map object.
header //it is map object.
headerValues //it is map object.
cookie //it is map object.
initParam //it is map object.
pageContext //of all the implicit objects ,only pageContext is not a map.It's an actual reference to the
pageContext object!pageContext is a JavaBean.
attribute:if the first thing in the EL expression ia an attribute,it can be the name of an attribute stored in
any of the four available scopes:
in page scope
in request scope
in session scope
in application scope
note:EL implicit objects are not the same as the implicit objects available to JSP scripting,except for
pageContext.
A map is a collection that holds key/value pairs ,like Hashtable and HashMap.
Using the dot (.) operator to access properties and map values.The first variable is either an implicit object
or an attribute, and the thing to the right of the dot is either a map key (if the first variable is a map) or
a bean property if the first variable is an attribute that's a JavaBean.
The [] operator is like the dot only way better. The dot operator works only when the thing on the right is a
bean property or map key for the thing on the left. That’s it. But the [ ] operator is a lot more powerful and
flexible...
If the expression has a variable followed by a bracket [ ], the left-hand variable can be a Map, a bean, a
List, or an array.
If the thing inside the brackets is a String literal (i.e., in quotes), it can be a Map key or a bean property,
or an index into a List or array.
Using the [] operator with an array.
In a Servlet:
String[] favoriteMusic = {“Zero 7”, “Tahiti 80”, “BT”, “Frou Frou”};
request.setAttribute(“musicList”, favoriteMusic);
In a JSP:
First song is: ${musicList[0]} //or First song is: ${musicList["0"]} A String index is coerced to an int for
arrays and Lists
The EL for accessing an array is the same as the EL for accessing a List.this is NOT Java. In EL, the [ ]
operator is NOT the array access operator. No, it’s just called the [ ] operator. (We swear, look it up in the
spec—it has no name! Just the symbol [ ]. Like Prince, kind of.) If it DID have a name, it would be the
array/List/Map/bean Property access operator.
Obviously ArrayList has a nice overridden toString().
For beans and Maps you can use either operator,For JavaBeans and Maps, you can use either the [] operator or
the convenient dot operator. Just think of map keys the same way you think of property names in a bean.
You ask for the key or property name, and you get back the value of the key or property.
In a Servlet:
java.util.Map musicMap = new java.util.HashMap();
musicMap.put(“Ambient”, “Zero 7”);
musicMap.put(“Surf”, “Tahiti 80”);
musicMap.put(“DJ”, “BT”);
musicMap.put(“Indie”, “Travis”);
request.setAttribute(“musicMap”, musicMap);
In a JSP:
Ambient is: ${musicMap.Ambient} //or Ambient is: ${musicMap[“Ambient”]}
eg:
In a servlet:
java.util.Map musicMap = new java.util.HashMap();
musicMap.put(“Ambient”, “Zero 7”);
musicMap.put(“Surf”, “Tahiti 80”);
musicMap.put(“DJ”, “BT”);
musicMap.put(“Indie”, “Frou Frou”);
request.setAttribute(“musicMap”, musicMap);
String[] musicTypes = {“Ambient”, “Surf”, “DJ”, “Indie”};
request.setAttribute(“MusicType”, musicTypes);
In a Jsp:
This DOES work in a JSP
Music is ${musicMap[MusicType[0]]}
The param implicit object is fine when you know you have only one parameter for that particular parameter name.
Use paramValues when you might have more than one parameter value for a given parameter name.
In the HTML form:
<form action=”TestBean.jsp”>
Name: <input type=”text” name=”name”>
ID#: <input type=”text” name=”empID”>
First food: <input type=”text” name=”food”>
Second food: <input type=”text” name=”food”>
<input type=”submit”>
</form>
In the JSP:
Request param name is: ${param.name}
Request param empID is: ${param.empID}
Request param food is: ${param.food}
First food request param: ${paramValues.food[0]}
Second food request param: ${paramValues.food[1]}
Request param name: ${paramValues.name[0]}
Getting the “host” header,We know we can do it with scripting
Host is: <%= request.getHeader(“host”) %>
But with EL, we’ve got the header implicit object
Host is: ${header[“host”]}
Host is: ${header.host}
The header implicit object keeps a Map of all the headers. Use either access operator to pass in the header
name and the value of that header will print. (Note: there’s also a headerValues implicit object for headers
with multiple values. It works just like paramValues.)
Getting the HTTP request method,We know we can do it with scripting.
Method is: <%= request.getMethod() %>
Method is: ${request.method} //this will NOT work,There IS no implicit request object!
Method is: ${requestScope.method} //There IS an implicit requestScope, but it’s NOT the request object
itself.The requestScope is NOT the request object.The implicit requestScope is just a Map of the request scope
attributes,not the request object itself!Use pageContext to get to everything else...
Method is: ${pageContext.request.method}//pageContext has a request property,request has a method property
If all you need is to print the name of a person, and you really don’t care what scope the person is in (or,
you do care, but you know there’s only one person out of all four scopes), you just use:${person.name}
Or, if you’re worried about a potential naming conflict, you can be explicit about which person you want:
${requestScope.person.name}
note:if you have a name that’s not in quotes in brackets [ ], that means it MUST adhere to Java naming rules,
right? Here, we’re OK, because person is a perfectly legal Java variable name. But that’s because somewhere,
someone said,
request.setAttribute(“person”, p);
But an attribute name is a String!
Strings don’t follow Java variable name rules!
That means someone could say:
request.setAttribute(“foo.person”, p);
And then you’d be in trouble, because THIS won’t work:
${foo.person.name}//This is certainly legal, but the Container just thinks that “foo” is an attribute
somewhere, with a “person” property. But the Container never finds a “foo” attribute.
But you’ll be so thankful for scope objects, because using a scope object lets you switch to the [ ] operator,
that can take String names that don’t conform to Java naming rules.
request.setAttribute(“foo.person”, p);
{requestScope[“foo.person”].name}
Getting Cookies and init params
We’ve looked at all the implicit objects except cookies and init params, so here we are. the request object
does NOT have a getCookie(cookieName) method! We have to get the whole Cookie array and iterate through it
ourselves.We know we can do it with scripting:
<% Cookie[] cookies = request.getCookies();
for (int i = 0; i < cookies.length; i++) {
if ((cookies[i].getName()).equals(“userName”)) {
out.println(cookies[i].getValue());
}
} %>
But with EL, we’ve got the Cookie implicit object
${ cookie.userName.value}
Printing the value of the “userName” Cookie.Just give it the name, and the value comes back from the Map of
Cookie names/values.this is how you configure context (app-wide) parameters. These are NOT the same as servlet
init params.We have to configure the parameter in the DD:
<context-param>
<param-name>mainEmail</param-name>
<param-value>likewecare@wickedlysmart.com</param-value>
</context-param>
Printing the value of a context init parameter ,We know we can do it with scripting
email is: <%= application.getInitParameter(“mainEmail”) %>
And with EL, it’s even easier:
email is: ${ initParam.mainEmail}
about EL functions:
1.Write a Java class with a public static method.The method MUST be public and static, and it can have
arguments. It should (but isn’t required to) have a non-void return type. After all, the whole point is to
call this from a JSP and get something back that you can use as part of the expression or to print out.
package foo;
public class DiceRoller {
public static int rollDice() {
return (int) ((Math.random() * 6) + 1);
}
}
2.Write a Tag Library Descriptor (TLD) file.For an EL function, the TLD provides a mapping between the Java
class that defines the function and the JSP that calls the function.That way, the function name and the actual
method name can be different.Put the TLD file inside the /WEB-INF directory. Name it with a .tld xtension.maybe
you want to provide a more obvious or intuitive name to page designers using EL. No problem—the TLD says,
“This is the Java class, this is the method signature for the function (including return type) and this is the
name we’ll use in EL expressions”.
The Tag Library Descriptor (TLD) file:
<?xml version=”1.0” encoding=”ISO-8859-1” ?>
< taglib xmlns=”http://java.sun.com/xml/ns/j2ee”
xmlns:xsi=”http://www.w3.org/2001/XMLSchema-instance”
xsi:schemaLocation=”http://java.sun.com/xml/ns/j2ee/web-
jsptaglibrary_2_0.xsd” version=”2.0”>
<tlib-version>1.2</tlib-version>
<uri>DiceFunctions</uri>
<function>
<name>rollIt</name>
<function-class>foo.DiceRoller</function-class>
<function-signature>
int rollDice()
</function-signature>
</function>
</taglib>
3.Put a taglib directive in your JSP.The taglib directive tells the Container, “I’m going to use this TLD,
and in the JSP, when I want to use a function from this TLD, I’m going to prefix it with this name...” In
other words, it lets you define the namespace. You can use functions from more than one TLD, and even if the
functions have the same name, that’s OK. The taglib directive is kind of like giving all your functions
fully-qualified names. You invoke the function by giving both the function name AND the TLD prefix. The prefix
can be anything you like.
The JSP
<%@ taglib prefix=”mine” uri=”DiceFunctions”%>
<html><body>
${mine:rollIt()}
</body></html>
4.Use EL to invoke the function.
EL artithmetic, relational, and logical operators:
Addition: +
Subtraction: -
Multiplication: *
Division: / and div
Remainder: % and mod
Logical (3)
AND: && and and
OR: || and or
NOT: ! and not
Relational (6)
Equals: == and eq
Not equals: != and ne
Less than: < and lt
Greater than: > and gt
Less than or equal to: <= and le
Greater than or equal to: >= and ge
${num > 3}
发表评论
-
PageContext Reference
2014-04-12 13:16 716Using a PageContext reference t ... -
Aplication Request Session Page scopes
2014-04-12 12:08 496The most of the time you'll be ... -
jsb scriptlet directive expression
2014-04-12 11:44 577scriptlet: <% %> direct ... -
implicit object
2014-04-09 14:15 508When a Container translates the ... -
Session lifecycle events
2014-04-12 10:31 419The sesssin was created: when t ... -
Setting session timeout
2014-04-08 19:56 518Two ways to set session timeout ... -
Key HttpSession method
2014-04-08 19:16 460getCreationTime() //returns t ... -
what if I want to know whether the session already existed or was just created?
2014-04-08 11:54 417Put the following code into you ... -
How session work and how the Container know who the client is
2014-04-08 09:44 424How session work 1.when Diane ... -
How can we track the client's answers?
2014-04-08 08:28 458We have serveral options: 1.Use ... -
encodeURL and encodeRedirectURL
2014-04-06 19:45 1002If the client doesn't accept co ... -
What if you only want a pre-existing session?
2014-04-06 18:51 515HttpSession session = request.g ...
相关推荐
《使用JSP/Servlet/Ajax技术开发新闻发布系统》 内部测试-笔试试卷 一、选择题(共25题,每题2分,... {EL expression} B. ${EL expression} C. @{EL expression} D. &{EL expression} 2) 在Servlet中有如下代码段:
JSP-EL 表达式是一种用于简化在 JSP 中访问变量的方式的表达式语言,Full Name 称为 Expression Language。JSP-EL 表达式的主要目的是简化静态 HTML 与 Java 代码的耦合,提供了一个灵活的方式来访问变量和对象。 ...
在提供的资源“ELExpression”中,可能包含了以下6个JSP EL表达式的基础实践案例: 1. **基础变量输出**:展示如何直接输出一个简单的变量值,如`${message}`。 2. **JavaBean属性访问**:通过`${user.name}`展示...
1. **EL表达式语法**:EL表达式的典型形式是`${EL Expression}`,其中`EL Expression`是需要求值的表达式。EL表达式可以插入到JSP页面的静态内容中,也可以在标准标签和自定义标签中使用。 2. **EL的用途**: - **...
EL(Expression Language)表达式是JavaServer Pages (JSP)技术中的一个重要组成部分,它用于简化JSP页面中的数据访问和处理。EL表达式通常用`${ }`括起来,旨在替代复杂的Java脚本,使得HTML和JSP标签的交互更加...
EL 表达式的语法结构是 ${expression},其中 expression 可以是变量、常量、隐式对象等。EL 提供 . 和 [] 两种运算符来存取数据。当要存取的属性名称中包含一些特殊字符,如 . 或 ? 等非字母或数字的符号,就一定要...
EL全名Expression Language EL 语法结构: ${ session.user.sex};所有EL都是以${为起始以}为结尾的; 上述语句等同于User user = (User)session.getAttribute(“user”);String sex=user.getSex(); 即在session中...
JSP表达式语言(Expression Language,简称EL)是一种强大的工具,允许开发者在JSP页面中轻松地访问和操作JavaBeans或其他Java对象的属性。 1. **JavaBean**:JavaBean是Java编程语言中的一种可重用组件,它遵循...
启动Tomcat时报错:Caused by: java.lang.LinkageError: loader constraints violated when linking javax/el/ExpressionFactory class 说明:原因是juel.jar, juel-engine.jar, juel-impl.jar包和Tomcat6.0中的el-...
在Java世界中,EL(Expression Language)是一种强大的脚本语言,用于在JSP(JavaServer Pages)和其他Java EE组件中简化数据访问和方法调用。它允许开发者通过简洁的表达式来访问Java对象的属性和调用方法,而无需...
本篇将深入探讨JSP表达式语言(Expression Language,简称EL),这是一种简洁而强大的脚本语言,用于访问和操作JavaBean或其他Java对象的属性。 1. **回顾JavaBean与JSP动作** JavaBean是Java平台上的可重用组件,...
EL(Expression Language)标签是JavaServer Pages (JSP) 技术的一部分,它提供了一种简单的方式来访问和操作JavaBeans组件中的属性。EL表达式语言是JSP 2.0及更高版本中引入的一种强大而灵活的数据绑定工具,用于...
开发语言:Java、HTML、JavaScript、EL Expression 程序类型:Web类B/S应用程序 运用框架:Spring framework,Spring MVC,Mybatis 开发工具:Maven 项目功能描述 本项目主要是对旅游网站的新闻、目录进行增删改查的...
《EL手册》是关于EL(Expression Language)的详尽指南,它是Java EE应用程序开发中的一个重要组成部分,主要用于在JSP(JavaServer Pages)和其他Java web组件中进行数据绑定和表达式处理。EL语言的设计目的是简化...
JSP表达式语言的语法是 ${EL expression}。 2. Servlet生命周期:Servlet生命周期包括加载、初始化、就绪、服务和销毁五个阶段。Servlet容器负责加载和创立Servlet,并调用init()方法初始化Servlet。Servlet初始化...
8. JSP表达式语言(EL):EL的语法是`${EL expression}`,用于简洁地从JSP页面中获取和输出数据。 9. JSTL(JavaServer Pages Standard Tag Library):`<c:forEach>`是JSTL中的循环标签,用于遍历集合。在这个例子...
EL 表达式的语法非常简单,基本语法结构为:${expression},其中 expression 是一个有效的 EL 表达式。EL 表达式可以访问 Java 对象的属性,例如:${user.name},访问 User 对象的 name 属性。 三、EL 表达式的作用...
在Java Web开发中,`el-api.jar` 和 `el-ri.jar` 是两个非常关键的库文件,它们与表达式语言(Expression Language, EL)有关。EL是JavaServer Pages(JSP)技术的一个组成部分,主要用于简化JSP页面中的数据绑定和...
EL 表达式的基本语法结构为 `${expression}`,其中 `expression` 是一个 EL 表达式。EL 提供了两种运算符来存取数据:`.` 和 `[]`。`.`运算符用于访问对象的属性,而 `[]` 运算符用于访问对象的属性,其中属性名称中...
eval-expression 是使用 ${expr} 或者 #{expr} 结构的形式构成,literal-expression 是不使用 ${expr} 或者 #{expr} 结构的形式构成,而 Composite expressions 是多个 EL 表达式的聚合。 1.1.1 Eval-expression ...