Praise for Head First Servlets and JSP™ “This Head First Servlets book is as good as the Head First EJB book, which made me laugh AND gave me 97% on the exam!” —Jef Cumps, J2EE consultant, Cronos “For our Servlet/JSP classes, we bought more than ten books, without finding any one really satisfying our teaching needs... Until we found the pedagogical gem you now hold in your hands! Head First books simply make us better teachers... Thank you so much for that!” —Philippe Maquet: Senior Instructor at Loop Factory, Brussels “There is no better introduction into the Servlet technology on the market than Head First Servlets & JSP. If you are new to web development with Java and you want an easy read which you really understand, then you have no other choice but to grab a copy of this book.” —Oliver Roell, SCJP, SCJD, SCBCD, SCWCD, and SCEA “Head First Servlets and JSPs is the first book I recommend to developers, both new and experienced, who are interested in learning to do more with Java EE. Nothing else out there even comes close. —Theodore Casser, senior software developer, Nanavati Consulting “I thought I knew JSP/Servlets before picking up Head First, but later after reading the book I really knew that I know JSP/Servlets. I appreciate the amazing style of writing in the Head First series.” —Jothi Shankar Kumar. S “When I read my first book from the Head First series, I realized how much fun learning a technology or methodology can be. It makes you glide through the learning process so easily, and it makes the learning stick to the walls of your brains. The latest one I have read is Head First Servlets & JSP. I picked this one when I was tired of reading big books for the SCWCD exam...After reading this book once, not only did I understand everything, but it really stayed there. I really really recommend this book to all the aspirants of SCWCD. —Neeraj Singhal, senior software consultant
Praise for the Head First approach “Java technology is everywhere—in mobile phones, cars, cameras, printers, games, PDAs, ATMs, smart cards, gas pumps, sports stadiums, medical devices, Web cams, servers, you name it. If you develop software and haven’t learned Java, it’s definitely time to dive in—Head First.” —Scott McNealy, Sun Microsystems Chairman, President and CEO “It’s fast, irreverent, fun, and engaging. Be careful—you might actually learn something!” —Ken Arnold, former Senior Engineer at Sun Microsystems Co-author (with James Gosling, creator of Java), The Java Programming Language “Until now, I could not have imagined a person smiling while studying an IT book! Using Head First EJB materials, I got a great score (91%) and set a world record as the youngest SCBCD, 14 years.” —Afsah Shafquat (world’s youngest Sun Certified Business Component Developer) “I received the book yesterday and started to read it on the way home... and I couldn’t stop. I took it to the gym and I expect people saw me smiling a lot while I was exercising and reading. This is très ‘cool.’ It is fun but they cover a lot of ground and they are right to the point. I’m really impressed.” —Erich Gamma, IBM Distinguished Engineer, and co-author of Design Patterns “Head First Design Patterns manages to mix fun, belly laughs, insight, technical depth and great practical advice in one entertaining and thought provoking read. Whether you are new to design patterns, or have been using them for years, you are sure to get something from visiting Objectville.” —Richard Helm, coauthor of “Design Patterns” with rest of the Gang of Four - Erich Gamma, Ralph Johnson and John Vlissides “I feel like a thousand pounds of books have just been lifted off of my head.” —Ward Cunningham, inventor of the Wiki and founder of the Hillside Group “Head First Object-Oriented Analysis and Design is a refreshing look at the subject of OOA&D. What sets this book apart is its focus on learning. There are too many books on the market that spend a lot of time telling you why, but do not actually enable the practitioner to start work on a project. Those books are very interesting, but not very practical. I strongly believe that the future of software development practice will focus on the practitioner. The authors have made the content of OOA&D accessible and usable for the practitioner ” — Ivar Jacobson, Ivar Jacobson Consulting
Praise for the Head First approach “The book does a good job of capturing that entertaining, visually oriented, ‘Head First’ writing style. But hidden behind the funny pictures and crazy fonts is a serious, intelligent, extremely well-crafted presentation of OO Analysis and Design. This book has a strong opinion of how to design programs, and communicates it effectively. I love the way it uses running examples to lead the reader through the various stages of the design process. As I read the book, I felt like I was looking over the shoulder of an expert designer who was explaining to me what issues were important at each step, and why.” — Edward Sciore, Associate Professor, Computer Science Department Boston College “I just finished reading HF OOA&D, and I loved it! The book manages to get across the essentials of object-oriented analysis and design with UML and use cases, and even several lectures on good software design, all in a fast-paced, easy to understand way. The thing I liked most about this book was its focus on why we do OOA&D—to write great software! By defining what great software is and showing how each step in the OOA&D process leads you towards that goal, it can teach even the most jaded Java programmer why OOA&D matters. This is a great ‘first book’ on design for anyone who is new to Java, or even for those who have been Java programmers for a while but have been scared off by the massive tomes on OO Analysis and Design.” — Kyle Brown, Distinguished Engineer, IBM “Head First Software Development is a whimsical but very thoughtfully designed series of information diagrams and clever illustrations meant to accurately and clearly convey information directly into YOUR brain. It’s a whole new kind of book.” — Scott Hanselman Software Developer, Speaker, Author Scott Hanselman’s Computer Zen “Head First Software Development tackles the aspects of software development that are rarely taught in class, but you REALLY need to know.” — Keith Wichmann, SOA architect, Johns Hopkins University, Applied Physics Laboratory “Head First Software Development teaches many valuable lessons that will help anyone deliver quality software on time and on budget. Following the core principles taught in this book will help keep your project on track from start to finish. No matter how long you’ve been developing software, Head First Software Development will give you essential tools for developing successful projects from start to finish.” — Adam Z. Szymanski, Software Project Manager, Naval Research Laboratory
Head First Servlets and JSP™ Second Edition
Wouldn’t it be dreamy if there were a Servlets book that was more stimulating than deleting spam from your inbox? It’s probably just a fantasy…
Bryan Basham Kathy Sierra Bert Bates
Beijing • Cambridge • Kln • Paris • Sebastopol • Taipei • Tokyo
Printing History: August 2004: First Edition. March 2008: Second Edition. The O’Reilly logo is a registered trademark of O’Reilly Media, Inc. The Head First series designations, Head First Servlets and JSP™, Second Edition, and related trade dress are trademarks of O’Reilly Media, Inc. Java and all Java-based trademarks and logos are trademarks or registered trademarks of Sun Microsystems, Inc., in the United States and other countries. O’Reilly Media, Inc. is independent of Sun Microsystems. Many of the designations used by manufacturers and sellers to distinguish their products are claimed as trademarks. Where those designations appear in this book, and O’Reilly Media, Inc., was aware of a trademark claim, the designations have been printed in caps or initial caps. While every precaution has been taken in the preparation of this book, the publisher and the author assume no responsibility for errors or omissions, or for damages resulting from the use of the information contained herein. In other words, if you use anything in Head First Servlets & JSP™ to, say, run a nuclear power plant or air traffic control system, you’re on your own. Readers of this book should be advised that the authors hope you remember them, should you create a huge, successful dotcom as a result of reading this book. We’ll take stock options, beer, or dark chocolate ISBN: 978-0-596-51668-0 [M]
This book is dedicated to whoever decided that the EL implicit object for a context param should be named initParam…
Perpetrators of the Head First series (and this book) Bert Bates
Bert is a longtime software
developer and architect, but a decade-long stint in artificial intelligence drove his interest in learning theory and technologybased training. He spent the first decade of his software career traveling the world to help broadcasting clients like Radio New Zealand, the Weather Channel, and the Arts and Entertainment Network (A&E). He’s currently a member of the development team for several of Sun’s Java Certification exams, including the new SCWCD. Bert is a long-time, hopelessly addicted go player, and has been working on a go program for way too long. Java may finally be a language expressive enough for him to finish the project. He’s a fair guitar player and is now trying his hand at banjo. His latest adventure is the purchase of an Icelandic horse which should give his training skills a new challenge...
Kathy has been interested in
learning theory and the brain since her days as a game designer (she wrote games for Virgin, MGM, and Amblin’) and an AI developer. She developed much of the Head First format while teaching New Media Interactivity for UCLA Extension’s Entertainment Studies program. More recently, she’s been a master trainer for Sun Microsystems, teaching Sun’s Java instructors how to teach the latest Java technologies, and developing several of Sun’s certification exams, including the SCWCD. Together with Bert Bates, she has been actively using the Head First concepts to teach thousands of developers. She founded one of the largest Java community websites in the world, javaranch.com, which won a 2003 and 2004 Software Development magazine Productivity Award. She likes running, skiing, horses, skateboarding, and weird science.
Bryan has over twenty years of
software development experience including time at NASA developing advanced automation software using AI techniques. He also worked for a consulting firm developing custom OO business apps. Currently, Bryan is a Course Developer for Sun, concentrating on Java and OO design principles. He’s worked on a large range of Sun’s Java courses including those n JDBC, J2EE, Servlets and JSP, and OO Software Development. He was also the lead designer of both the original and new version of the SCWCD exam. Bryan is a practicing Zen Buddhist, Ultimate Frisbee player, audiophile, and telemark skier.
When even JSTL is not enough: custom tag development
Deploying your web app: web app deployment
Keep it secret, keep it safe: web app security
The Power of Filters: wrappers and filters
Enterprise design patterns: patterns and struts
Appendix A: Final Mock Exam
Table of Contents (the real thing)
Intro Your brain on Servlets. Here you are trying to learn something, while here your brain is doing you a favor by making sure the learning doesn’t stick. Your brain’s thinking, “Better leave room for more important things, like which wild animals to avoid and whether naked snowboarding is a bad idea.” So how do you trick your brain into thinking that your life depends on knowing Servlets? Who is this book for?
We know what your brain is thinking
Bend your brain into submission
What you need for this book
Passing the certification exam
table of contents
Why use Servlets & JSPs Web applications are hot. How many GUI apps do you know that are used by millions of users worldwide? As a web app developer, you can free yourself from the grip of deployment problems all standalone apps have, and deliver your app to anyone with a browser. But you need servlets and JSPs. Because plain old static HTML pages are so, well, 1999. Learn to move from web site to web app.
What web servers and clients do, and how they talk?
Two-minute guide to HTML
What is the HTTP protocol?
Anatomy of HTTP GET and POST requests and HTTP responses
Locating web pages using URLs
Web servers, static web pages, and CGI
Servlets Demystified: write, deploy, and run a servlet
JSP is what happened when somebody introduced Java to HTML
Web app architecture Servlets need help. When a request comes in, somebody has to instantiate the servlet or at least allocate a thread to handle the request. Somebody has to call the servlet’s doPost() or doGet() method. Somebody has to get the request and the response to the servlet. Somebody has to manage the life, death, and resources of the servlet. In this chapter, we’ll look at the Container, and we’ll take a first look at the MVC pattern.
What is a Container and what does it give you?
How it looks in code (and what makes a servlet)
Naming servlets and mapping them to URLs using the DD
Story: Bob Builds a Matchmaking Site ( and MVC intro)
A Model-View-Controller (MVC) overview and example
A “working” Deployment Descriptor (DD)
How J2EE fits into all this
table of contents
Mini MVC tutorial Create and deploy an MVC web app. It’s time to get your hands dirty writing an HTML form, a servlet controller, a model (plain old Java class), an XML deployment descriptor, and a JSP view. Time to build it, deploy it, and test it. But first, you need to set up your development environment. Next, you need to set up your deployment environment following the servlet and JSP specs and Tomcat requirements. True, this is a small app... but there’s almost NO app that’s too small to use MVC. Exam Objectives
Let’s build an MVC application; the first design
Create the development and deployment environments
Create and test the HTML for the initial form page
Create the Deployment Descriptor (DD)
Create, compile, deploy, and test the controller servlet
Design, build, and test the model component
Enhance the controller to call the model
Create and deploy the view component (it’s a JSP)
Enhance the controller servlet to call the JSP
Being a Servlet Servlets need help. When a request A servlet’s job is to take a client’s request and send back a response. The request might be simple: “get me the Welcome page.” Or it might be complex: “Complete my shopping cart check-out.” The request carries crucial data, and your servlet code has to know how to find it and how to use it. And your servlet code has to know how to send a response. Or not... Exam Objectives A servlet’s life in the Container Servlet initialization and threads A Servlet’s REAL job is to handle GET and POST requests. The story of the non-idempotent request What determines whether you get a GET or POST request? Sending and using parameter(s) So that’s the Request... now let’s see the Response You can set response headers, you can add response headers Servlet redirect vs. request dispatcher Review: HttpServletResponse
94 95 101 105 112 117 119 126 133 136 140
table of contents
Being a web app No servlet stands alone. In today’s modern web app, many components work together to accomplish a goal. You have models, controllers, and views. You have parameters and attributes. You have helper classes. But how do you tie the pieces together? How do you let components share information? How do you hide information? How do you make information thread-safe? Your job may depend on the answers.
Init Parameters and ServletConfig to the rescue
How can a JSP get servlet init parameters?
Context init parameters to the rescue
Comparing ServletConfig with ServletContext
She wants a ServletContextListener
Tutorial: a simple ServletContextListener
Compile, deploy, and test your listener
The full story, a ServletContextListener review
Eight Listeners: they’re not just for context events...
What, exactly, is an attribute?
The Attribute API and the dark side of attributes
Context scope isn’t thread-safe!
The problem in slow motion...
Trying out Synchronization
Are Session attributes thread-safe?
Only Request attributes and local variables are thread-safe!
Request attributes and Request dispatching
table of contents
Conversational state Web servers have no short-term memory. As soon as they send you a response, they forget who you are. The next time you make a request, they don’t recognize you. They don’t remember what you’ve requested in the past, and they don’t remember what they’ve sent you in response. Nothing. But sometimes you need to keep conversational state with the client across multiple requests. A shopping cart wouldn’t work if the client had to make all his choices and then checkout in a single request. Exam Objectives
It’s supposed to be a conversation, (how sessions work)
Session IDs, cookies, and other session basics
URL rewriting: something to fall back on
When sessions get stale; getting rid of bad sessions
Key milestones for an HttpSession
Don’t forget about HttpSessionBindingListener
Being a JSP A JSP becomes a servlet. A servlet that you don’t create. The Container looks at your JSP, translates it into Java source code, and compiles it into a full-fledged Java servlet class. But you’ve got to know what happens when the code you write in the JSP is turned into Java code. You can write Java code in your JSP, but should you? And if not Java code, what do you write? How does it translate into Java code? We’ll look at six different kinds of JSP elements—each with its own purpose and, yes, unique syntax. You’ll learn how, why, and what to write in your JSP. And you’ll learn what not to write. Exam Objectives
Create a simple JSP using “out” and a page directive
JSP expressions, variables, and declarations
Time to see a JSP-generated servlet
The out variable isn’t the only implicit object...
The Lifecycle and initialization of a JSP
While we’re on the subject... let’s talk more about the three directives
Scriptlets considered harmful? Here’s EL
But wait... we haven’t seen: actions
table of contents
When attributes are beans
Standard actions: useBean, getProperty, setProperty
Can you make polymorphic bean references?
The param attribute to the rescue
Expression Language (EL) saves the day!
Using the dot (.) operator to access properties and map values
The  gives you more options (Lists, arrays...)
More dot and [ ] operator details
The EL implicit objects
EL functions, and handling “null”
Reusable template pieces—two kinds of “include”
The standard action
She doesn’t know about JSTL tags (a preview)
Reviewing standard actions and include
table of contents
Custom tags are powerful Sometimes you need more than EL or standard actions. What if you want to loop through the data in an array, and display one item per row in an HTML table? You know you could write that in two seconds using a for loop in a scriptlet. But you’re trying to get away from scripting. No problem. When EL and standard actions aren’t enough, you can use custom tags. They’re as easy to use in a JSP as standard actions. Even better, someone’s already written a pile of the ones you’re most likely to need, and bundled them into the JSP Standard Tag Library (JSTL). In this chapter we’ll learn to use custom tags, and in the next chapter we’ll learn to create our own.
Looping without scripting
Conditional control with and
Using the and tags
With , there are now three ways to include content