java用jax读取excel_java-如何在JAX-RS中设置响应标头,以便用户看到Excel的下载弹出窗口?...

java-如何在JAX-RS中设置响应标头,以便用户看到Excel的下载弹出窗口?

我编写了使用REST JAX-RS生成Excel文件的代码,并确认生成的Excel文件位于GlassFish服务器目录中。

但是我的目标是,当用户单击按钮(生成Excel .xls)时,我要显示下载弹出窗口,询问用户是否要保存或打开.xls文件,就像其他任何下载任何类型文件的Web服务一样。

根据我的搜索,步骤是:

生成Excel .xls(完成)

写excel流

在JAX-RS文件中,将响应标头设置为类似的内容,

字符串fileName =“ Blah_Report.xls”;response.setHeader(“ Content-Disposition”,“ attachment; filename =” + fileName);

我的问题是我正在JAX-RS文件中完成所有这些操作,而我没有HttpServletResponse对象可用。

根据答案将响应标头添加到JAX-RS Web服务

他说:

您可以插入对   实际的HttpServletResponse通过   Web服务中的@Context批注   并使用addHeader()等添加您的   标头。

没有示例代码,我真的无法弄清楚这到底意味着什么。

3个解决方案

86 votes

您不需要HttpServletResponse来在响应上设置标头。 您可以使用javax.ws.rs.core.Response。 只需使您的方法返回Response而不是实体即可:

return Response.ok(entity).header("Content-Disposition", "attachment; filename=\"" + fileName + "\"").build()

如果仍要使用HttpServletResponse,则可以将其注入到类字段之一中,或者使用属性或方法参数:

@Path("/resource")

class MyResource {

// one way to get HttpServletResponse

@Context

private HttpServletResponse anotherServletResponse;

// another way

Response myMethod(@Context HttpServletResponse servletResponse) {

// ... code

}

}

Tarlog answered 2020-02-20T05:40:15Z

16 votes

@Context ServletContext ctx;

@Context private HttpServletResponse response;

@GET

@Produces(MediaType.APPLICATION_OCTET_STREAM)

@Path("/download/{filename}")

public StreamingOutput download(@PathParam("filename") String fileName) throws Exception {

final File file = new File(ctx.getInitParameter("file_save_directory") + "/", fileName);

response.setHeader("Content-Length", String.valueOf(file.length()));

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

return new StreamingOutput() {

@Override

public void write(OutputStream output) throws IOException,

WebApplicationException {

Utils.writeBuffer(new BufferedInputStream(new FileInputStream(file)), new BufferedOutputStream(output));

}

};

}

Jay answered 2020-02-20T05:40:31Z

1 votes

我想设置HTTP响应标头和流以通过标准servlet在浏览器中显示下载弹出窗口。 注意:我使用的是Excella,excel输出API。

package local.test.servlet;

import java.io.IOException;

import java.net.URL;

import java.net.URLDecoder;

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 local.test.jaxrs.ExcellaTestResource;

import org.apache.poi.ss.usermodel.Workbook;

import org.bbreak.excella.core.BookData;

import org.bbreak.excella.core.exception.ExportException;

import org.bbreak.excella.reports.exporter.ExcelExporter;

import org.bbreak.excella.reports.exporter.ReportBookExporter;

import org.bbreak.excella.reports.model.ConvertConfiguration;

import org.bbreak.excella.reports.model.ReportBook;

import org.bbreak.excella.reports.model.ReportSheet;

import org.bbreak.excella.reports.processor.ReportProcessor;

@WebServlet(name="ExcelServlet", urlPatterns={"/ExcelServlet"})

public class ExcelServlet extends HttpServlet {

@Override

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

try {

URL templateFileUrl = ExcellaTestResource.class.getResource("myTemplate.xls");

// /C:/Users/m-hugohugo/Documents/NetBeansProjects/KogaAlpha/build/web/WEB-INF/classes/local/test/jaxrs/myTemplate.xls

System.out.println(templateFileUrl.getPath());

String templateFilePath = URLDecoder.decode(templateFileUrl.getPath(), "UTF-8");

String outputFileDir = "MasatoExcelHorizontalOutput";

ReportProcessor reportProcessor = new ReportProcessor();

ReportBook outputBook = new ReportBook(templateFilePath, outputFileDir, ExcelExporter.FORMAT_TYPE);

ReportSheet outputSheet = new ReportSheet("MySheet");

outputBook.addReportSheet(outputSheet);

reportProcessor.addReportBookExporter(new OutputStreamExporter(response));

System.out.println("wtf???");

reportProcessor.process(outputBook);

System.out.println("done!!");

}

catch(Exception e) {

System.out.println(e);

}

} //end doGet()

@Override

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

}

}//end class

class OutputStreamExporter extends ReportBookExporter {

private HttpServletResponse response;

public OutputStreamExporter(HttpServletResponse response) {

this.response = response;

}

@Override

public String getExtention() {

return null;

}

@Override

public String getFormatType() {

return ExcelExporter.FORMAT_TYPE;

}

@Override

public void output(Workbook book, BookData bookdata, ConvertConfiguration configuration) throws ExportException {

System.out.println(book.getFirstVisibleTab());

System.out.println(book.getSheetName(0));

//TODO write to stream

try {

response.setContentType("application/vnd.ms-excel");

response.setHeader("Content-Disposition", "attachment; filename=masatoExample.xls");

book.write(response.getOutputStream());

response.getOutputStream().close();

System.out.println("booya!!");

}

catch(Exception e) {

System.out.println(e);

}

}

}//end class

masato-san answered 2020-02-20T05:40:51Z

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值