SlideShare a Scribd company logo
Servlet and JSP development with Eclipse
WTP - Tutorial
Lars Vogel
Version 2.1
Copyright © 2008, 2009, 2010, 2011, 2012 Lars Vogel
15.11.2012
Revision History
Revision 0.1 - 2.1 12.12.2007 - 15.11.2012 Lars
Vogel
bug fixing and improvem
Eclipse Web Tool Platform (WTP)
This tutorial describes the development of servlets and JSPs with Eclipse WTP. This
tutorial is based on Eclipse 3.7 (Indigo) and Tomcat 6.0 and JDK 1.6.
Table of Contents
1. Eclipse Web Tool Platform
2. Tomcat Installation
3. Installation of WTP
4. WTP Configuration
4.1. Setting up runtime environments
4.2. Server
5. Servlets
5.1. Project
5.2. Creating Data Access Object
5.3. Creating the Servlet
5.4. Run
6. JavaServer Pages (JSPs)
6.1. Create Project
6.2. Create the JSP
6.3. Run it
6.4. Adjust web.xml
7. JSP's and Servlets
7.1. Create Project
7.2. Create the Controller (servlet)
7.3. Create the Views (JSP)
7.4. Run it
8. Web Archive - How to create a war file from Eclipse
9. Additional Eclipse WTP resources
10. Support this website
10.1. Thank you
10.2. Questions and Discussion
11. Links and Literature
11.1. Source Code
11.2. Web development resources
11.3. vogella Resources
1. Eclipse Web Tool Platform
Eclipse WTP provides tools for developing standard Java web applications and Java EE
applications. Typical web artifacts in a Java environment are HTML pages, XML files,
webservices, servlets and JSPs. Eclipse WTP simplifies the creation these web artifacts
and provides runtime environments in which these artifacts can be deployed, started
and debugged.
In Eclipse WTP you create Dynamic Web Projects. These projects provide the
necessary functionality to run, debug and deploy Java web applications. If you are
completely new to Java web development, you may want to read Introduction to Java
Web development tutorial.
Eclipse WTP supports all major web containers, e.g., Jetty and Apache Tomcat as well
as the mayor Java EE application server. This tutorial uses Apache Tomcat as a web
container.
2. Tomcat Installation
Apache Tomcat Tutorial for instructions how to install Apache Tomcat.
After the installation, test if Tomcat is correctly installed by opening a browser
to http://localhost:8080/. This should open an information page of Tomcat.
Afterwards, stop Tomcat. Eclipse WTP needs to start Tomcat itself for its deployments.
3. Installation of WTP
In case you have downloaded an Eclipse version for Java development, you can update
it via the Eclipse Update Manager. Install all packages from the category "Web, XML,
Java EE Development and OSGi Enterprise Development" except "PHP Development"
and the "RAP" Tooling.
For an introduction in the Eclipse IDE please see the Eclipse IDE Tutorial.
4. WTP Configuration
4.1. Setting up runtime environments
To configure Eclipse WTP, select from the
menu Window → Preferences → Server → Runtime Environments. Press
the Add button.
Select your version of Tomcat.
To compile the JSP into servlets, you need to use the JDK. You can check your setup
by clicking on the Installed JRE button.
Press Finish and then OK. You are now ready to use Tomcat with WTP.
4.2. Server
During development, you will create your server. You can manage your server via
the Server view.
You can stop and start the server via the Window → Show View → Servers → Servers
menu menu.
5. Servlets
5.1. Project
We will create a servlet which works as a webpage counter. This servlet keeps track of
the number of visitors of a webpage. The servlet will persist the number of visitors in a
text file. Create a new Dynamic Web Project called de.vogella.wtp.filecounter by
selecting File → New → Other... → Web → Dynamic Web Project.
Press finished. If Eclipse asks you, to switch to the Java EE Perspective answer yes.
A new project has been created with the standard structure of a Java web application.
The WEB-INF/lib directory holds all the JAR files that the Java web application
requires.
5.2. Creating Data Access Object
Create a new package called de.vogella.wtp.filecounter.dao.
Create the Java class which will provide the number of visitors and write this value to a
file.
package de.vogella.wtp.filecounter.dao;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.io.PrintWriter;
public class FileDao {
public int getCount() {
int count = 0;
// Load the file with the counter
FileReader fileReader = null;
BufferedReader bufferedReader = null;
PrintWriter writer = null ;
try {
File f = new File("FileCounter.initial");
if (!f.exists()) {
f.createNewFile();
writer = new PrintWriter(new FileWriter(f));
writer.println(0);
}
if (writer !=null){
writer.close();
}
fileReader = new FileReader(f);
bufferedReader = new BufferedReader(fileReader);
String initial = bufferedReader.readLine();
count = Integer.parseInt(initial);
} catch (Exception ex) {
if (writer !=null){
writer.close();
}
}
if (bufferedReader != null) {
try {
bufferedReader.close();
} catch (IOException e) {
e.printStackTrace();
}
}
return count;
}
public void save(int count) throws Exception {
FileWriter fileWriter = null;
PrintWriter printWriter = null;
fileWriter = new FileWriter("FileCounter.initial");
printWriter = new PrintWriter(fileWriter);
printWriter.println(count);
// make sure to close the file
if (printWriter != null) {
printWriter.close();
}
}
}
Tip
This Java class is not a servlet, it is a normal Java class.
5.3. Creating the Servlet
Create a servlet. Right-click on the folder Webcontent and select New → Other.
Select Web → Servlet. Enter the following data.
Press finish.
You could also create a servlet without the wizard. The wizard creates a Java class
which extends thejavax.servlet.http.HttpServlet and adds the servlet settings to
the web.xml file.
Enter the following code.
package de.vogella.wtp.filecounter.servlets;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import de.vogella.wtp.filecounter.dao.FileDao;
/**
* Servlet implementation class FileCounter
*/
public class FileCounter extends HttpServlet {
private static final long serialVersionUID = 1L;
int count;
private FileDao dao;
public void init() throws ServletException {
dao = new FileDao();
try {
count = dao.getCount();
} catch (Exception e) {
getServletContext().log("An exception occurred in
FileCounter", e);
throw new ServletException("An exception occurred in
FileCounter"
+ e.getMessage());
}
}
protected void doGet(HttpServletRequest request,
HttpServletResponse response) throws ServletException,
IOException {
// Set a cookie for the user, so that the counter does not
increate
// every time the user press refresh
HttpSession session = request.getSession(true);
// Set the session valid for 5 secs
session.setMaxInactiveInterval(5);
response.setContentType("text/plain");
PrintWriter out = response.getWriter();
if (session.isNew()) {
count++;
}
out.println("This site has been accessed " + count + " times.");
}
public void destroy() {
super.destroy();
try {
dao.save(count);
} catch (Exception e) {
e.printStackTrace();
}
}
}
This code will read the counter from a file on the server and return plain text to the
browser. The servlet will increase the counter if the user was inactive for 5 seconds.
5.4. Run
Select your servlet, right-click on it and select Run As → Run on Server.
Select your server and include your servlet so that is runs on the server.
Servlet and jsp development with eclipse wtp
Press Finish. You should see the Eclipse internal web browser displaying the count
number to you. If you wait 5 seconds and refresh, the number should increase.
Congratulations. You created your first working servlet with Eclipse WTP!
6. JavaServer Pages (JSPs)
6.1. Create Project
The following will demonstrate the creation and usage of a JaveServer Page. Create a
new Dynamic Web Project calledde.vogella.wtp.jspsimple and a package with the same
name.
6.2. Create the JSP
Select the folder "WebContent", right-click New → JSP. and create the JSP "FirstJSP".
Select the "New JSP File (html)" template.
Create the following coding.
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-
8859-1">
<title>JSP with the current date</title>
</head>
<body>
<%java.text.DateFormat df = new
java.text.SimpleDateFormat("dd/MM/yyyy"); %>
<h1>Current Date: <%= df.format(new java.util.Date()) %> </h1>
</body>
</html>
6.3. Run it
Start your webapplication. You find your JSP under the
URL http://localhost:8080/de.vogella.wtp.jspsimple/FirstJSP.jsp.
6.4. Adjust web.xml
Set the JSP page as the welcome page for your application to have it automatically
opened if the application is started. Modify theWebContent/WEB-INF/web.xml file.
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID"
version="2.5">
<display-name>de.vogella.wtp.jspsimple</display-name>
<welcome-file-list>
<welcome-file>FirstJSP.jsp</welcome-file>
</welcome-file-list>
</web-app>
This allows to start the JSP via the
URL http://localhost:8080/de.vogella.wtp.jspsimple.
7. JSP's and Servlets
7.1. Create Project
This example will demonstrate the usage of JSPs for the display and a servlet as the
controller for a web application. The servlet will dispatch the request to the correct JSP.
Create the Dynamic Web Project "de.vogella.wtp.jsp" and the package
"de.vogella.wtp.jsp"
7.2. Create the Controller (servlet)
Create a new servlet called Controller in the de.vogella.wtp.jsp.controller package.
package de.vogella.wtp.jsp.controller;
import java.io.IOException;
import java.util.Map;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* Servlet implementation class Controller
*/
public class Controller extends HttpServlet {
private static final long serialVersionUID = 1L;
private static String DELETE_JSP = "/Delete.jsp";
private static String EDIT_JSP = "/Edit.jsp";
private static String SHOWALL_JSP = "/ShowAll.jsp";
protected void doGet(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
String forward="";
// Get a map of the request parameters
@SuppressWarnings("unchecked")
Map parameters = request.getParameterMap();
if (parameters.containsKey("delete")){
forward = DELETE_JSP;
} else if (parameters.containsKey("edit")){
forward = EDIT_JSP;
} else {
forward = SHOWALL_JSP;
}
RequestDispatcher view = request.getRequestDispatcher(forward);
view.forward(request, response);
}
}
This controller checks which parameters are passed to the servlet and then forward the
request to the correct JSP.
7.3. Create the Views (JSP)
In the folder "WebContent" create the new JSP "ShowAll" with the following code.
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-
8859-1">
<title>Show all names</title>
</head>
<body>
<form method="GET" action='Controller' name="showall">
<table>
<tr>
<td><input type="checkbox" name="id1" /></td>
<td>Jim</td>
<td>Knopf</td>
</tr>
<tr>
<td><input type="checkbox" name="id2" /></td>
<td>Jim</td>
<td>Bean</td>
</tr>
</table>
<p><input type="submit" name="delete" value="delete" />&nbsp;
<input type="submit" name="edit" value="edit" />&nbsp;
<input type="reset"
value="reset" /></p>
</form>
</body>
</html>
Create the Delete.jsp JSP.
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-
8859-1">
<title>Insert title here</title>
</head>
<body>
Delete successful
<form method="GET" action='Controller' name="delete_success"><input
type="submit" value="back"></form>
</body>
</html>
Create the JSP Edit.jsp.
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-
8859-1">
<title>Insert title here</title>
</head>
<body>
<form method="GET" action='Controller' name="edit">
<table>
<tr>
<td>First name:</td>
<td><input type="text" name="firstName"></td>
</tr>
<tr>
<td>Last name:</td>
<td><input type="text" name="lastName"></td>
</tr>
<tr>
<td><input type="submit" value="save"> <input
type="reset" value="reset"> <input type="submit" value="back">
</td>
</tr>
</table>
</form>
</body>
</html>
7.4. Run it
Run your new application by running ShowAll.jsp on the server. You should be able
to navigate between the pages.
8. Web Archive - How to create a war file
from Eclipse
´The following describes how to create a Web Archive (WAR) from Eclipse.
Right-click on the project and select Export.
Specify the target directory and press Finish.
You can now import the WAR file to your production Tomcat system and test the web
application.
9. Additional Eclipse WTP resources
The development of webservices with Eclipse WTP is covered in Webservices with
Axis2 and the Eclipse Web Tool Platform (WTP) - Tutorial.
The development of JavaServerFaces is covered in JavaServer Faces (JSF)
development with Eclipse WTP JSF - Tutorialand JSF with Apache Myfaces
Trinidad and Eclipse.
10. Support this website
This tutorial is Open Content under the CC BY-NC-SA 3.0 DE license. Source code in
this tutorial is distributed under the Eclipse Public License. See the vogella
License page for details on the terms of reuse.
Writing and updating these tutorials is a lot of work. If this free community service was
helpful, you can support the cause by giving a tip as well as reporting typos and factual
errors.
10.1. Thank you
Please consider a contribution if this article helped you.
10.2. Questions and Discussion
If you find errors in this tutorial, please notify me (see the top of the page). Please note
that due to the high volume of feedback I receive, I cannot answer questions to your
implementation. Ensure you have read the vogella FAQ as I don't respond to questions
already answered there.
11. Links and Literature
11.1. Source Code
Source Code of Examples
11.2. Web development resources
Introduction into Java Web development
11.3. vogella Resources
vogella Training Android and Eclipse Training from the vogella team
Android Tutorial Introduction to Android Programming
GWT Tutorial Program in Java, compile to JavaScript and HTML
Eclipse RCP Tutorial Create native applications in Java
JUnit Tutorial Test your application
Git Tutorial Put all your files in a distributed version control system
Servlet and jsp development with eclipse wtp

More Related Content

What's hot (19)

DOC
Gwt portlet
prabakaranbrick
 
PPTX
Spring Boot and REST API
07.pallav
 
PDF
NLOUG 2018 - Future of JSF and ADF
Daniel Merchán García
 
PDF
BP204 It's Not Infernal: Dante's Nine Circles of XPages Heaven
Michael McGarel
 
PDF
NLOUG 2017- Oracle WebCenter Portal 12c Performance
Daniel Merchán García
 
PPT
Programming Server side with Sevlet
backdoor
 
PDF
NodeJS : Communication and Round Robin Way
Edureka!
 
PDF
Create a meteor chat app in 30 minutes
Designveloper
 
PPTX
Spring boot Introduction
Jeevesh Pandey
 
PDF
High Performance JavaScript - jQuery Conference SF Bay Area 2010
Nicholas Zakas
 
PDF
Servlet and JSP
Gary Yeh
 
PPTX
Dsc Charusat Learning React Part 1
JainamMehta19
 
PDF
Spring Boot and Microservices
seges
 
PDF
Introduction to Spring Boot
Trey Howard
 
PPTX
How to customize Spring Boot?
GilWon Oh
 
PDF
Node JS Express: Steps to Create Restful Web App
Edureka!
 
PDF
Introduction of React.js
Jyaasa Technologies
 
ODP
Introduction to rails 4 v1
Muhammad Irfan
 
PDF
Selenium RC: Automated Testing of Modern Web Applications
qooxdoo
 
Gwt portlet
prabakaranbrick
 
Spring Boot and REST API
07.pallav
 
NLOUG 2018 - Future of JSF and ADF
Daniel Merchán García
 
BP204 It's Not Infernal: Dante's Nine Circles of XPages Heaven
Michael McGarel
 
NLOUG 2017- Oracle WebCenter Portal 12c Performance
Daniel Merchán García
 
Programming Server side with Sevlet
backdoor
 
NodeJS : Communication and Round Robin Way
Edureka!
 
Create a meteor chat app in 30 minutes
Designveloper
 
Spring boot Introduction
Jeevesh Pandey
 
High Performance JavaScript - jQuery Conference SF Bay Area 2010
Nicholas Zakas
 
Servlet and JSP
Gary Yeh
 
Dsc Charusat Learning React Part 1
JainamMehta19
 
Spring Boot and Microservices
seges
 
Introduction to Spring Boot
Trey Howard
 
How to customize Spring Boot?
GilWon Oh
 
Node JS Express: Steps to Create Restful Web App
Edureka!
 
Introduction of React.js
Jyaasa Technologies
 
Introduction to rails 4 v1
Muhammad Irfan
 
Selenium RC: Automated Testing of Modern Web Applications
qooxdoo
 

Viewers also liked (14)

PDF
The java rogramming swing _tutorial for beinners(java programming language)
Daroko blog(www.professionalbloggertricks.com)
 
PDF
Struts2 tutorial
Suhas Kamble
 
PDF
Simple tutorial for using jdbc
William Bonney
 
PDF
Jdbc tutorial
Dharma Kshetri
 
PPTX
Java server pages
Farzad Wadia
 
PDF
Assignment 2
Gregory Eason
 
DOCX
Java assignment 1
Daman Toor
 
PPTX
Sql tutorial
prabhu rajendran
 
PPTX
Angular js 1.3 basic tutorial
Al-Mutaz Bellah Salahat
 
PDF
Angular JS blog tutorial
Claude Tech
 
PPTX
SQL Fundamentals
Brian Foote
 
PPTX
Getting Started with Angular JS
Akshay Mathur
 
PDF
java swing tutorial for beginners(java programming tutorials)
Daroko blog(www.professionalbloggertricks.com)
 
PPTX
Understanding angular js
Aayush Shrestha
 
The java rogramming swing _tutorial for beinners(java programming language)
Daroko blog(www.professionalbloggertricks.com)
 
Struts2 tutorial
Suhas Kamble
 
Simple tutorial for using jdbc
William Bonney
 
Jdbc tutorial
Dharma Kshetri
 
Java server pages
Farzad Wadia
 
Assignment 2
Gregory Eason
 
Java assignment 1
Daman Toor
 
Sql tutorial
prabhu rajendran
 
Angular js 1.3 basic tutorial
Al-Mutaz Bellah Salahat
 
Angular JS blog tutorial
Claude Tech
 
SQL Fundamentals
Brian Foote
 
Getting Started with Angular JS
Akshay Mathur
 
java swing tutorial for beginners(java programming tutorials)
Daroko blog(www.professionalbloggertricks.com)
 
Understanding angular js
Aayush Shrestha
 
Ad

Similar to Servlet and jsp development with eclipse wtp (20)

DOC
Unit5 servlets
Praveen Yadav
 
PDF
01 web-apps
snopteck
 
PDF
01 web-apps
Aravindharamanan S
 
DOC
Java Servlets & JSP
Manjunatha RK
 
PPTX
Cis 274 intro
Aren Zomorodian
 
PDF
01 overview-and-setup
snopteck
 
PPTX
Mastering-Servlets-with-Tomcat-and-Eclipse.pptx
shanthidl1
 
PPT
192563547-Servletsjhb,mnjhjhjm,nm,-Pres-ppt.ppt
sindhu991994
 
PDF
Java Servlets.pdf
Arumugam90
 
PPT
Ta Javaserverside Eran Toch
Adil Jafri
 
PPT
Java Servlets
BG Java EE Course
 
PPTX
Chapter 3 servlet & jsp
Jafar Nesargi
 
PPT
1 java servlets and jsp
Ankit Minocha
 
PPTX
SCWCD : Servlet web applications : CHAP : 3
Ben Abdallah Helmi
 
PPT
Introduction to Java Servlets and JSP (1).ppt
ansariparveen06
 
PPTX
SCWCD : Servlet web applications : CHAP 3
Ben Abdallah Helmi
 
PPTX
Java web application development
RitikRathaur
 
PPTX
Understanding JSP -Servlets
Gagandeep Singh
 
PPT
Ppt for Online music store
ADEEBANADEEM
 
PPTX
Web container and Apache Tomcat
Auwal Amshi
 
Unit5 servlets
Praveen Yadav
 
01 web-apps
snopteck
 
01 web-apps
Aravindharamanan S
 
Java Servlets & JSP
Manjunatha RK
 
Cis 274 intro
Aren Zomorodian
 
01 overview-and-setup
snopteck
 
Mastering-Servlets-with-Tomcat-and-Eclipse.pptx
shanthidl1
 
192563547-Servletsjhb,mnjhjhjm,nm,-Pres-ppt.ppt
sindhu991994
 
Java Servlets.pdf
Arumugam90
 
Ta Javaserverside Eran Toch
Adil Jafri
 
Java Servlets
BG Java EE Course
 
Chapter 3 servlet & jsp
Jafar Nesargi
 
1 java servlets and jsp
Ankit Minocha
 
SCWCD : Servlet web applications : CHAP : 3
Ben Abdallah Helmi
 
Introduction to Java Servlets and JSP (1).ppt
ansariparveen06
 
SCWCD : Servlet web applications : CHAP 3
Ben Abdallah Helmi
 
Java web application development
RitikRathaur
 
Understanding JSP -Servlets
Gagandeep Singh
 
Ppt for Online music store
ADEEBANADEEM
 
Web container and Apache Tomcat
Auwal Amshi
 
Ad

Recently uploaded (20)

PPTX
MailsDaddy Outlook OST to PST converter.pptx
abhishekdutt366
 
PPTX
Feb 2021 Cohesity first pitch presentation.pptx
enginsayin1
 
PPTX
The Role of a PHP Development Company in Modern Web Development
SEO Company for School in Delhi NCR
 
DOCX
Import Data Form Excel to Tally Services
Tally xperts
 
PDF
Powering GIS with FME and VertiGIS - Peak of Data & AI 2025
Safe Software
 
PDF
Why Businesses Are Switching to Open Source Alternatives to Crystal Reports.pdf
Varsha Nayak
 
PPTX
MiniTool Power Data Recovery Full Crack Latest 2025
muhammadgurbazkhan
 
PPTX
Equipment Management Software BIS Safety UK.pptx
BIS Safety Software
 
PDF
Unlock Efficiency with Insurance Policy Administration Systems
Insurance Tech Services
 
PPTX
Java Native Memory Leaks: The Hidden Villain Behind JVM Performance Issues
Tier1 app
 
PDF
Understanding the Need for Systemic Change in Open Source Through Intersectio...
Imma Valls Bernaus
 
PPTX
Agentic Automation Journey Session 1/5: Context Grounding and Autopilot for E...
klpathrudu
 
PDF
Thread In Android-Mastering Concurrency for Responsive Apps.pdf
Nabin Dhakal
 
PDF
Streamline Contractor Lifecycle- TECH EHS Solution
TECH EHS Solution
 
PDF
Capcut Pro Crack For PC Latest Version {Fully Unlocked} 2025
hashhshs786
 
PDF
vMix Pro 28.0.0.42 Download vMix Registration key Bundle
kulindacore
 
PPTX
An Introduction to ZAP by Checkmarx - Official Version
Simon Bennetts
 
PPTX
Tally software_Introduction_Presentation
AditiBansal54083
 
PDF
Beyond Binaries: Understanding Diversity and Allyship in a Global Workplace -...
Imma Valls Bernaus
 
PPTX
Human Resources Information System (HRIS)
Amity University, Patna
 
MailsDaddy Outlook OST to PST converter.pptx
abhishekdutt366
 
Feb 2021 Cohesity first pitch presentation.pptx
enginsayin1
 
The Role of a PHP Development Company in Modern Web Development
SEO Company for School in Delhi NCR
 
Import Data Form Excel to Tally Services
Tally xperts
 
Powering GIS with FME and VertiGIS - Peak of Data & AI 2025
Safe Software
 
Why Businesses Are Switching to Open Source Alternatives to Crystal Reports.pdf
Varsha Nayak
 
MiniTool Power Data Recovery Full Crack Latest 2025
muhammadgurbazkhan
 
Equipment Management Software BIS Safety UK.pptx
BIS Safety Software
 
Unlock Efficiency with Insurance Policy Administration Systems
Insurance Tech Services
 
Java Native Memory Leaks: The Hidden Villain Behind JVM Performance Issues
Tier1 app
 
Understanding the Need for Systemic Change in Open Source Through Intersectio...
Imma Valls Bernaus
 
Agentic Automation Journey Session 1/5: Context Grounding and Autopilot for E...
klpathrudu
 
Thread In Android-Mastering Concurrency for Responsive Apps.pdf
Nabin Dhakal
 
Streamline Contractor Lifecycle- TECH EHS Solution
TECH EHS Solution
 
Capcut Pro Crack For PC Latest Version {Fully Unlocked} 2025
hashhshs786
 
vMix Pro 28.0.0.42 Download vMix Registration key Bundle
kulindacore
 
An Introduction to ZAP by Checkmarx - Official Version
Simon Bennetts
 
Tally software_Introduction_Presentation
AditiBansal54083
 
Beyond Binaries: Understanding Diversity and Allyship in a Global Workplace -...
Imma Valls Bernaus
 
Human Resources Information System (HRIS)
Amity University, Patna
 

Servlet and jsp development with eclipse wtp

