In this tutorial, I will guide you how to implement login and logout functions for a small Java web application using Servlet, JSP, JDBC and MySQL. Just plain old, core Java EE technologies. No frameworks are used.

Suppose that you have an existing Java web project and now you wish to add the login and logout features for your website.

Table of content:

1. Create database table used for authentication

2. The User model class

3. Code Check Login method

4. Code Login Page

5. Code Login Servlet Class

6. Code Logout Servlet Class

7. Test Login and Logout Functions

 

1. Create database table used for authentication

In the login page, the user enters email and password – so we need to verify that login information against data in a database table, typically the users table.

Make sure that the table you use for authentication has at least 3 fields: fullname, email and password.

Here’s the structure of the table users I use for this tutorial:

database table users

If you haven’t created any table for authentication, execute the following MySQL script to create one:

CREATE TABLE `users` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `email` varchar(45) NOT NULL,
  `password` varchar(45) NOT NULL,
  `fullname` varchar(45) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB;

Of course you can add additional fields to this table if you want.


2. The User model class

Next, create a plain old Java object (POJO) class that represents a user:

package net.codejava;

public class User {
	private int id;
	private String fullname;
	private String email;
	private String password;

	// getters and setters are not shown for brevity	
	
}

You should generate getter and setter methods for all fields of this class. They are not shown in the above code or brevity.


3. Code Check Login method

Next, we need to implement a method that checks the login information entered by the user against the data in the database. So create UserDAO class with the following code:

package net.codejava;

import java.sql.*;

public class UserDAO {

	public User checkLogin(String email, String password) throws SQLException, 
			ClassNotFoundException {
		String jdbcURL = "jdbc:mysql://localhost:3306/bookshop";
		String dbUser = "root";
		String dbPassword = "password";

		Class.forName("com.mysql.jdbc.Driver");
		Connection connection = DriverManager.getConnection(jdbcURL, dbUser, dbPassword);
		String sql = "SELECT * FROM users WHERE email = ? and password = ?";
		PreparedStatement statement = connection.prepareStatement(sql);
		statement.setString(1, email);
		statement.setString(2, password);

		ResultSet result = statement.executeQuery();

		User user = null;

		if (result.next()) {
			user = new User();
			user.setFullname(result.getString("fullname"));
			user.setEmail(email);
		}

		connection.close();

		return user;
	}
}

Note that the database connection information specified in the beginning of the checkLogin() method. You should update the JDBC URL, username and password accordingly to MySQL on your computer.

You can see checkLogin() method returns a non-null User object if the email and password are found in the database. Otherwise null is returned.

To learn more about database programming in Java, read this JDBC tutorial.


4. Code Login Page

Write code for the login page (login.jsp) with the following code:

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Bookshop Website</title>
</head>
<body>
	<div style="text-align: center">
		<h1>Admin Login</h1>
		<form action="login" method="post">
			<label for="email">Email:</label>
			<input name="email" size="30" />
			<br><br>
			<label for="password">Password:</label>
			<input type="password" name="password" size="30" />
			<br>${message}
			<br><br>			
			<button type="submit">Login</button>
		</form>
	</div>
</body>
</html>

When running, this login page looks like this:

login page form

Note that in the login.jsp page, we use an EL expression ${message} to display the message sent from the server – typically to tell the user that the login failed.

If you want to validate the fields in the form before the form is submitted, add the following script tags inside the <head> section of the page:

<script
  src="https://code.jquery.com/jquery-3.4.1.min.js"
  integrity="sha256-CSXorXvZcTkaix6Yvo6HppcZGetbYMGWSFlBw8HfCJo="
  crossorigin="anonymous"></script>
<script type="text/javascript" 
	src="https://cdn.jsdelivr.net/npm/jquery-validation@1.19.0/dist/jquery.validate.min.js"></script>

Here we use 2 jQuery libraries (core and validation) from CDN websites.

And add the following jQuery code before the closing </html> tag:

<script type="text/javascript">

	$(document).ready(function() {
		$("#loginForm").validate({
			rules: {
				email: {
					required: true,
					email: true
				},
		
				password: "required",
			},
			
			messages: {
				email: {
					required: "Please enter email",
					email: "Please enter a valid email address"
				},
				
				password: "Please enter password"
			}
		});

	});
</script>

This script validates the email and password fields are not empty, and the user must enter a valid email address. You can use plain Javascript to validate the form’s fields, but using jQuery is more convenient.


5. Code Login Servlet Class

On the server side, create a Java servlet class to handle the submission of the login form above. Here’s the code:

package net.codejava;

import java.io.*;
import java.sql.SQLException;

import javax.servlet.*;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.*;

