java ajax 导出excel文件_springMVC(4)---生成excel文件并导出

springMVC(4)---生成excel文件并导出

在开发过程中,需要将数据库中的数据以excel表格的方式导出。

首先说明。我这里用的是Apache的POI项目,它是目前比较成熟的HSSF接口,用来处理Excel对象。其实POI不仅仅只能处理excel,它还可以处理word、PowerPoint、Visio、甚至Outlook。

一.首先介绍利用POI如何生成excel。

首先在生成Excel前,我们需要理解一下Excel文件的组织形式。在POI中,是这样理解的:一个Excel文件对应一个workbook,一个workerbook是有若干个sheet组成的。一个sheet有多个row,一个row一般存在多个cell。

对于上面的四个名词我们可以在下图理解:

2dab9eaf572571502c4116fbde32831f.png

对于生成Excel,POI提供了如下几个基本对象:

HSSFWorkbook             excel 的文档对象

HSSFSheet                excel 的表单

HSSFRow                  excel 的行

HSSFCell                 excel 的格子单元

从上面的图片和Excel的组织结构,我们就可以明白创建Excel的步骤。

1、生成文档对象HSSHWorkbook。

2、通过HSSFWorkbook生成表单HSSFSheet。

3、通过HSSFSheet生成行HSSFRow

4、通过HSSFRow生成单元格HSSFCell。

下面展示代码:

第一步、导入jar包

org.apache.poi

poi-ooxml

3.9

第二步,创建Model对象

public classPerson {privateString id;privateString name;privateString password;privateString age;publicPerson(String id, String name, String password, String age) {super();this.id =id;this.name =name;this.password =password;this.age =age;

}//提供set和get方法

}

第三步.下载界面 exportexcel.jsp

functiondownload(){varurl="download_excel?id=10&name=张三";

window.open(url);

}

第四步、ExcleController.java

importjava.io.UnsupportedEncodingException;importjava.net.URLEncoder;importjavax.servlet.ServletOutputStream;importjavax.servlet.http.HttpServletResponse;importorg.springframework.stereotype.Controller;importorg.springframework.web.bind.annotation.RequestMapping;importorg.springframework.web.bind.annotation.RequestParam;importorg.springframework.web.bind.annotation.ResponseBody;importcom.ssm.service.impl.ExcleImpl;

@Controllerpublic classExcleController {//这里直接new了

ExcleImpl excleImpl=newExcleImpl();

@RequestMapping(value="/jsp/download_excel")//获取url链接上的参数

public @ResponseBody String dowm(HttpServletResponse response,@RequestParam("id") String id,@RequestParam("name") String name){

response.setContentType("application/binary;charset=UTF-8");try{

ServletOutputStream out=response.getOutputStream();try{//设置文件头:最后一个参数是设置下载文件名(这里我们叫:张三.pdf)

response.setHeader("Content-Disposition", "attachment;fileName=" + URLEncoder.encode(name+".xls", "UTF-8"));

}catch(UnsupportedEncodingException e1) {

e1.printStackTrace();

}

String[] titles= { "用户id", "用户姓名", "用户密码", "用户年龄"};

excleImpl.export(titles, out);return "success";

}catch(Exception e){

e.printStackTrace();return "导出信息失败";

}

}

}

第五步、ExcleImpl 报表导出实现层

importjava.util.ArrayList;importjavax.servlet.ServletOutputStream;importorg.apache.poi.hssf.usermodel.HSSFCell;importorg.apache.poi.hssf.usermodel.HSSFCellStyle;importorg.apache.poi.hssf.usermodel.HSSFRow;importorg.apache.poi.hssf.usermodel.HSSFSheet;importorg.apache.poi.hssf.usermodel.HSSFWorkbook;importcom.ssm.model.Person;public classExcleImpl {public void export(String[] titles, ServletOutputStream out) throwsException{try{//第一步,创建一个workbook,对应一个Excel文件

HSSFWorkbook workbook = newHSSFWorkbook();//第二步,在webbook中添加一个sheet,对应Excel文件中的sheet

HSSFSheet hssfSheet = workbook.createSheet("sheet1");//第三步,在sheet中添加表头第0行,注意老版本poi对Excel的行数列数有限制short

HSSFRow row= hssfSheet.createRow(0);//第四步,创建单元格,并设置值表头 设置表头居中

HSSFCellStyle hssfCellStyle =workbook.createCellStyle();//居中样式

hssfCellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);

HSSFCell hssfCell= null;for (int i = 0; i < titles.length; i++) {

hssfCell= row.createCell(i);//列索引从0开始

hssfCell.setCellValue(titles[i]);//列名1

hssfCell.setCellStyle(hssfCellStyle);//列居中显示

}//第五步,写入实体数据

Person person1=new Person("1","张三","123","26");

Person person2=new Person("2","李四","123","18");

Person person3=new Person("3","王五","123","77");

Person person4=new Person("4","徐小筱","123","1");//这里我把list当做数据库啦

ArrayList list=new ArrayList();

list.add(person1);

list.add(person2);

list.add(person3);

list.add(person4);for (int i = 0; i < list.size(); i++) {

row= hssfSheet.createRow(i+1);

Person person=list.get(i);//第六步,创建单元格,并设置值

String id = null;if(person.getId() != null){

id=person.getId();

}

row.createCell(0).setCellValue(id);

String name= "";if(person.getName() != null){

name=person.getName();

}

row.createCell(1).setCellValue(name);

String password= "";if(person.getPassword() != null){

password=person.getPassword();

}

row.createCell(2).setCellValue(password);

String age=null;if(person.getAge() !=null){

age=person.getAge();

}

row.createCell(3).setCellValue(age);

}//第七步,将文件输出到客户端浏览器

try{

workbook.write(out);

out.flush();

out.close();

}catch(Exception e) {

e.printStackTrace();

}

}catch(Exception e){

e.printStackTrace();throw new Exception("导出信息失败!");

}

}

}