  • 1. Servlet and JSP development with Eclipse WTP - Tutorial Lars Vogel Version 2.1 Copyright © 2008, 2009, 2010, 2011, 2012 Lars Vogel 15.11.2012 Revision History Revision 0.1 - 2.1 12.12.2007 - 15.11.2012 Lars Vogel bug fixing and improvem Eclipse Web Tool Platform (WTP) This tutorial describes the development of servlets and JSPs with Eclipse WTP. This tutorial is based on Eclipse 3.7 (Indigo) and Tomcat 6.0 and JDK 1.6. Table of Contents 1. Eclipse Web Tool Platform 2. Tomcat Installation 3. Installation of WTP 4. WTP Configuration 4.1. Setting up runtime environments 4.2. Server 5. Servlets 5.1. Project 5.2. Creating Data Access Object 5.3. Creating the Servlet 5.4. Run 6. JavaServer Pages (JSPs) 6.1. Create Project
  • 2. 6.2. Create the JSP 6.3. Run it 6.4. Adjust web.xml 7. JSP's and Servlets 7.1. Create Project 7.2. Create the Controller (servlet) 7.3. Create the Views (JSP) 7.4. Run it 8. Web Archive - How to create a war file from Eclipse 9. Additional Eclipse WTP resources 10. Support this website 10.1. Thank you 10.2. Questions and Discussion 11. Links and Literature 11.1. Source Code 11.2. Web development resources 11.3. vogella Resources 1. Eclipse Web Tool Platform Eclipse WTP provides tools for developing standard Java web applications and Java EE applications. Typical web artifacts in a Java environment are HTML pages, XML files, webservices, servlets and JSPs. Eclipse WTP simplifies the creation these web artifacts and provides runtime environments in which these artifacts can be deployed, started and debugged. In Eclipse WTP you create Dynamic Web Projects. These projects provide the necessary functionality to run, debug and deploy Java web applications. If you are completely new to Java web development, you may want to read Introduction to Java Web development tutorial. Eclipse WTP supports all major web containers, e.g., Jetty and Apache Tomcat as well as the mayor Java EE application server. This tutorial uses Apache Tomcat as a web container. 2. Tomcat Installation Apache Tomcat Tutorial for instructions how to install Apache Tomcat. After the installation, test if Tomcat is correctly installed by opening a browser to http://localhost:8080/. This should open an information page of Tomcat. Afterwards, stop Tomcat. Eclipse WTP needs to start Tomcat itself for its deployments. 3. Installation of WTP In case you have downloaded an Eclipse version for Java development, you can update it via the Eclipse Update Manager. Install all packages from the category "Web, XML,
  • 3. Java EE Development and OSGi Enterprise Development" except "PHP Development" and the "RAP" Tooling. For an introduction in the Eclipse IDE please see the Eclipse IDE Tutorial. 4. WTP Configuration 4.1. Setting up runtime environments To configure Eclipse WTP, select from the menu Window → Preferences → Server → Runtime Environments. Press the Add button. Select your version of Tomcat.
  • 4. To compile the JSP into servlets, you need to use the JDK. You can check your setup by clicking on the Installed JRE button.
  • 5. Press Finish and then OK. You are now ready to use Tomcat with WTP. 4.2. Server During development, you will create your server. You can manage your server via the Server view.
  • 6. You can stop and start the server via the Window → Show View → Servers → Servers menu menu. 5. Servlets 5.1. Project
  • 7. We will create a servlet which works as a webpage counter. This servlet keeps track of the number of visitors of a webpage. The servlet will persist the number of visitors in a text file. Create a new Dynamic Web Project called de.vogella.wtp.filecounter by selecting File → New → Other... → Web → Dynamic Web Project.
  • 8. Press finished. If Eclipse asks you, to switch to the Java EE Perspective answer yes. A new project has been created with the standard structure of a Java web application. The WEB-INF/lib directory holds all the JAR files that the Java web application requires. 5.2. Creating Data Access Object Create a new package called de.vogella.wtp.filecounter.dao. Create the Java class which will provide the number of visitors and write this value to a file.
  • 9. package de.vogella.wtp.filecounter.dao; import java.io.BufferedReader; import java.io.File; import java.io.FileReader; import java.io.FileWriter; import java.io.IOException; import java.io.PrintWriter; public class FileDao { public int getCount() { int count = 0; // Load the file with the counter FileReader fileReader = null; BufferedReader bufferedReader = null; PrintWriter writer = null ; try { File f = new File("FileCounter.initial"); if (!f.exists()) { f.createNewFile(); writer = new PrintWriter(new FileWriter(f)); writer.println(0); } if (writer !=null){ writer.close(); } fileReader = new FileReader(f); bufferedReader = new BufferedReader(fileReader); String initial = bufferedReader.readLine(); count = Integer.parseInt(initial); } catch (Exception ex) { if (writer !=null){ writer.close();
  • 10. } } if (bufferedReader != null) { try { bufferedReader.close(); } catch (IOException e) { e.printStackTrace(); } } return count; } public void save(int count) throws Exception { FileWriter fileWriter = null; PrintWriter printWriter = null; fileWriter = new FileWriter("FileCounter.initial"); printWriter = new PrintWriter(fileWriter); printWriter.println(count); // make sure to close the file if (printWriter != null) { printWriter.close(); } } } Tip This Java class is not a servlet, it is a normal Java class. 5.3. Creating the Servlet Create a servlet. Right-click on the folder Webcontent and select New → Other. Select Web → Servlet. Enter the following data.
  • 11. Press finish. You could also create a servlet without the wizard. The wizard creates a Java class which extends thejavax.servlet.http.HttpServlet and adds the servlet settings to the web.xml file. Enter the following code. package de.vogella.wtp.filecounter.servlets; import java.io.IOException; import java.io.PrintWriter; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse;
  • 12. import javax.servlet.http.HttpSession; import de.vogella.wtp.filecounter.dao.FileDao; /** * Servlet implementation class FileCounter */ public class FileCounter extends HttpServlet { private static final long serialVersionUID = 1L; int count; private FileDao dao; public void init() throws ServletException { dao = new FileDao(); try { count = dao.getCount(); } catch (Exception e) { getServletContext().log("An exception occurred in FileCounter", e); throw new ServletException("An exception occurred in FileCounter" + e.getMessage()); } } protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // Set a cookie for the user, so that the counter does not increate // every time the user press refresh HttpSession session = request.getSession(true); // Set the session valid for 5 secs session.setMaxInactiveInterval(5); response.setContentType("text/plain");
  • 13. PrintWriter out = response.getWriter(); if (session.isNew()) { count++; } out.println("This site has been accessed " + count + " times."); } public void destroy() { super.destroy(); try { dao.save(count); } catch (Exception e) { e.printStackTrace(); } } } This code will read the counter from a file on the server and return plain text to the browser. The servlet will increase the counter if the user was inactive for 5 seconds. 5.4. Run Select your servlet, right-click on it and select Run As → Run on Server. Select your server and include your servlet so that is runs on the server.
  • 15. Press Finish. You should see the Eclipse internal web browser displaying the count number to you. If you wait 5 seconds and refresh, the number should increase. Congratulations. You created your first working servlet with Eclipse WTP! 6. JavaServer Pages (JSPs) 6.1. Create Project
  • 16. The following will demonstrate the creation and usage of a JaveServer Page. Create a new Dynamic Web Project calledde.vogella.wtp.jspsimple and a package with the same name. 6.2. Create the JSP Select the folder "WebContent", right-click New → JSP. and create the JSP "FirstJSP". Select the "New JSP File (html)" template. Create the following coding. <%@ page language="java" contentType="text/html; charset=ISO-8859-1" pageEncoding="ISO-8859-1"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  • 17. <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=ISO- 8859-1"> <title>JSP with the current date</title> </head> <body> <%java.text.DateFormat df = new java.text.SimpleDateFormat("dd/MM/yyyy"); %> <h1>Current Date: <%= df.format(new java.util.Date()) %> </h1> </body> </html> 6.3. Run it Start your webapplication. You find your JSP under the URL http://localhost:8080/de.vogella.wtp.jspsimple/FirstJSP.jsp. 6.4. Adjust web.xml Set the JSP page as the welcome page for your application to have it automatically opened if the application is started. Modify theWebContent/WEB-INF/web.xml file. <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5"> <display-name>de.vogella.wtp.jspsimple</display-name> <welcome-file-list> <welcome-file>FirstJSP.jsp</welcome-file>
  • 18. </welcome-file-list> </web-app> This allows to start the JSP via the URL http://localhost:8080/de.vogella.wtp.jspsimple. 7. JSP's and Servlets 7.1. Create Project This example will demonstrate the usage of JSPs for the display and a servlet as the controller for a web application. The servlet will dispatch the request to the correct JSP. Create the Dynamic Web Project "de.vogella.wtp.jsp" and the package "de.vogella.wtp.jsp" 7.2. Create the Controller (servlet) Create a new servlet called Controller in the de.vogella.wtp.jsp.controller package. package de.vogella.wtp.jsp.controller; import java.io.IOException; import java.util.Map; import javax.servlet.RequestDispatcher; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; /** * Servlet implementation class Controller */ public class Controller extends HttpServlet { private static final long serialVersionUID = 1L; private static String DELETE_JSP = "/Delete.jsp"; private static String EDIT_JSP = "/Edit.jsp";
  • 19. private static String SHOWALL_JSP = "/ShowAll.jsp"; protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String forward=""; // Get a map of the request parameters @SuppressWarnings("unchecked") Map parameters = request.getParameterMap(); if (parameters.containsKey("delete")){ forward = DELETE_JSP; } else if (parameters.containsKey("edit")){ forward = EDIT_JSP; } else { forward = SHOWALL_JSP; } RequestDispatcher view = request.getRequestDispatcher(forward); view.forward(request, response); } } This controller checks which parameters are passed to the servlet and then forward the request to the correct JSP. 7.3. Create the Views (JSP) In the folder "WebContent" create the new JSP "ShowAll" with the following code. <%@ page language="java" contentType="text/html; charset=ISO-8859-1" pageEncoding="ISO-8859-1"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=ISO- 8859-1"> <title>Show all names</title>
  • 20. </head> <body> <form method="GET" action='Controller' name="showall"> <table> <tr> <td><input type="checkbox" name="id1" /></td> <td>Jim</td> <td>Knopf</td> </tr> <tr> <td><input type="checkbox" name="id2" /></td> <td>Jim</td> <td>Bean</td> </tr> </table> <p><input type="submit" name="delete" value="delete" />&nbsp; <input type="submit" name="edit" value="edit" />&nbsp; <input type="reset" value="reset" /></p> </form> </body> </html> Create the Delete.jsp JSP. <%@ page language="java" contentType="text/html; charset=ISO-8859-1" pageEncoding="ISO-8859-1"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  • 21. <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=ISO- 8859-1"> <title>Insert title here</title> </head> <body> Delete successful <form method="GET" action='Controller' name="delete_success"><input type="submit" value="back"></form> </body> </html> Create the JSP Edit.jsp. <%@ page language="java" contentType="text/html; charset=ISO-8859-1" pageEncoding="ISO-8859-1"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=ISO- 8859-1"> <title>Insert title here</title> </head> <body> <form method="GET" action='Controller' name="edit"> <table> <tr> <td>First name:</td> <td><input type="text" name="firstName"></td> </tr> <tr>
  • 22. <td>Last name:</td> <td><input type="text" name="lastName"></td> </tr> <tr> <td><input type="submit" value="save"> <input type="reset" value="reset"> <input type="submit" value="back"> </td> </tr> </table> </form> </body> </html> 7.4. Run it Run your new application by running ShowAll.jsp on the server. You should be able to navigate between the pages. 8. Web Archive - How to create a war file from Eclipse ´The following describes how to create a Web Archive (WAR) from Eclipse. Right-click on the project and select Export.
  • 23. Specify the target directory and press Finish.
  • 24. You can now import the WAR file to your production Tomcat system and test the web application. 9. Additional Eclipse WTP resources The development of webservices with Eclipse WTP is covered in Webservices with Axis2 and the Eclipse Web Tool Platform (WTP) - Tutorial. The development of JavaServerFaces is covered in JavaServer Faces (JSF) development with Eclipse WTP JSF - Tutorialand JSF with Apache Myfaces Trinidad and Eclipse. 10. Support this website This tutorial is Open Content under the CC BY-NC-SA 3.0 DE license. Source code in this tutorial is distributed under the Eclipse Public License. See the vogella License page for details on the terms of reuse.
  • 25. Writing and updating these tutorials is a lot of work. If this free community service was helpful, you can support the cause by giving a tip as well as reporting typos and factual errors. 10.1. Thank you Please consider a contribution if this article helped you. 10.2. Questions and Discussion If you find errors in this tutorial, please notify me (see the top of the page). Please note that due to the high volume of feedback I receive, I cannot answer questions to your implementation. Ensure you have read the vogella FAQ as I don't respond to questions already answered there. 11. Links and Literature 11.1. Source Code Source Code of Examples 11.2. Web development resources Introduction into Java Web development 11.3. vogella Resources vogella Training Android and Eclipse Training from the vogella team Android Tutorial Introduction to Android Programming GWT Tutorial Program in Java, compile to JavaScript and HTML Eclipse RCP Tutorial Create native applications in Java JUnit Tutorial Test your application Git Tutorial Put all your files in a distributed version control system