excel导出servlet

首先导入jar包

c3p0-0.9.2.1.jar

commons-fileupload-1.2.2.jar

mchange-commons-java-0.2.3.4.jar

mysql-connector-java-5.0.5

lombok-1.16.20.jar

poi-3.17.jar

ueditor-mini.jar

web.xml文件:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1">
  <display-name>excel_export_servlet</display-name>
  <welcome-file-list>
    <welcome-file>index.html</welcome-file>
    <welcome-file>index.htm</welcome-file>
    <welcome-file>index.jsp</welcome-file>
    <welcome-file>default.html</welcome-file>
    <welcome-file>default.htm</welcome-file>
    <welcome-file>default.jsp</welcome-file>
  </welcome-file-list>
</web-app>

c3p0-config.xml文件:

<?xml version="1.0" encoding="UTF-8"?>
<c3p0-config>
<!-- 第一种配置方法 获取方法DataSource ds = new ComboPooledDataSource(); <default-config> 
</default-config> 第二种配置方法可以指定数据库 获取方法 DataSource ds = new ComboPooledDataSource("mysql"); 
<named-config name="mysql"></named-config> -->


<named-config name="mysql">
<!--JDBC驱动 -->
<property name="driverClass">com.mysql.jdbc.Driver</property>
<!--数据库地址 -->
<property name="jdbcUrl">jdbc:mysql://192.168.26.3:3306/two?useUnicode=true&amp;characterEncoding=utf8
</property>
<!--用户名。Default: null -->
<property name="user">root</property>
<!--密码。Default: null -->
<property name="password">root</property>
<!--初始化时获取三个连接,取值应在minPoolSize与maxPoolSize之间。Default: 3 -->
<property name="initialPoolSize">3</property>
<!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 -->
<property name="maxIdleTime">60</property>
<!--连接池中保留的最大连接数。Default: 15 -->
<property name="maxPoolSize">100</property>
<!--连接池中保留的最少连接数。Default: 15 -->
<property name="minPoolSize">5</property>
<!--JDBC的标准参数,用以控制数据源内加载的PreparedStatements数量。但由于预缓存的statements  属于单个connection而不是整个连接池。所以设置这个参数需要考虑到多方面的因素。 
如果maxStatements与maxStatementsPerConnection均为0,则缓存被关闭。Default: 0 -->
<property name="maxStatements">200</property>
</named-config>
</c3p0-config>

实体类:

package com.xy.excel.bean;


import lombok.Data;


@Data
public class User {


private Integer uid;
private String uname;
private String uaddress;
public User(Integer uid, String uname, String uaddress) {
super();
this.uid = uid;
this.uname = uname;
this.uaddress = uaddress;
}
public User(Integer uid) {
super();
this.uid = uid;
}

}

持久层dao:

接口:

package com.xy.excel.dao;


import java.util.List;


import com.xy.excel.bean.User;


public interface UserDao {


List<User>query();
}

实现类:

package com.xy.excel.dao.impl;


import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;


import com.xy.excel.bean.User;
import com.xy.excel.dao.UserDao;
import com.xy.excel.utils.DBUtils;


public class UserDaoImpl implements UserDao{


@Override
public List<User> query() {
List<User> list = new ArrayList<>();
Connection conn= DBUtils.getConnection();
String sql="select * from users ";
PreparedStatement pstmt=DBUtils.getPreparedStatement(conn, sql,null);
ResultSet rs=DBUtils.getResultSet(pstmt);
try {
if(rs.next()){
int uid = rs.getInt("uid");
String uname = rs.getString("uname");
String uaddress = rs.getString("uaddress");
User u = new User(uid, uname, uaddress);
list.add(u);
}
} catch (Exception e) {
e.printStackTrace();
}
DBUtils.close(rs);
DBUtils.close(pstmt);
DBUtils.close(conn);
return list;
}


}

控制层servlet:

package com.xy.excel.sevlet;


import java.io.IOException;
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;


import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;


import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFFont;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.HorizontalAlignment;
import org.apache.poi.ss.usermodel.VerticalAlignment;
import org.apache.poi.ss.util.CellRangeAddress;


import com.xy.excel.bean.User;
import com.xy.excel.dao.UserDao;
import com.xy.excel.dao.impl.UserDaoImpl;


/**
 * 访问路径:http://localhost:8080/excel_export_servlet/index.jsp
 * Servlet implementation class UserServlet
 */
@WebServlet("/UserServlet")
public class UserServlet extends HttpServlet {
private UserDao userDao = new UserDaoImpl();
private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public UserServlet() {
        super();
        // TODO Auto-generated constructor stub
    }


/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doPost(request, response);
}


/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//准备要导出来的数据
List<User> user = userDao.query();