第六步:最终效果,当我点击报表导出按钮

4f319b7070ee741f00d01cbebe7a1415.png

完美!

想的太多,做的太少,中间的落差就是烦恼,要么去做,要么别想 少尉【11】

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/442430.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java swing 模拟发牌_用java设计一个发牌程序

展开全部// 发牌程序。import java.awt.*;import java.awt.event.*;import javax.swing.*;public class CardBuffer //加互斥锁的缓冲区{private int value;private boolean isEmpty true; //value是否为空的信号量private int order0; //信号量&#xff0c;e68a8462616964757…

Java写文件导致io过高_161108、Java IO流读写文件的几个注意点

平时写IO相关代码机会挺少的&#xff0c;但却都知道使用BufferedXXXX来读写效率高&#xff0c;没想到里面还有这么多陷阱&#xff0c;这两天突然被其中一个陷阱折腾一下&#xff1a;读一个文件&#xff0c;然后写到另外一个文件&#xff0c;前后两个文件居然不一样&#xff1f;…

java接口测试框架搭建_接口自动化测试框架搭建

一、原理及特点参数放在XML文件中进行管理用httpClient简单封装一个httpUtils工具类测试用例管理使用了testNg管理&#xff0c;使用了TestNG参数化测试&#xff0c;通过xml文件来执行case。测试报告这里用到第三方的包ReportNG 项目组织用Maven二、准备使用工具&#xff1a;ecl…

java工厂模式 uml_深入浅出设计模式-简单工厂模式

模式定义简单工厂模式是属于创建型模式&#xff0c;又叫做静态工厂方法(Static Factory Method)模式&#xff0c;但不属于23种GOF设计模式之一。简单工厂模式定义了一个创建对象的类&#xff0c;由这个类来封装实例化对象的行为。设计原则遵循的原则&#xff1a;依赖倒置原则迪…

java技术难点_Java核心技术第四章----对象与类重难点总结

一、类之间的关系类和类之间的关系&#xff0c;耦合度从高到低&#xff1a;is -a。继承、实现has-a。组合、聚合、关联user-a。依赖。要求是&#xff1a;高内聚、低耦合。继承(“is-a”)继承(Inheritance)&#xff0c;即“is-a”关系&#xff0c;是一种用于表示特殊与一般关系的…

java日志级别的作用_Java系统日志级别对性能的影响性

先介绍下java系统的日志日志框架&#xff1a;是一种日志接口&#xff0c;不负责具体的日志输出形式(有点类似于JDBC)&#xff0c;可以灵活的切换日志输出形式。常见的日志框架有slf4j、jcl&#xff0c;只提供Logger、LoggerFactory等接口日志系统&#xff1a;是应用实际使用的日…

java用链表做学生系统_C语言链表实现学生管理系统

本文实例为大家分享了C语言链表实现学生管理系统的具体代码&#xff0c;供大家参考&#xff0c;具体内容如下#include#include#include#include#include#includeusing namespace std;typedef struct ndoe{char id[10];char name[10];char sex[3];char num[10];struct node *nex…

mysql 全文本检索的列_Mysql 全文本检索

