Extra blank page when converting HTML to PDF using abcPDF

前端 未结 8 1156
花落未央
花落未央 2020-12-30 08:40

I have an HTML report, with each print page contained by a

. The page class is defined as

width: 180mm;
height: 250mm         


        
相关标签:
8条回答
  • 2020-12-30 09:18

    I've found abcPDF to be strange and unpredictable. That being said, what may be happening is that the combination of the page size and page-break-after may be the culprit. Reduce your page height and/or remove the page break.

    0 讨论(0)
  • 2020-12-30 09:19

    The AddImageURL() method of ABCPDF is loosely bind method which doesn't render html tightly within required area which causes new blank page.

    try to use AddImageHTML() method to convert your desired HTML into PDF..

    Doc theDoc = new Doc();
    theDoc.Page = theDoc.AddPage();
    
    int theID = 0;
    theDoc.SetInfo(0, "CheckBgImages", "1");
    theDoc.SetInfo(0, "RenderDelay", "5000");
    theDoc.HtmlOptions.Engine = EngineType.MSHtml;
    theID = theDoc.AddImageHtml(HTML);
    
    while (true)
    {
     if (!theDoc.Chainable(theID))
                    break;
                theDoc.Page = theDoc.AddPage();
                theID = theDoc.AddImageToChain(theID);
            }
    
            for (int i = 0; i <= theDoc.PageCount; i++)
            {
                theDoc.PageNumber = i;
                theDoc.Flatten();
            }
    
            theDoc.Save(HttpContext.Current.Server.MapPath(Path));
            theDoc.Clear();
    

    It will always give accurate results.

    0 讨论(0)
  • 2020-12-30 09:20

    One thing worth revisiting is the validity of your HTML markup if you are using the AddImageUrl method. Instances where the rendered PDF is not as expected can result from bad markup, busted tags, etc.

    For what it's worth, WebSuperGoo has excellent support and respond great when you encounter anomalies. Often they can advise a work around or provide alternatives to your implementation if you send them your source code.

    0 讨论(0)
  • 2020-12-30 09:21

    I have experienced the same exact problem. the empty page is due to the page-break-after: always; in the CSS. Not just ABCpdf but also the printed will spit out an extra page. So I used the following code to eliminate the last page: MyDoc.Delete(MyDoc.Page);

    This however lead to a different kind of a problem. On development server, which has IE 8 I get an extra blank page and on production where I have IE6, I get no extra blank page. So I have emailed the support team at websupergoo to show me a way to look for a blank page. The idea is to iterate through a pdf and identify all blank pages and delete them using above logic.

    And I second Jakkwylde's opinion. Websupergoo folks are extremely helpful and prompt in responding. I had another problem getting ABCpdf to work under 64 bit and had spent almost a day trying to figure it out. They provided me multiple scenarios which I could try out. Their support was right on the money and I got my app up and running in minutes.

    0 讨论(0)
  • 2020-12-30 09:27

    Kush is correct in that "I have experienced the same exact problem. the empty page is due to the page-break-after: always; in the CSS. Not just ABCpdf but also the printed will spit out an extra page."

    If a div has "page-break-after:always" IE will literally always start a new page, and if nothing is added it will just print blank. Firefox does not.

    abcpdf uses IE8s rendering engine, and as such makes a blank page. For purposes of the OP, just using an explicit height should solve the problem, and the engine will insert the page breaks for you.

    I am trying to solve a similar issue, where I can't set the height explicitly because sometimes the content may take 2 pages. (Each page corresponds to a person, and each person should start on a new page when printed). I emailed abcpdf as well to see if they have a hack fix to detect the empty page, but was curious if anyone knows how to fix the underlying problem and css hack IE8 so as to make it not print the final page if empty. I'm guessing it's not possible, but wanted to make sure I'm not missing something obvious.

    0 讨论(0)
  • 2020-12-30 09:28

    We had the same issue in production environment only but not in test environment. We only had page-brek-after used at multiple places in the html.

    Fix for first issue: I spotted the issue by removing the page-brek-after attributes one by one and this finally gave me the DIV section where page break was causing by some of it's element.

    I fixed the height of each elements inside the DIV and this finally fixed my issue without removing the page-break-after attribute.

    Fix for similar issue: If you have a custom hard coded footer, make sure to check by increasing/decresing it's height and margine.

    0 讨论(0)
提交回复
热议问题