Java ServletConfig
last modified July 13, 2020
Java ServletConfig tutorial shows how to pass initialization data to a servlet with ServletConfig.
ServletConfig is a servlet configuration object used by a
servlet container to pass information to a servlet during initialization.
Servlet container creates a ServletConfig
for each servlet in
a web application.
Java Servlet
Servlet is a Java class which responds to a particular type of network request - most commonly an HTTP request. Java servlets are used to create web applications. They run in servlet containers such as Tomcat or Jetty. Modern-day Java web development uses frameworks that are built on top of servlets.
Pure.css
Pure.css is a set of small, responsive CSS modules that can be used in every web project. The library is created by Yahoo.
Java ServletConfig example
In the following web application, we have a simple web form. We sent a name parameter
to the servlet. If the parameter is empty, we read an initialization parameter through
ServletConfig
. In the example, we also use Yahoo's Pure.css library.
$ tree . ├── nb-configuration.xml ├── pom.xml └── src ├── main │ ├── java │ │ └── com │ │ └── zetcode │ │ └── web │ │ └── MyServlet.java │ └── webapp │ ├── index.html │ ├── META-INF │ │ └── context.xml │ └── WEB-INF └── test └── java
This is the project structure.
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.zetcode</groupId> <artifactId>JavaServletConfigEx</artifactId> <version>1.0-SNAPSHOT</version> <packaging>war</packaging> <name>JavaServletConfigEx</name> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <maven.compiler.source>1.8</maven.compiler.source> <maven.compiler.target>1.8</maven.compiler.target> </properties> <dependencies> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>3.1.0</version> <scope>provided</scope> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-war-plugin</artifactId> <version>2.3</version> <configuration> <failOnMissingWebXml>false</failOnMissingWebXml> </configuration> </plugin> </plugins> </build> </project>
This is the Maven pom.xml
file. The javax.servlet-api
artifact is
used for Java servlets. The maven-war-plugin
is responsible for collecting all
artifact dependencies, classes and resources of the web application and packaging them
into a web application archive (WAR).
<?xml version="1.0" encoding="UTF-8"?> <Context path="/JavaServletConfigEx"/>
In the Tomcat context.xml
file, we define the context path. It
is the name of the web application.
<!DOCTYPE html> <html> <head> <title>Home Page</title> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1"> <link rel="stylesheet" href="https://unpkg.com/purecss@1.0.0/build/pure-min.css"> </head> <body> <form class="pure-form" action="MyServlet"> <fieldset> <legend>Enter your name</legend> <input type="text" name="name"> <button type="submit" class="pure-button pure-button-primary">Submit</button> </fieldset> </form> </body> </html>
This is the home page. It contains an HTML
form. Upon submitting the form,
the processing is sent to the MyServlet
.
<link rel="stylesheet" href="https://unpkg.com/purecss@1.0.0/build/pure-min.css">
We include the Pure.css library.
<form class="pure-form" action="MyServlet">
The form
tag uses the pure-form
class from the Pure.css
library. The action
attribute points to the MyServlet
.
<input type="text" name="name">
The name value entered by the user will be sent to the servlet as a name
parameter.
<button type="submit" class="pure-button pure-button-primary">Submit</button>
The Submit button uses pure-button
and pure-button-primary
classes.
package com.zetcode.web; import java.io.IOException; import javax.servlet.ServletConfig; import javax.servlet.ServletException; import javax.servlet.ServletOutputStream; import javax.servlet.annotation.WebServlet; import javax.servlet.annotation.WebInitParam; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; @WebServlet(name = "MyServlet", urlPatterns = {"/MyServlet"}, initParams = { @WebInitParam(name = "name", value = "Guest")}) public class MyServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/plain;charset=UTF-8"); String name = request.getParameter("name"); name = name.trim(); if (name.isEmpty()) { ServletConfig sc = getServletConfig(); name = sc.getInitParameter("name"); } ServletOutputStream os = response.getOutputStream(); os.println("Hello " + name); } }
The MyServlet
reads the name
attribute from the request and
generates output. The output is plain text.
@WebServlet(name = "MyServlet", urlPatterns = {"/MyServlet"}, initParams = { @WebInitParam(name = "name", value = "Guest")})
With @WebInitParam
, we initialize a name
parameter
to the "Guest" value.
String name = request.getParameter("name"); name = name.trim();
We read the name
parameter from the request object and trim spaces.
if (name.isEmpty()) { ServletConfig sc = getServletConfig(); name = sc.getInitParameter("name"); }
If no value was entered by the user, we read the name
initialization parameter using ServletConfig
. ServletConfig
is retrieved with getServletConfig
. The parameter is retrieved with
getInitParameter
.
ServletOutputStream os = response.getOutputStream(); os.println("Hello " + name);
We write the text message to the ServletOutputStream
.
In this tutorial, we have used ServletConfig
to read an
initialization parameter in a Java servlet.