Java XLSTransformer生成excel文件

Java XLSTransformer生成excel文件把页面的数据导出excel数据 然后进入struts2action packagecomxx.emidas.activity.activity.ajax;importcom.xx.combiz.spring.util.LionConfigUtils;importcom.xx.e

大家好,又见面了,我是你们的朋友全栈君。

  把页面的数据导出excel 数据  

Java XLSTransformer生成excel文件

然后进入 struts2 action 

          <action name="generateExcel" class="com.xx.emidas.activity.activity.ajax.XLSTransformerGenerateExcelAction">
         </action>

package com.xx.emidas.activity.activity.ajax;

import com.xx.combiz.spring.util.LionConfigUtils;
import com.xx.emidas.activity.external.util.XLSTransformerGenerateExcelUtil;
import com.xx.emidas.activity.picture.BaseAction;







import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import org.apache.struts2.ServletActionContext;








import java.io.File;
import java.io.IOException;
import java.io.Writer;
import java.util.*;

import javax.servlet.http.HttpServletResponse;


public class XLSTransformerGenerateExcelAction extends BaseAction {
	
	private String url;
	private String name;
    /**活动ID*/
    private int activityId;

    /**查询起始日期*/
    private String queryStart;

    /**查询结束日期*/
    private String queryend;
	/**
	 * 
	 */
	private static final long serialVersionUID = 2058361031969467470L;

	@Override
	public String execute() throws Exception {
        try {
        	//url="http://localhost:8080/activities/activity/newClickdate"+"?activityId="+activityId+"&queryStart="+queryStart+"&queryend="+queryend;
        	  url = LionConfigUtils.getProperty("emidas-event.activity.data.excelExport", "0");
        	  url+="?activityId="+activityId+"&queryStart="+queryStart+"&queryend="+queryend;
        	XLSTransformerGenerateExcelUtil.ExportExcel(url, name);
		} catch (Exception e) {
			
		}
       return null;
	}

	public String getUrl() {
		return url;
	}

	public void setUrl(String url) {
		this.url = url;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public int getActivityId() {
		return activityId;
	}

	public void setActivityId(int activityId) {
		this.activityId = activityId;
	}

	public String getQueryStart() {
		return queryStart;
	}

	public void setQueryStart(String queryStart) {
		this.queryStart = queryStart;
	}

	public String getQueryend() {
		return queryend;
	}

	public void setQueryend(String queryend) {
		this.queryend = queryend;
	}
	
	
	
	

}

这里的 url  是你的 需要数据的页面 或者 action  图片也可以显示的 

这里是我自己封装的XLSTransformer的工具类 

package com.xx.emidas.activity.external.util;


import java.io.IOException;
import java.io.Writer;

import javax.servlet.http.HttpServletResponse;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import org.apache.struts2.ServletActionContext;
public class XLSTransformerGenerateExcelUtil {
	/**
	 * 导出页面数据生成 xlsx
	 * @author hongwang.zhang
	 * @date 20150826
	 * @param path  url路径
	 * @param name  excel名称
	 */
	public static void  ExportExcel( String path,String name){
		CloseableHttpClient httpClient = HttpClients.createDefault();
        HttpGet httppost = new HttpGet(path);
        try {
            // 发送请求,返回响应
            HttpResponse response = httpClient.execute(httppost);

            // 打印响应信息
            HttpEntity entity = response.getEntity();
            HttpServletResponse x = ServletActionContext.getResponse();
            x.setContentType("application/vnd.ms-excel");  
            String titlename="data"; 
            if(null!=name){
            	titlename=name;
            }
            x.setHeader("Content-Disposition", "attachment;filename="+new String((titlename).getBytes("gbk"),"iso8859-1")+".xlsx");  
              Writer w = null;
              w = x.getWriter();
              w.write(EntityUtils.toString(entity));
              w.flush();
              
              EntityUtils.consume(entity);
            //
        } catch (ClientProtocolException e) {
            // 协议错误
            e.printStackTrace();
        } catch (IOException e) {
            // 网络异常
            e.printStackTrace();
        }
	}
	
	

}

导出来的基本会和页面上的数据 样式一样的,这里我自己做了一个独立的页面 对样式做了一些修改 导出的excel 和页面上的一模一样 

Java XLSTransformer生成excel文件

是不是很吊呢偷笑偷笑偷笑偷笑  这里就是大概的代码了,如果有什么 不懂的可以在留言

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/163869.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • tcp洪水攻击_udp编程socket

    tcp洪水攻击_udp编程socket#include/**UDP洪水攻击:不停的向目的主机发送UDP包,让目的主机接收端口拥塞,以达到攻击的目的**/#defineMAXCHILD2#defineK1024#defineDATUML1*KstaticintPROTO_UDP=-1;//UDP协议类型staticunsignedlongdest=0;//目的地址,32位二进制staticintdest_po…

    2022年10月1日
    2
  • spring boot 接口_什么是API接口

    spring boot 接口_什么是API接口引言前后端分离、APP交互等,大多都是通过API接口实现的。既然要进行数据交互,那么这接口就得有讲究了:既要实用,又要优雅好看!那么,如何写一套(个)漂亮的API接口呢?一、返回格式API接口要求返回的格式是text/json,我们知道网页返回的格式一般是text/html,因此,SpringBoot为写接口,提供了两种实现方式:类注解和方法注解。类注解@Re…

    2022年9月18日
    1
  • random.nextInt()与Math.random()基础用法

    random.nextInt()与Math.random()基础用法1、来源java.util.Random类中的方法;Math类中的静态方法2、用法产生0-n的伪随机数(伪随机数参看最后注解)://两种生成对象方式:带种子和不带种子(两种方式的区别见注解)Randomrandom=newRandom();Integerres=random.nextInt(n);Integerres=(int)(Math.random()*n);3、

    2022年7月21日
    14
  • CDN技术详解及实现原理「建议收藏」

    CDN技术详解及实现原理「建议收藏」CDN技术详解一本好的入门书是带你进入陌生领域的明灯,《CDN技术详解》绝对是带你进入CDN行业的那盏最亮的明灯。因此,虽然只是纯粹的重点抄录,我也要把《CDN技术详解》的精华放上网。公诸同好。第

    2022年7月2日
    48
  • Java字符串常量池_字符串常量池溢出

    Java字符串常量池_字符串常量池溢出包装类对象池是不是JVM常量池的一种?Java创建newString会产生多少个对象

    2022年7月28日
    5
  • 变量

    变量

    2022年3月3日
    40

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号