获取PDF Java Web中的当前页面

时间:2014-06-26 08:54:19

标签: java javascript pdf

我需要从我的网络应用程序中读取当前页码。我有:

 <iframe id="myPdf" src="C:\test.pdf#page=5" style="width: 650px; height: 550px;" />

在页面= 5上打开PDF,用户可以导航到另一个页面。然后,当用户单击按钮/链接时,我需要以PDF格式获取页面的当前索引。

我的用户使用的是Acrobat Reader,我无法使用Adobe提供的插件。我可以使用Javascript / Java代码。

由于 塔米

1 个答案:

答案 0 :(得分:1)

我发现我可以使用iText(免费软件)将JavaScript注入pdf文件, PDF中的JS将消息发送到html中的容器。 该消息包含当前页面,每次更改页面时都会将其传递给容器。

我使用pdfobject.js pdfobject.min.js来创建捕获消息的PDFJS对象。

用Java注入JS到PDF的代码:

public String mAddJS()
{
    InputStream vbReaderFile = null;

    try
    {
        vbReaderFile = new FileInputStream("C:\\test.pdf");
        PdfReader myReader = new PdfReader( vbReaderFile ); // throws IOException
        PdfStamper myStamper = new PdfStamper( myReader, new FileOutputStream("C:\\outTest.pdf") ); // throws IOE, DocumentException
        // add a page-open script, 1 is the first page, not zero0
        PdfAction jsAction = PdfAction.javaScript ("app.alert('Think again next time!');", myStamper.getWriter());
        int pageNum = myReader.getNumberOfPages();
        for(int i=1 ; i<pageNum ; i++ )
        {
             jsAction = PdfAction.javaScript (
                     "this.disclosed=true;" +
                     "if(this.hostContainer){" +
                     "var names = new Array();names[0]=" + i + ";" +
                     "try{this.hostContainer.postMessage(names);}" +
                     "catch(e){app.alert(e.message); }"+
                     "}", myStamper.getWriter());

             myStamper.setPageAction( PdfWriter.PAGE_OPEN, jsAction, i); 

        }

        myStamper.close(); // write everything out, throws DocumentException, IOE
        vPath = "C:\\outTest.pdf";

    //  JavascriptContext.addJavascriptCall(FacesContext.getCurrentInstance(), "mChangePDF('C:\\outTest.pdf');");

    }
    catch (Exception e) {
        e.printStackTrace();
    }
    return null;

}

html页面:

 <h:body >
         <ice:form id="myForm">
          <object id="myPDFObj" type="application/pdf" data="test.pdf#page=3" 
            height="550px" width="650px"></object>

            <br/><ice:commandButton onclick="test();" value="test" ></ice:commandButton>

            <ice:commandButton action="#{pDFTest.mAddJS}" value="JAVA" partialSubmit="false"></ice:commandButton>

             <div id="myDivPdf">
              </div>
        </ice:form> 
</h:body>

html上的JS:

  <script type="text/javascript">

     var PDF1;
     var PDF2;

     window.onload = function(evt)
     {
         createPDF();

         createMessageHandler();
     }

function createPDF(){

 PDF1 = new PDFObject({
      url: "test.pdf#page=3",
      id: "myPDFObj",
      width: "500px",
      height: "300px"
    });
 PDF2 = PDF1.embed("myForm:myDivPdf");

};

function createMessageHandler() { 
    var PDFObject = document.getElementById("myPDFObj"); 
    if(PDFObject==null)
        alert('e1');
    PDFObject.messageHandler = { 
        onMessage: function(msg) { 
        //  alert('app');
            alert( msg[0]);
            }, 
        onError: function(error, msg) { 
            alert('error.message'); 
        } 
    } 
} 



</script>