0

サーブレットから pdf ファイルをダウンロードするために、コンテンツ処理を使用しています。私のコードは chrome、firefox、IE では正常に動作しますが、問題は、opera を使用して pdf ファイルをダウンロードしようとすると、pdf 拡張子が削除され、htm が追加されることです。以下は私のコードです:

        String filename = "abc.pdf";
        String filepath = "/pdf/" + filename;
        System.out.println("filepath "+filepath);
        resp.addHeader("content-disposition", "attachment; filename=" + filename);

        ServletContext ctx = getServletContext();
        InputStream is = ctx.getResourceAsStream(filepath);

        System.out.println(is.toString());
        int read = 0;

        byte[] bytes = new byte[1024];

        OutputStream os = resp.getOutputStream();           
        while ((read = is.read(bytes)) != -1) {
            os.write(bytes, 0, read);
        }
        System.out.println(read);

        os.flush();
        os.close();
        }catch(Exception ex){
            logger.error("Exception occurred while downloading pdf -- "+ex.getMessage());
            System.out.println(ex.getStackTrace());
        }
4

1 に答える 1

2

application/pdfダウンロードしたファイルが HTML ファイルではなく PDF ファイルであることをブラウザーに知らせるために、おそらく応答のコンテンツ タイプを に設定する必要があります。

を参照してくださいServletResponse.setContentType()

于 2011-09-13T08:50:06.070 に答える