mysql 全文索引注意 并非所有的引擎都支持 全文检索mysql最常用的引擎 INnodb 和 myisam 后者支持全文检索 前者不支持创建表的时候指定要检索列 CREATE TABLE TEST_FULLTEXT(note_id int not null auto_increment,note_text text null, primaty key(note_id),FULLTEXT(note_te…

java 的对象类用_java基础(第零篇)对象与类

前言&#xff1a;本文讲述java中对象与类的一些概念。包括对象与类的有关概念&#xff0c;类间五种关系&#xff0c;类的访问权限等。在java中&#xff0c;一切都可以用对象来描述&#xff0c;操作对象的标识符只不过是对象的一个引用&#xff0c;一个对象可以有多个引用&#…

buffer java nio_Java NIO深入理解Buffer(缓冲区)

前言Github&#xff1a;https://github.com/yihonglei/java-allProject&#xff1a;java-nio一 Buffer概述Java NIO中的Buffer用于和NIO通道进行交互。数据是从通道读入缓冲区&#xff0c;从缓冲区写入到通道中的。缓冲区本质上是一块可以写入数据&#xff0c;然后可以从中读取…

java robot键值_Java:使用Robot类模拟键盘, 以Alt码方式输出汉字

java.awt.Robot类Java提供java.awt.Robot类来模拟操作键盘和鼠标, 下面是一个简单的demopublic static void keyPressByInt(Robot r,int key, int time){r.keyPress(key);r.keyRelease(key);if (time > 0) {r.delay(time);}}public static void main(String[] args) throws …

java调用 火眼臻睛,火眼臻睛车牌识别SDK评测

【CPS中安网 cps.com.cn】CPS LAB总评:用专业角度解读产品--CPS评测中心对火眼臻睛车牌识别SDK进行了全面评测,火眼臻睛车牌识别SDK在综合识别率、车牌定位成功率、大角度下的识别率、夜间环境下的识别率、极端环境下的识别率、支持的最小车牌像素宽度等测试表现,都位于行业前列…

java各层级限流对比,面试官说:来谈谈限流-从概念到实现,一问你就懵逼了?...

后端服务的接口都是有访问上限的&#xff0c;如果外部qps或并发量超过了访问上限会导致应用瘫痪。所以一般都会对接口调用加上限流保护&#xff0c;防止超出预期的请求导致系统故障。从限流类型来说一般来说分为两种:并发数限流和qps限流&#xff0c;并发数限流就是限制同一时刻…

mysql and 和where,关于mysql:连接sql查询中where和and子句的区别

本问题已经有最佳答案&#xff0c;请猛点这里访问。下面两个SQL查询有什么区别和号根据以下两个测试结果速度更快(237比460)。据我所知&#xff0c;这是一个标准。。氧化镁不&#xff0c;有细微的差别&#xff0c;你不能说没有差别除了语法之外没有别的区别。虽然只有一个简短的…

matlab里输出恒压的逆变器,基于IGBT逆变器的异步电机变频调速系统的MATLAB仿真...

异步电机变频调速系统电路仿真模型如图(4)所示。直流电压不621V&#xff0c;逆变器为IGBT 的三相半桥逆变器&#xff0c;电机为异步电机模块&#xff0c;其主电路由直流电压源、逆变器和电机依次相连。图(4)变频调速系统控制部分&#xff0c;利用“Step”模块设定频率指令f1*&a…

php 获取京东交易账号,PHP爬虫爬取京东列表

这里使用到了一个php插件下面是源码simple_html_dom.phpdefined(IN_ECS);define(HDOM_TYPE_ELEMENT, 1);define(HDOM_TYPE_COMMENT, 2);define(HDOM_TYPE_TEXT, 3);define(HDOM_TYPE_ENDTAG, 4);define(HDOM_TYPE_ROOT, 5);define(HDOM_TYPE_UNKNOWN, 6);define(HDOM_QUOTE_DOU…

php dns刷新,Windows DNS缓存自动刷新

Windows DNS缓存自动刷新admin • 2018 年 09 月 04 日DNS(域名服务器)DNS(Domain Name Server)是进行域名和与之相对应的ip地址转换的服务器。DNS中保存了一张域名和与之相应的ip地址的表&#xff0c;以解析消息的域名。DNS轮训在统一主机添加多条A记录&#xff0c;这就是DNS轮…

jq上传file到php,jQuery文件上传

插件描述&#xff1a;这是一个文件上传的展示&#xff0c;看很多插件&#xff0c;并不满意就自己写了一个&#xff0c;可能兼容性不是很好&#xff0c;没有准确进行测试过&#xff0c;还请各位不吝赐教更新时间&#xff1a;2019/3/25 下午8:53:17更新说明&#xff1a;修复上传成…

linux误删表空间文件,UNDO表空间下的数据文件被误删除后的处理方法

UNDO表空间下的数据文件被误删除后的处理方法&#xff1a;操作前备份数据库&#xff0c;以避免更大的损失。思路&#xff1a;1、把误删除的数据文件offline2、正常打开数据库后创建新的UNDO表空间及数据文件3、修改相应参数指向新的UNDO表空间4、重新启动数据库验证5、删除旧的…

linux内核有ebpf吗,聊聊很重要的内核技术eBPF

在2018年的 Linux Plumber 大会上&#xff0c;eBPF成了亮点&#xff0c;有24个议题提到了 eBPF&#xff0c;可以预计eBPF会成为一大技术热点。eBPF(Extended Berkeley Packet Filter) 的核心是驻留在 kernel 的高效虚拟机。最初的目的是高效网络过滤框架&#xff0c;前身是 BPF…