@WebServlet("/login")
public class UserLoginServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;

	public UserLoginServlet() {
		super();
	}

	protected void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		String email = request.getParameter("email");
		String password = request.getParameter("password");
		
		UserDAO userDao = new UserDAO();
		
		try {
			User user = userDao.checkLogin(email, password);
			String destPage = "login.jsp";
			
			if (user != null) {
				HttpSession session = request.getSession();
				session.setAttribute("user", user);
				destPage = "home.jsp";
			} else {
				String message = "Invalid email/password";
				request.setAttribute("message", message);
			}
			
			RequestDispatcher dispatcher = request.getRequestDispatcher(destPage);
			dispatcher.forward(request, response);
			
		} catch (SQLException | ClassNotFoundException ex) {
			throw new ServletException(ex);
		}
	}
}

As you can see, the doPost() method handles the request to login from the client. It calls the checkLogin() method of the UserDAO class to verify email and password against the database.

If the login succeeds, it sets an attribute in the session to store information about the logged in user, and forwards the request to the admin home page:

if (user != null) {
	HttpSession session = request.getSession();
	session.setAttribute("user", user);
	destPage = "home.jsp";
}

To learn more about session handling in Java, read this Java session tutorial.

If the login fails, sets error message as an attribute in the request, and forwards to the login page again:

} else {
	String message = "Invalid email/password";
	request.setAttribute("message", message);
}

You can learn more about redirection in Java servlet here.

And code of the home.jsp page is as follows:

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Admin CPanel - Bookshop</title>
</head>
<body>
	<div style="text-align: center">
		<h1>Welcome to Bookshop Website Admin Panel</h1>
		<b>${user.fullname} (${user.email})</b>
		<br><br>
		<a href="/logout">Logout</a>
	</div>
</body>
</html>

Note that we use EL expression ${user.fullname} to display the full name and ${user.email} to show the email of the logged in user. And there is a logout link that allows the user to logout from the website.

You can learn more about EL operators in JSP by reading this EL operators summary article.


6. Code Logout Servlet Class

To implement the logout function, create a Java servlet class to handle request to logout from the client as follows:

package net.codejava;

import java.io.IOException;

import javax.servlet.*;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.*;

@WebServlet("/logout")
public class UserLogoutServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;

	public UserLogoutServlet() {
		super();
	}

	protected void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		HttpSession session = request.getSession(false);
		if (session != null) {
			session.removeAttribute("user");
			
			RequestDispatcher dispatcher = request.getRequestDispatcher("login.jsp");
			dispatcher.forward(request, response);
		}
	}
}

As you can see, we check if a session exists, remove the attribute user which is set in the login function, and forward the request to the login page.


7. Test Login and Logout Functions

You can download the sample project in the attachments section at the end of this tutorial to run and test. Suppose that we have the following data in the table users:

data in table users

Access the login page showing the following screen:

test login form

Try to enter an invalid email and blank password, you will see the validation error message appears like this:

login validation error

Now let’s enter correct email and password and click Login, you will see the admin home page appears as follows:

login success home page

You can see the full name and email of the logged in user are displayed on this page.

Click the Logout link and you will see it redirects to the login page.

That’s how to implement the login and logout functions for a Java web application using Java Servlet, JSP, JDBC and MySQL. It’s very simple so you can easily add to your existing small project, without using any frameworks.

However, to fully secure login-required pages of a website, you need to implement an authentication filter.

By the way, I have a video course that teaches you how to build a complete Java web application (e-commerce). You can learn here.

 

Other Java Coding Tutorials:


About the Author:

is certified Java programmer (SCJP and SCWCD). He began programming with Java back in the days of Java 1.4 and has been passionate about it ever since. You can connect with him on Facebook and watch his Java videos on YouTube.

Attachments:
Download this file (LoginLogoutServletJSP.zip)LoginLogoutServletJSP.zip[Java Login Logout Sample Project]20 kB

Add comment

   


Comments 

#17Nancy2024-05-08 10:33
Needing to test servlet
Quote
#16Kapil patel2024-04-06 00:56
as a student i am learnig servlet
Quote
#15asger2023-10-23 03:59
Very educational! However, of course a password should never be stored as plaintext in a database for real-life applications. Salt your passwords, people!
Quote
#14Aran2023-01-28 17:22
Thank you for the tutorial, however I can bypass the login page by directly accessing the home.jsp page from the browser localhost:8080/home.jsp

How do I prevent access to html or jsp webpages that are already created?
Quote
#13Ramprasad2021-11-10 12:55
Nam Ha Minh..your website is very useful for learning purpose.....it's very nice your website...Thank's go ahead..
Quote