try {
exportUserExcel(response,user);
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 提取头部公共的样式
*/
private HSSFCellStyle createTitleStyle(HSSFWorkbook workbook, int fontSize){
HSSFCellStyle style = workbook.createCellStyle();

style.setAlignment(HorizontalAlignment.CENTER);//设置水平居中

style.setVerticalAlignment(VerticalAlignment.CENTER);//设置垂直居中

//创建字体样式
HSSFFont font = workbook.createFont();

font.setFontHeightInPoints((short)fontSize);

font.setBold(true);//设置字体样式   如加粗,斜体 等

font.setFontName("华文行楷");

style.setFont(font);
        
return style;
}
/**
* 提取小标题公共的样式 
* @param workbook
* @param fontSize
* @return
*/
private  HSSFCellStyle createSecondTitleStyle(HSSFWorkbook workbook, int fontSize) {
HSSFCellStyle style = workbook.createCellStyle();

        style.setAlignment(HorizontalAlignment.CENTER);//设置水平居中

        style.setVerticalAlignment(VerticalAlignment.CENTER);//设置垂直居中

        // 创建一个字体样式

        HSSFFont font = workbook.createFont();

        font.setFontHeightInPoints((short)fontSize);

        font.setBold(true);

        style.setFont(font);

        return style;
}
/**

     * 提取表格头部的样式

     * 

     * @param workbook

     * @param fontSize

     * @return

     */

   private  HSSFCellStyle createDataHeaderStyle(HSSFWorkbook workbook, int fontSize) {

        HSSFCellStyle style = workbook.createCellStyle();

        style.setAlignment(HorizontalAlignment.CENTER);//设置水平居中

        style.setVerticalAlignment(VerticalAlignment.CENTER);//设置垂直居中

        // 创建一个字体样式

        HSSFFont font = workbook.createFont();

        font.setFontHeightInPoints((short)fontSize);

        font.setBold(true);

        style.setFont(font);

        return style;

    }

    /**
    
         * 提取表格数据的样式
   
         * 
   
         * @param workbook
   
         * @param fontSize
   
         * @return
    
         */
   
private  HSSFCellStyle createDataStyle(HSSFWorkbook workbook, int fontSize) {
   
            HSSFCellStyle style = workbook.createCellStyle();
   
            style.setAlignment(HorizontalAlignment.CENTER);//设置水平居中
   
            style.setVerticalAlignment(VerticalAlignment.CENTER);//设置垂直居中
   
            // 创建一个字体样式
   
            HSSFFont font = workbook.createFont();
   
            font.setFontHeightInPoints((short)fontSize);
   
            style.setFont(font);
  
            return style;
    
        }  

/**
* 创建导出的方法
* @param response
* @param users
* @throws Exception
*/
public void  exportUserExcel(HttpServletResponse response,List<User> users) throws Exception{
//声明文件名

        String fileName="用户数据.xls";

        //处理文件名

        try {

            fileName=URLEncoder.encode(fileName, "utf-8");

        } catch (Exception e) {

            e.printStackTrace();

        }

        //处理文件类型

        response.setContentType("application/x-download");

        // 设置下载的文件名

        response.setHeader("Content-Disposition", "attachment; filename=\"" + fileName + "\"");

        //创建一个工作表

        HSSFWorkbook workbook = new HSSFWorkbook();//是一个空的,没有sheet的excel

        //创建sheet并取名

        HSSFSheet sheet = workbook.createSheet("用户数据");

        //设置整个Excel表格的列的默认宽度

        sheet.setDefaultColumnWidth((short) 30);

        //开始写数据

        int row=0;

        //写第一行数据

        HSSFRow titleRow = sheet.createRow(row);

        //在第一行里面创建列

        HSSFCell titleCell = titleRow.createCell(0);

        //创建合并的对象

        /**

         * 参数1:开始行  参数2:结束行   参数3  开始列    参数4 :结束列的下标  

         */

        CellRangeAddress region=new CellRangeAddress(row, row, 0, 2);

        //合并

        sheet.addMergedRegion(region);

        //设置合并后的列的的数据

        titleCell.setCellValue("用户数据");

        //从公共方法里面提取样式 

        HSSFCellStyle titleStyle = this.createTitleStyle(workbook, 25);

        //把样式应该到Cell里面

        titleCell.setCellStyle(titleStyle);

        

        

        //第二行

        row++;
      HSSFRow secondTitleRow = sheet.createRow(row);

        //在第二行里面创建列

        HSSFCell secondCell = secondTitleRow.createCell(0);

        CellRangeAddress region2=new CellRangeAddress(row, row, 0, 2);

        //合并

        sheet.addMergedRegion(region2);

        //设置合并后的列的的数据

        secondCell.setCellValue("总数:"+users.size()+"条,导出时间:"+new Date().toLocaleString());

        //从公共方法里面提取样式 

        HSSFCellStyle secondTitleStyle = this.createSecondTitleStyle(workbook, 14);

        //把样式应该到Cell里面

        secondCell.setCellStyle(secondTitleStyle);

        

        

        String[] headers={"用户ID","用户姓名","用户地址"};

        //第三行 是头部数据   

        row++;

        HSSFRow rowHeader = sheet.createRow(row);

        HSSFCellStyle dataHeaderStyle = this.createDataHeaderStyle(workbook, 12);

        for (int i = 0; i < headers.length; i++) {

            HSSFCell cell = rowHeader.createCell(i);

            cell.setCellValue(headers[i]);

            cell.setCellStyle(dataHeaderStyle);

        }

        //第四行到最后都是用户数据

        HSSFCellStyle dataStyle = this.createDataStyle(workbook, 12);

        for (int i = 0; i < users.size(); i++) {

            row++;

            User user = users.get(i);

            HSSFRow rowData = sheet.createRow(row);

            String [] data={user.getUid()+"",user.getUname(),user.getUaddress()};

            for (int j = 0; j < data.length; j++) {

                HSSFCell cell = rowData.createCell(j);

                cell.setCellValue(data[j]);

                cell.setCellStyle(dataStyle);

            }

        }

        //把它写出去

        workbook.write(response.getOutputStream());

        
}


}
页面,只是测试,很简单的一个a标签

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!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=UTF-8">
<title>Insert title here</title>
</head>
<body>
<h1>
<a href="UserServlet">导出所有数据</a>
</h1>
</body>
</html>
启动tomcat后访问:访问路径:http://localhost:8080/excel_export_servlet/index.jsp

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值