Export Grid View to Excel in Servlet and Jsp
Exporting contents to excel spreadsheet is a much required functionality for almost every data driven website. In this article I am going to explain in detail on how to export gridview contents to an excel sheet via a java web application.
Project Structure

Servlet
package servlet;
import java.io.IOException;
import java.util.ArrayList;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import model.Student;
public class ExportToExcel extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doGet(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
ArrayList<Student> students = new ArrayList<Student>();
students.add(new Student("Mohaideen", "CSE", 17));
students.add(new Student("Nilafar", "IT", 16));
students.add(new Student("Thasleema", "CSE", 16));
request.setAttribute("students", students);
RequestDispatcher rd = request.getRequestDispatcher("report.jsp");
rd.forward(request, response);
}
protected void doPost(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
ArrayList<Student> students = new ArrayList<Student>();
students.add(new Student("Mohaideen", "CSE", 17));
students.add(new Student("Nilafar", "IT", 16));
students.add(new Student("Thasleema", "CSE", 16));
request.setAttribute("students", students);
RequestDispatcher rd = request.getRequestDispatcher("exportExcel.jsp");
rd.forward(request, response);
}
}
Model
package model;
public class Student {
private String name;
private String department;
private int age;
public Student(String name, String department, int age) {
this.name = name;
this.department = department;
this.age = age;
}
public String getName() {
return name;
}
public String getDepartment() {
return department;
}
public int getAge() {
return age;
}
public void setName(String name) {
this.name = name;
}
public void setDepartment(String department) {
this.department = department;
}
public void setAge(int age) {
this.age = age;
}
}
JSP Page
File : index.jsp – Used to navigate to exporttoexcel servlet action
<html> <head> <META HTTP-EQUIV="Refresh" CONTENT="0;URL=exporttoexcel"> </head> <body> </body> </html>
File : report.jsp – This page used to display gridview filled with data of student table from server side.
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<%@ page import="java.util.List"%>
<%@ page import="model.Student"%>
<html>
<head>
<title>Export to Excel</title>
</head>
<body>
<h3>Export to Excel Example</h3>
<form action="exporttoexcel" method="post">
<table cellpadding="1" cellspacing="1" border="1" bordercolor="gray">
<tr>
<td><b>Name</b></td>
<td><b>Department</b></td>
<td><b>Age</b></td>
</tr>
<%
List<Student> students = (List<Student>) request
.getAttribute("students");
for (Student std : students) {
%>
<tr>
<td><%=std.getName()%></td>
<td><%=std.getDepartment()%></td>
<td><%=std.getAge()%></td>
</tr>
<%
}
%>
</table>
<BR /> <input type="submit" value="Export To Excel" />
</form>
</body>
</html>
File : exportExcel.jsp
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<%@ page import="java.util.List"%>
<%@ page import="model.Student"%>
<html>
<head>
<title>Export to Excel Example</title>
</head>
<body>
<h3>Export to Excel Example</h3>
<table cellpadding="1" cellspacing="1" border="1" bordercolor="gray">
<tr>
<td>Name</td>
<td>Department</td>
<td>Age</td>
</tr>
<%
List<Student> students = (List<Student>) request.getAttribute("students");
if (students != null) {
response.setContentType("application/vnd.ms-excel");
response.setHeader("Content-Disposition", "inline; filename="
+ "StudentReport.xls");
}
for (Student std : students) {
%>
<tr>
<td><%=std.getName()%></td>
<td><%=std.getDepartment()%></td>
<td><%=std.getAge()%></td>
</tr>
<%
}
%>
</table>
</body>
</html>
web.xml
<web-app .. version="3.0">
<display-name>ExportToExcel</display-name>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<servlet>
<servlet-name>ExportToExcel</servlet-name>
<servlet-class>servlet.ExportToExcel</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>ExportToExcel</servlet-name>
<url-pattern>/exporttoexcel</url-pattern>
</servlet-mapping>
</web-app>
Demo
On running the application

On clicking “Export To Excel” button the following page with download file options get appears



