JavaBeans Components
JavaBeans components are Java classes that can be easily reused and composed together into applications. Any Java class that follows certain design conventions is a JavaBeans component.
JavaServer Pages technology directly supports using JavaBeans components with standard JSP language elements. You can easily create and initialize beans and get and set the values of their properties.
JavaBeans Component Design Conventions
JavaBeans component design conventions govern the properties of the class and govern the public methods that give access to the properties.
A JavaBeans component property can be
A property does not have to be implemented by an instance variable. It must simply be accessible using public methods that conform to the following conventions:
In addition to the property methods, a JavaBeans component must define a constructor that takes no parameters.
The Duke's Bookstore application JSP pages
bookstore.jsp
,bookdetails.jsp
,catalog.jsp
, andshowcart.jsp
use thecom.sun.bookstore2.database.BookDB
andcom.sun.bookstore2.database.BookDetails
JavaBeans components.BookDB
provides a JavaBeans component front end to the access objectBookDBAO
. The JSP pagesshowcart.jsp
andcashier.jsp
access the beancom.sun.bookstore.cart.ShoppingCart
, which represents a user's shopping cart.The
BookDB
bean has two writable properties,bookId
anddatabase
, and three readable properties:bookDetails
,numberOfBooks
, andbooks
. These latter properties do not correspond to any instance variables but rather are a function of thebookId
anddatabase
properties.package database; public class BookDB { private String bookId = "0"; private BookDBAO database = null; public BookDB () { } public void setBookId(String bookId) { this.bookId = bookId; } public void setDatabase(BookDBAO database) { this.database = database; } public Book getBook() throws BookNotFoundException { return (Book)database.getBook(bookId); } public List getBooks() throws BooksNotFoundException { return database.getBooks(); } public void buyBooks(ShoppingCart cart) throws OrderException { database.buyBooks(cart); } public int getNumberOfBooks() throws BooksNotFoundException { return database.getNumberOfBooks(); } }Creating and Using a JavaBeans Component
To declare that your JSP page will use a JavaBeans component, you use a
jsp:useBean
element. There are two forms:and
<jsp:useBean id="beanName
" class="fully_qualified_classname
" scope="scope
"> <jsp:setProperty .../> </jsp:useBean>The second form is used when you want to include
jsp:setProperty
statements, described in the next section, for initializing bean properties.The
jsp:useBean
element declares that the page will use a bean that is stored within and is accessible from the specified scope, which can beapplication
,session
,request
, orpage
. If no such bean exists, the statement creates the bean and stores it as an attribute of the scope object (see Using Scope Objects, page 64). The value of theid
attribute determines the name of the bean in the scope and the identifier used to reference the bean in EL expressions, other JSP elements, and scripting expressions (see Chapter 8). The value supplied for theclass
attribute must be a fully qualified class name. Note that beans cannot be in the unnamed package. Thus the format of the value must bepackage_name.class_name
.The following element creates an instance of
mypkg.myLocales
if none exists, stores it as an attribute of the application scope, and makes the bean available throughout the application by the identifierlocales
:Setting JavaBeans Component Properties
The standard way to set JavaBeans component properties in a JSP page is by using the
jsp:setProperty
element. The syntax of thejsp:setProperty
element depends on the source of the property value. Table 4-6 summarizes the various ways to set a property of a JavaBeans component using thejsp:setProperty
element.
A property set from a constant string or request parameter must have one of the types listed in Table 4-7. Because constants and request parameters are strings, the web container automatically converts the value to the property's type; the conversion applied is shown in the table.
String
values can be used to assign values to a property that has aPropertyEditor
class. When that is the case, thesetAsText(String)
method is used. A conversion failure arises if the method throws anIllegalArgumentException
.The value assigned to an indexed property must be an array, and the rules just described apply to the elements.
You use an expression to set the value of a property whose type is a compound Java programming language type. The type returned from an expression must match or be castable to the type of the property.
The Duke's Bookstore application demonstrates how to use the
setProperty
element to set the current book from a request parameter in the database bean inbookstore2/web/bookdetails.jsp
:<c:set var="bid" value="${param.bookId}"/> <jsp:setProperty name="bookDB" property="bookId" value="${bid}" />The following fragment from the page
bookstore2/web/bookshowcart.jsp
illustrates how to initialize aBookDB
bean with adatabase
object. Because the initialization is nested in auseBean
element, it is executed only when the bean is created.<jsp:useBean id="bookDB" class="database.BookDB" scope="page"> <jsp:setProperty name="bookDB" property="database" value="${bookDBAO}" /> </jsp:useBean>Retrieving JavaBeans Component Properties
The main way to retrieve JavaBeans component properties is by using the unified EL expressions. Thus, to retrieve a book title, the Duke's Bookstore application uses the following expression:
Another way to retrieve component properties is to use the
jsp:getProperty
element. This element converts the value of the property into aString
and inserts the value into the response stream:Note that
beanName
must be the same as that specified for theid
attribute in auseBean
element, and there must be aget
PropName
method in the JavaBeans component. Although the preferred approach to getting properties is to use an EL expression, thegetProperty
element is available if you need to disable expression evaluation.