3

クライアントに複数のファイルをダウンロードできる Web アプリを構築しようとしています (zip ファイルではありません)。私はjsf、jquery、およびサーブレットを使用しています。コードは Mozilla では問題なく動作しますが、IE8 では動作しません。

より具体的には、クライアントがブラウザから4つの異なる保存/開くプロンプトを受け取るようにしたい. だから...私はこのような簡単な例を作りました:ユーザーがアクションボタンを押す>> 4つの異なるiframeがサーブレットパスに等しいsrc属性で作成されます>>サーブレットはpdfファイルで応答を生成します>>クライアントは複数を受け取りますプロンプトを保存/開く

これは Mozilla では問題なく動作しますが、IE8 では ESC キーをすばやく押すと、3 つの保存/開くプロンプトが表示されます :) これでは十分ではありません... 4 つの要求すべてと 4 つの応答すべてが行われたかどうかを確認しました。それらはすべてそこにあります...プロンプトのどこに問題があるのか​​ わかりません...

次の iframe (リクエスト) を作成するために promt が閉じられるまで jquery を待機させる方法はありますか? これはIEでも動作するはずです:)

この例では、JasperReports で作成された 4 つの PDF があります。

サーブレット:

public class TestServlet extends HttpServlet {
private static final long   serialVersionUID    = 509291005008276860L;
private Logger logger LoggerFactory.getLogger( TestServlet.class );

@Override
protected void doGet( HttpServletRequest req, HttpServletResponse resp ) throws ServletException, IOException
{
    try {

        Map<String, Object> params = new HashMap<String, Object>();

        params.put( "JUDET", "Alba" );
        params.put( "NUME", "Caliman" );
        params.put( "PRENUME", "Victor" );
        params.put( "DATA_NASTERE", "01/03/1987" );
        params.put( "LOCALITATE", "Alba Iulia" );
        params.put( "STR", "T. Vladimirescu" );
        params.put( "NR", "11" );
        params.put( "BL", "V4" );
        params.put( "SC", "A" );
        params.put( "ET", "1" );
        params.put( "AP", "1" );
        params.put( "JUDET_DOMICILIU", "Alba" );
        params.put( "TIP_ACT", "CI" );
        params.put( "SERIA", "Ax" );
        params.put( "NR_ACT", "42910" );
        params.put( "CNP", "1870301011193" );
        params.put( "COR", "Inginer software" );
        params.put( "BENEFICIAR", 0 );
        params.put( "EVIDENTA", 0 );
        params.put( "DATA", "02/08/2012" );

        PdfData pdfData = new PdfData();
        pdfData.setExportedFileName( "cerereDosar.pdf" );
        pdfData.setTemplateName( "reports/cerereDosar.jasper" );
        pdfData.setParams( params );

        InputStream inputStream = null;

        resp.reset();
        resp.setHeader( "Content-Type", "application/octet-stream" );
        resp.setHeader( "Content-Disposition", "attachment; filename=\"" + pdfData.getExportedFileName() + "\";" );

        inputStream = new ClassPathResource( pdfData.getTemplateName() ).getInputStream();

        //          final Locale locale = FacesContext.getCurrentInstance().getApplication().getDefaultLocale();
        //          pdfData.getParams().put( JRParameter.REPORT_LOCALE, new Loca );

        JasperPrint jasperPrint = JasperFillManager.fillReport( inputStream, pdfData.getParams(),
            new JREmptyDataSource() );

        JasperExportManager.exportReportToPdfStream( jasperPrint, resp.getOutputStream() );

        inputStream.close();

        logger.info( req.getQueryString() );
    }
    catch( Exception e ) {
        e.printStackTrace();
    }
}

}

そしてtest.xhtml:

<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:a4j="http://richfaces.org/a4j"
xmlns:rich="http://richfaces.org/rich"
xmlns:nao="http://nao.anofm.org/jsf/composite/util"
xmlns:naocc="http://java.sun.com/jsf/composite/components">
<ui:composition template="/layout/template.xhtml">
<ui:define name="content">
    <h:form id="forma">
        <a4j:commandButton value="Action" onclick="printTest();" />
        <div style="display: none;" id="result"></div>
    </h:form>

    <script type="text/javascript">     

                function print(tipAct){
                    $('<iframe>')
                    .appendTo('#result')
                    .attr('src', 'http://localhost:8080/nao-inregistrare/TestServlet/')
                    .attr('id', tipAct);
                }

                function printTest(){
                    for(var i = 1; 5>i; i++){
                        $.when(print(i)).done();
                        }
                }

</script>
</ui:define>
</ui:composition>
</html>

どんな提案も大歓迎です!

4

1 に答える 1

0

今週末はとても忙しくて、答えを投稿するのを忘れていました。javascriptウィンドウオブジェクトがすべてのpromtでフォーカスを失っていることが判明したため(私はそれを知っていましたが、私は本当に怠け者になっているようです:(そして人々に私の仕事をするように頼み始めます)...だから私はリクエスト/フォーカスを得ることができます. これは非常に専門的ではない「最初の試行」の例ですが、IE を騙します :)

var i = 4;

window.onfocus = function(){
if(b == true && i != 0){
print(i);
} else {
alert('i`m done');
}
}

var b;

function print(tipAct){
i--;
b = true;
$('<iframe>')
.appendTo('#result')
.attr('src', 'http://localhost:8080/nao-inregistrare/TestServlet/')
.attr('id', tipAct);
}

変数 i = 4; 削除した printTest() 関数のループを表します。要求/フォーカスが得られるたびに、print() 関数で i が減少します。var b は、これが最初のフォーカスであり、アクション ボタンが押されていないかどうかを示すフラグです。また、ボタンのアクションも変更しました。

<a4j:commandButton value="Action" onclick="print(i);" />

しかし、まだ疑問が残ります: ウォルドはどこにいますか? (最初の例の 4 番目のファイル) 最初の例での通常の流れは、次のようになり
ます 。

IE はランダムな数のファイルを要求し、すべてのファイルを要求することはありません。私は本当に混乱しています。自由な時間ができたら、これを Microsoft フォーラムに投稿します...おそらく、これについて論理的な説明があるでしょう。こちらにもリンクを貼っておきます。:)

于 2012-08-19T11:11:21.930 に答える