Как установить заголовок ответа в JAX-RS, чтобы пользователь видел всплывающее окно загрузки для Excel? - PullRequest
46 голосов
/ 07 января 2011

Я написал код, который генерирует файл Excel, используя REST JAX-RS, и подтвердил, что созданный файл Excel находится в каталоге сервера GlassFish.

Но моя цель - когда пользователь нажимает кнопку (которая генерирует Excel.xls), я хочу, чтобы всплывающее окно загрузки отображало вопрос о том, нужно ли пользователю сохранять или открывать файл .xls, как и любые другие веб-службы, выполняющие загрузку файлов любого типа.

В соответствии с моим поиском, выполняется следующий шаг:

  1. генерировать Excel .xls (ВЫПОЛНЕНО)

  2. записать Excel в поток

  3. в JAX-RS файл, установите для заголовка ответа что-то вроде

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

У меня вопрос, я делаю все это в файле JAX-RS, и я необъект HttpServletResponse недоступен.

Согласно ответу от Добавить заголовок ответа в веб-службу JAX-RS

Он говорит:

Вы можете вставить ссылку на фактический HttpServletResponse через аннотацию @Context в вашем веб-сервисе и использовать addHeader () и т. Д., Чтобы добавить свой заголовок.

Я не могу понять, что именно это означает без образцакод ..

Ответы [ 3 ]

82 голосов
/ 07 января 2011

Вам не нужен 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
  }
}
15 голосов
/ 19 июня 2013
@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));
        }
    };
}
0 голосов
/ 07 января 2011

Я решил установить заголовок ответа HTTP и поток для отображения всплывающего окна загрузки в браузере через стандартный сервлет.примечание: я использую Excella, API вывода Excel.

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
...