struts tags speakernoted
DESCRIPTION
TRANSCRIPT
1
Struts Tag Library
.
2
Disclaimer & Acknowledgments? Even though Sang Shin is a full-time employees of Sun Microsystems, the
contents here are created as their own personal endeavor and thus does not reflect any official stance of Sun Microsystems.
? Sun Microsystems is not responsible for any inaccuracies in the contents.? Acknowledgments:
– Struts' user's guide is also used in creating slides and speaker notes– “Using the Struts framework” presentation material from Sue Spielman
of Switchback Software ([email protected])
3
Revision History? 11/10/2003: version 1: created by Sang Shin ? Things to do
– Speaker notes need to be added to some slides
4
Agenda? Struts tag libraries? Struts and JSTL? Struts-EL
This is the agenda. We will learn first what is and why Struts. Then we will look into Struts architecture as one that follows MVC pattern.
Struts comes with extensive tag library so we will learn how to use them. We will also learn how internationalization is done in Struts. We will learn how input form validation and error handling can be done. At the end, I will talk about “Struts console” tool that you can use to graphically edit Struts configuration file.
5
Struts Tag Libraries
6
Tag Libraries Overview? Number of taglibs included as part of Struts
– Usage is not required, but helpful? Bean tags
– Tags for accessing Beans and their properties ? Html tags
– Form bridge between JSP view and other components ? Logic tags
– Provides presentation logic tags that eliminate need for scriptlets? Template tags (Tiles in v1.1)
– Tags to form JSP templates that include parameterized content? Nested Tags (v1.1)
– Allows for object hierarchy– Helpful for rendering lists of lists
7
Access to Tag Libraries? All tag libraries are defined in web.xml using
<taglib> element
<!-- Struts Tag Library Descriptors --> <taglib> <taglib-uri>/WEB-INF/struts-bean.tld</taglib-uri> <taglib-location>/WEB-INF/struts-bean.tld</taglib-location> </taglib>
<taglib> <taglib-uri>/WEB-INF/struts-html.tld</taglib-uri> <taglib-location>/WEB-INF/struts-html.tld</taglib-location> </taglib>
…
As was mentioned before, the tag libraries need to be declared in web.xml deployment descriptor.
8
Bean Tags
9
Bean Tags? Tags for accessing beans and their
properties (not altering, however)? Enhancements to <jsp:useBean>
– Some of the attributes, for example id, name, property, and scope, share same meanings
? Convenient mechanisms to create new beans based on the value of:
– User entered parameters– Request headers– Cookies
The "struts-bean" tag library contains JSP custom tags useful in defining new beans (in any desired scope) from a variety of possible sources, as well as a tag to render a particular bean (or bean property) to the output response.
This tag library contains tags useful in accessing beans and their properties, as well as defining new beans (based on these accesses) that are accessible to the remainder of the page via scripting variables and page scope attributes. Convenient mechanisms to create new beans based on the value of request cookies, headers, and parameters are also provided.
10
Attributes of Bean Tags? id - define a bean? name - refer to an existing bean (the value is
either the value of an id attribute in a previous tag, or is found in application, session, request, or page scope)
? property - a property from a bean? scope - scope to search for the bean. If
scope is not specified then the bean is searched for in page, request, session and application order
The "struts-bean" tag library contains JSP custom tags useful in defining new beans (in any desired scope) from a variety of possible sources, as well as a tag to render a particular bean (or bean property) to the output response.
This tag library contains tags useful in accessing beans and their properties, as well as defining new beans (based on these accesses) that are accessible to the remainder of the page via scripting variables and page scope attributes. Convenient mechanisms to create new beans based on the value of request cookies, headers, and parameters are also provided.
11
Bean Tags
? <bean:define/>? <bean:write/>? <bean:message/>? <bean:include/>? <bean:resource/>? <bean:cookie>? <bean:header>? <bean:parameter>? <bean:size>
.
12
<bean:define/>
? For creating variables from beans and properties
– Without it, you would have to create Java code-based scripting variables in your JSP pages
? The variables are used later in the JSP page
? For exposing Java objects (i.e. Collections) that are created in a Action class to a JSP
.
13
Examples: <bean:define/>
? <bean:define id="string" value="Struts in Javaboutique"/>
– Get a bean with a String constant? <bean:define id="copy" name="dvd"/>
– Get an existing bean? <bean:define id="title" name="copy"
property="title"/>– Get a single property from a bean
.
14
Example1: favorites.jsp (ch 03)1 <c:forEach var="theColor" items="${FavoritesForm.colors}" varStatus="loopStatus">2 <bean:define id="ctr">3 <c:out value="${loopStatus.index}"/>4 </bean:define>5 <br/><html:text property='<%="color["+ctr+"]"%>'/>6 </c:forEach>
Here in this example, the lastname property of bean is rendered to output reponse being created by the JSP page.
15
Example2: view_favorites.jsp (ch 03)1 <bean:define id="favs" name="FavoritesForm"/>2 <script language="JavaScript">3 function showMessage() {4 alert( "Hello, <bean:write name='favs' property='name'/>!" );5 }6 </script>7 <p>8 Thanks for responding, <bean:write name="favs" property="name"/> !<br/>9 <a href="javascript:showMessage()">Click Me</a>10 </p>11 <p>You have indicated that your favorite colors are:12 <ul>13 <li><bean:write name="favs" property="color[0]"/></li>14 <li><bean:write name="favs" property="color[1]"/></li>15 <li><bean:write name="favs" property="color[2]"/></li>16 </ul>17 <ul>18 <c:forEach var="color" items="${favs.color}">19 <li><c:out value="${color}"/></li>20 </c:forEach>
Here in this example, the lastname property of bean is rendered to output reponse being created by the JSP page.
16
Example2: FovoritesForm Class (ch 03)1 public final class FavoritesForm extends ActionForm {2 3 private static String[] javaIdes = new String[] {"Eclipse", "IDEA", "JBuilder", "JDeveloper", "NetBeans"};4 private static String[] csharpIdes = new String[] {"SharpDevelop", "Visual Studio"};5 6 public FavoritesForm() {7 webLinks = new ArrayList();8 for (int i=0; i<5; i++) webLinks.add(new WebLink()); 9 colors = new String[3];10 colors[0]="Black";11 colors[1]="Blue";12 colors[2]="Red";13 }14 ...15 public String[] getColors() {16 return colors;17 }18 public void setColors(String[] colors) {
Here in this example, the lastname property of bean is rendered to output reponse being created by the JSP page.
17
<bean:write/>
? Use it to output the contents of a bean's property
? The information returned to the page is rendered as a String
? Use it to encode and unencode information
.
18
Example1: <bean:write/><jsp:useBean id="dvd" class="hansen.playground.DVD"
scope="request"/>
. . .
<jsp:getProperty name="dvd" property="title"/>
Using Struts you simply use the write tag:
<bean:write name="dvd" property="title" scope="request"/>
.
19
Example2: submitAction.java1 public final class SubmitAction extends Action {2 3 // The execute() method is where you provide your business logic4 public ActionForward execute(ActionMapping mapping,5 ActionForm form,6 HttpServletRequest request,7 HttpServletResponse response) {8 9 // Cast ActionForm object to SubmitForm type10 SubmitForm f = (SubmitForm) form;11 12 // Retrieve the value of lastname field13 String lastName = f.getLastName();14 15 // Translate the lastname to upper case and save it Request scope16 request.setAttribute("lastName", lastName.toUpperCase());17 18 // Create and return ActionForward object with "success" outcome19 return (mapping.findForward("success"));20 }21 }22
Here in this example, the lastname property of bean is rendered to output reponse being created by the JSP page.
20
Example2: submit.jsp1 <logic:present name="lastName" scope="request">2 Hello3 <logic:equal name="submitForm" property="age" value="a">4 young5 </logic:equal>6 <logic:equal name="submitForm" property="age" value="c">7 old8 </logic:equal>9 <bean:write name="lastName" scope="request"/>10 </logic:present>11 12 </body>13 </html>
Here in this example, the lastname property of bean is rendered to output reponse being created by the JSP page.
21
Example3: view_favorites.jsp (ch 03)1 <bean:define id="favs" name="FavoritesForm"/>2 <script language="JavaScript">3 function showMessage() {4 alert( "Hello, <bean:write name='favs' property='name'/>!" );5 }6 </script>7 <p>8 Thanks for responding, <bean:write name="favs" property="name"/> !<br/>9 <a href="javascript:showMessage()">Click Me</a>10 </p>11 <p>You have indicated that your favorite colors are:12 <ul>13 <li><bean:write name="favs" property="color[0]"/></li>14 <li><bean:write name="favs" property="color[1]"/></li>15 <li><bean:write name="favs" property="color[2]"/></li>16 </ul>17 <ul>18 <c:forEach var="color" items="${favs.color}">19 <li><c:out value="${color}"/></li>20 </c:forEach>
Here in this example, the lastname property of bean is rendered to output reponse being created by the JSP page.
22
<bean:message/>
? Looks up a key in the resource file
.
23
Example: index.jsp (ch 03)1 <html:html locale="true">2 <head>3 <title><bean:message key="index.title"/></title>4 <html:base/>5 </head>6 <body bgcolor="white">7 <h2>Struts Chapter 3 Examples</h2>8 9 <p>10 <bean:message key="msg.hello"/>11 </p>
Here in this example, the lastname property of bean is rendered to output reponse being created by the JSP page.
24
<bean:parameter/>
? Get a request parameter? Example
– <bean:parameter id="req" name="item" />
.
25
HTML Tags
26
HTML Tags? Form bridge between JSP view and other
components ? Input forms are important for gathering user-
entered data? Most of the actions of the HTML taglib involve
HTML forms? Error messages, hyperlinking,
internationalization
The tags in the Struts HTML library form a bridge between a JSP view and the other components of a Web application. Since a dynamic Web application often depends on gathering data from a user, input forms play an important role in the Struts framework. Consequently, the majority of the HTML tags involve HTML forms.
The HTML taglib contains tags used to create Struts input forms, as well as other tags generally useful in the creation of HTML-based user interfaces. The output is HTML 4.01 compliant or XHTML 1.0 when in XHTML mode.HTML Tag Resources
27
HTML Tags? checkboxes? hidden fields? password input fields? radio buttons? reset buttons? select lists with embedded option or options items? option? options? submit buttons? text input fields? textareas
This is the list of HTML tags that allowssome types of inputs from a user.
In every case, a field tag must be nested within a form tag, so that the field knows what bean to use for initializing displayed values.
28
HTML Tags
? <html:errors/>? <html:messages/>? <html:html>? <html:form>? <html:link>? <html:text>
.
29
<html:errors/>
? Simplest way to display error messages– It is expected that ActionErrors is created (either in
the validate() method of an ActionForm class or in execute() method of an Action class)
? Place the tag anywhere on the page you want the list of errors to be displayed
? Iterates over the errors writing unescaped contents to the page
– Messages need to have HTML tags, which are not desirable
.
30
Example: submit.jsp1 <%@ page language="java" %>2 <%@ taglib uri="/WEB-INF/struts-bean.tld" prefix="bean" %>3 <%@ taglib uri="/WEB-INF/struts-html.tld" prefix="html" %>4 <%@ taglib uri="/WEB-INF/struts-logic.tld" prefix="logic" %>5 6 <html>7 <head><title>Submit example</title></head>8 <body>9 10 <h3>Example Submit Page</h3>11 12 <html:errors/>13 14 <html:form action="submit.do">15 Last Name: <html:text property="lastName"/><br>16 Address: <html:textarea property="address"/><br>17 Sex: <html:radio property="sex" value="M"/>Male 18 <html:radio property="sex" value="F"/>Female<br>19 Married: <html:checkbox property="married"/><br>20 Age: <html:select property="age">21 <html:option value="a">0-19</html:option>22 <html:option value="b">20-49</html:option>23 <html:option value="c">50-</html:option>24 </html:select><br>
31
Example: ApplicationResources.properties1 errors.header=<h4>Validation Error(s)</h4><ul>2 3 error.lastName=<li>Enter your last name4 error.address=<li>Enter your address5 error.sex=<li>Enter your sex6 error.age=<li>Enter your age7 error.birthYear=<li>Enter the year you were born between 1900 and 2004 inclusive8 9 errors.footer=</ul><hr>
32
<html:messages/>
? Corrects the problem of <html:errors/>– Allows you to keep HTML tags in JSP pages not in
the resource file? By default, it looks for error messages
stored in the request scope? The id attribute defines the name of the
scripting variable used to expose the error message text
.
33
Logic Tags
34
Logic Tags
? Provides presentation logic tags that eliminate need for scriptlets
? Value comparisons Include: = != <= >= < >
? Substring matching– match, notmatch
? Presentation logic– forward, redirect
? Collections– iterate
The "struts-logic" tag library contains tags that are useful in managing conditional generation of output text, looping over object collections for repetitive generation of output text, and application flow management
35
Logic Tags
? <logic:present/>? <logic:equal/>
.
36
<logic:present/> & <logic:notPresent> tags? The body of the <logic:present/> tag is
evaluated whenever the JavaBean, or its property, is present within the JSP page
? Attributes for evaluation– name– parameter– cookie– header– property
.
37
Example: submit.jsp1 <logic:present name="lastName" scope="request">2 Hello3 <logic:equal name="submitForm" property="age" value="a">4 young5 </logic:equal>6 <logic:equal name="submitForm" property="age" value="c">7 old8 </logic:equal>9 <bean:write name="lastName" scope="request"/>10 </logic:present>11 12 </body>13 </html>
<
38
<logic:equal/> & <logic:notEqual> tags? Checks against a specific value in a bean? Assumes the bean exists
– Exception occurs if not? <logic:equal/> tag compares the bean's
toString() value aganst the value property? If property attribute is specified, then the
value attribute is compared against the bean's property
.
39
Example: submit.jsp1 <logic:present name="lastName" scope="request">2 Hello3 <logic:equal name="submitForm" property="age" value="a">4 young5 </logic:equal>6 <logic:equal name="submitForm" property="age" value="c">7 old8 </logic:equal>9 <bean:write name="lastName" scope="request"/>10 </logic:present>11 12 </body>13 </html>
<
40
Usage Example: <logic:equal/> & <logic:notEqual> tags? You want to present different messages or
buttons on a page depending upon the type of action you migt perform
? Example:– Depending what a user wants to do (mode) –
view, edit, or delete, you want to present different set of buttons
– View mode: Show only view button– Edit mode: Show view and edit buttons– Delete mode: Show only delete button
.
41
Example: subscription.jsp (ch 13)1 <html:html>2 <head>3 <logic:equal name="SubscriptionForm" property="action"4 scope="request" value="Create">5 <title><bean:message key="subscription.title.create"/></title>6 </logic:equal>7 <logic:equal name="SubscriptionForm" property="action"8 scope="request" value="Delete">9 <title><bean:message key="subscription.title.delete"/></title>10 </logic:equal>11 <logic:equal name="SubscriptionForm" property="action"12 scope="request" value="Edit">13 <title><bean:message key="subscription.title.edit"/></title>14 </logic:equal>15 <html:base/>
<
42
Template Tags
43
Template Tags
? Templates are JSP pages that include parameterized content
? Useful for creating dynamic JSP templates for pages that share a common format
? Functionality provided is similar to what can be achieved using the standard JSP include directive, but these tags allow for dynamic rather than static content
44
Template Tags? Three template tags work in an
interrelated function:
– Get - Gets the content from request scope that was put there by a put tag.
– Insert - Includes a template– Put - Puts content into request scope
45
Template sample (insert/put)
<template:insert template='/layout.jsp'> <template:put name='title'
content='CD Manager Logon‘/> <template:put name='header' content='/header.jsp' /> <template:put name='content‘
content='/logonContent.jsp'/> <template:put name='footer' content='/footer.jsp' />
</template:insert>
46
layout.jsp
<html><head> <title> <template:get name='title'/> </title></head> <body > <table> <tr><td> <template:get name='header'/> </td></tr> <tr><td> <template:get name='content'/> </td></tr> <tr><td> <template:get name='footer'/> </td></tr> </table> </body>
</html>
47
Struts andJSTL
48
When to JSTL in your Struts application?
? Developers should evaluate when to use the JSTL
? Many of the Struts taglib features are now available in the JSTL
? It’s simple: If the tag exists in the JSTL – use it
? Continue using the Struts tags where appropriate, they will continue to be supported
Some of the features in this taglib are also available in the JavaServer Pages Standard Tag Library (JSTL). The Struts team encourages the use of the standard tags over the Struts specific tags when possible.
49
Interaction with JSTL? Struts-el taglibs allow for using expression
values instead of just rtexprvalueRuntime: <bean:message key='<%= stringvar %>'/>
Expression: <bean-el:message key="${stringvar}"/>
? Set of optional taglibs that can be used with the JSTL expression language (EL)
? Implements many (but not all) of the Struts tags.
? Located in the contrib folder of the Struts release
? Container with servlet 2.3 support required
50
Struts ELTag library
51
Struts EL Extension? Extension of the Struts tag library? Uses the expression evaluation engine in the
Jakarta Taglibs implementation of the JSP Standard Tag Library (version 1.0) to evaluate attribute values
? Some of the Struts tags were not ported to this library
– their functionality was entirely supplied by the JSTL
? Requires the use of the Struts tag library, and the Java Server Pages Standard Tag Library
This subproject is an extension of the Struts tag library. Each JSP custom tag in this library is a subclass of an associated tag in the Struts tag library. One difference is that this tag library does not use "rtexprvalues", it uses the expression evaluation engine in the Jakarta Taglibs implementation of the JSP Standard Tag Library (version 1.0) to evaluate attribute values.
In addition, some of the Struts tags were not ported to this library, as it was determined that their functionality was entirely supplied by the JSTL. These particular Struts tags, and the reason for their non-porting will be described in the documentation for this library.
In order to fully understand the correct utilization of this library, you must understand the use and operation of the Struts tag library, and the use and operation of the JavaServer Pages Standard Tag Library (hereafter called the "JSTL"), along with the expression language (sometimes called the "EL") used for evaluating attribute values.
The Struts-EL tag library requires the use of the Struts tag library, and the Java Server Pages Standard Tag Library. It is not necessary for JSP pages using the Struts-EL tag library to also use the Struts tags or the JSTL tags, but the Struts and JSTL tag libraries need to be part of the application utilizing the Struts-EL tag library.
This is because the Struts-EL tag classes are all subclasses of Struts tag classes, and their implementation uses classes provided by the JSTL.
52
Tag Mapping
? Every Struts tag that provides a feature that is not covered by the JSTL (1.0) library is mapped into the Struts-EL library
? Bean Tag Library Tags NOT Implemented in Struts-EL
– cookie (in Struts): c:set, EL (in JSTL)– define (in Struts), c:set, EL (In JSTL)
In implementing the Struts-EL library, every Struts tag that provides a feature that is not covered by the JSTL (1.0) library is mapped into the Struts-EL library. This section reviews which Struts tags are NOT implemented in the Struts-EL library, and which JSTL tags provide that feature.
Many of the non-porting decisions were based on the fact that the JSTL expression language itself provides the same functionality. In those cases, in addition to a possible JSTL tag name, the symbol "EL" will be listed.
53
How to use Struts EL
? Struts– <bean:message key='<%= stringvar %>'/>
? Struts EL– <bean-el:message key="${stringvar}"/>
The Struts-EL tag library is a contributed library in the Struts distribution. It represents an integration of the Struts tag library with the JavaServer Pages Standard Tag Library, or at least the "expression evaluation" engine that is used by the JSTL.
The base Struts tag library contains tags which rely on the evaluation of "rtexprvalue"s (runtime scriptlet expressions) to evaluate dynamic attribute values. For instance, to print a message from a properties file based on a resource key, you would use the bean:write tag, perhaps like this:
<bean:message key='<%= stringvar %>'/>
This assumes that stringvar exists as a JSP scripting variable. If you're using the Struts-EL library, the reference looks very similar, but slightly different, like this:
<bean-el:message key="${stringvar}"/>
54
Best PracticeGuidelines
55
Follow Good MVC Practice
? JSP pages must “know” as little as possible about the back-end architecture
? JSP page should only concern itself with rendering the view and not manipulating any data logic
.
56
Passion!