繁体   English   中英

java.lang.noClassDefFoundError:Java Applet上的com / itextpdf / text / element

[英]java.lang.noClassDefFoundError: com/itextpdf/text/element on a Java Applet

我正在尝试编写Word-To-PDF转换器的代码,并将Java代码以Java Applet的形式构建到HTML网站中。

我使用了http://java.worldbestlearningcenter.com/2013/07/word-to-pdf-converter.html中的Java代码。 代码本身似乎运行良好,当我在Eclipse中运行该程序时,确实可以将Word文档转换为PDF。 现在,我想将该代码添加到我的HTML文件中并使其工作。

为此,我从JApplet继承了我的课程,并编写了paint()方法。 我现在拥有的代码如下所示:

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.util.Iterator;
import java.util.List;
import javax.swing.JFileChooser;
import javax.swing.filechooser.FileNameExtensionFilter;
import org.apache.poi.xwpf.usermodel.XWPFDocument;
import org.apache.poi.xwpf.usermodel.XWPFParagraph;
import org.apache.poi.xwpf.usermodel.XWPFPicture;
import org.apache.poi.xwpf.usermodel.XWPFPictureData;
import org.apache.poi.xwpf.usermodel.XWPFRun;
import com.itextpdf.text.Chunk;
import com.itextpdf.text.BaseColor;
import com.itextpdf.text.Document;
import com.itextpdf.text.Font;
import com.itextpdf.text.FontFactory;
import com.itextpdf.text.Image;
import com.itextpdf.text.pdf.PdfWriter;
import com.itextpdf.text.PageSize;
import java.applet.*;
import java.awt.*;

public class ConverterApplet extends Applet {
    private static final long serialVersionUID = 1L;

    public void paint(Graphics g) {
        g.drawString("Hello", 60, 40);
        selectFiles();
    }

    public static void selectFiles(){
        JFileChooser chooser = new JFileChooser();
        FileNameExtensionFilter filter = new FileNameExtensionFilter("Microsoft Word 2007+", "docx");
        chooser.setFileFilter(filter);
        chooser.setMultiSelectionEnabled(true);
        int returnVal = chooser.showOpenDialog(null);
        if(returnVal == JFileChooser.APPROVE_OPTION) {
            File[] Files=chooser.getSelectedFiles();
            System.out.println("Konvertierung gestartet ...");
            for( int i=0;i<Files.length;i++){     
                String wordfile=Files[i].toString();            
                convertWordToPdf(wordfile,wordfile.substring(0,wordfile.indexOf('.'))+".pdf");
            }

            System.out.println("Konvertierung abgeschlossen!");
        }
    }

    public static void convertWordToPdf(String src, String desc){
        try {
            //create file inputstream object to read data from file 
            FileInputStream fs=new FileInputStream(src);
            //create document object to wrap the file inputstream object
            XWPFDocument doc=new XWPFDocument(fs); 
            //72 units=1 inch
            Document pdfdoc=new Document(PageSize.A4,72,72,72,72);
            //create a pdf writer object to write text to mypdf.pdf file
            PdfWriter pwriter=PdfWriter.getInstance(pdfdoc, new FileOutputStream(desc));
            //specify the vertical space between the lines of text
            pwriter.setInitialLeading(20);
            //get all paragraphs from word docx
            List<XWPFParagraph> plist=doc.getParagraphs();

            //open pdf document for writing
            pdfdoc.open();
            for (int i = 0; i < plist.size(); i++) {
                //read through the list of paragraphs
                XWPFParagraph pa = plist.get(i);
                //get all run objects from each paragraph
                List<XWPFRun> runs = pa.getRuns();
                //read through the run objects
                for (int j = 0; j < runs.size(); j++) {       
                    XWPFRun run=runs.get(j);
                    //get pictures from the run and add them to the pdf document
                    List<XWPFPicture> piclist=run.getEmbeddedPictures();
                    //traverse through the list and write each image to a file
                    Iterator<XWPFPicture> iterator=piclist.iterator();
                    while(iterator.hasNext()){
                        XWPFPicture pic=iterator.next();
                        XWPFPictureData picdata=pic.getPictureData();
                        byte[] bytepic=picdata.getData(); 
                        Image imag=Image.getInstance(bytepic);
                        pdfdoc.add(imag);

                    }
                    //get color code
                    int color=getCode(run.getColor());
                    //construct font object
                    Font f=null;
                    if(run.isBold() && run.isItalic())
                        f=FontFactory.getFont(FontFactory.TIMES_ROMAN,run.getFontSize(),Font.BOLDITALIC, new BaseColor(color));
                    else if(run.isBold())
                        f=FontFactory.getFont(FontFactory.TIMES_ROMAN,run.getFontSize(),Font.BOLD, new BaseColor(color));
                    else if(run.isItalic())
                        f=FontFactory.getFont(FontFactory.TIMES_ROMAN,run.getFontSize(),Font.ITALIC, new BaseColor(color));
                    else if(run.isStrike())
                        f=FontFactory.getFont(FontFactory.TIMES_ROMAN,run.getFontSize(),Font.STRIKETHRU, new BaseColor(color));
                    else
                        f=FontFactory.getFont(FontFactory.TIMES_ROMAN,run.getFontSize(),Font.NORMAL, new BaseColor(color));
                    //construct unicode string
                    String text=run.getText(-1);
                    byte[] bs;
                    if (text!=null){
                        bs=text.getBytes();
                        String str=new String(bs,"UTF-8");
                        //add string to the pdf document
                        Chunk chObj1=new Chunk(str,f);
                        pdfdoc.add(chObj1);
                    }      

                }
                //output new line
                pdfdoc.add(new Chunk(Chunk.NEWLINE));
            }
            //close pdf document  
            pdfdoc.close();
        } catch(Exception e){
            e.printStackTrace();
        }
    } 

    public static int getCode(String code){
        int colorCode;
        if(code!=null)
            colorCode=Long.decode("0x"+code).intValue();
        else
            colorCode=Long.decode("0x000000").intValue();
        return colorCode;
    }
}

我使用以下代码创建了一个HTML文档:

<DOCTYPE! html>
<html lang="DE-CH">
    <head>
        <title>Testseite</title>
    </head>

    <body>
        <h1>Titel</h1>

        <object type="application/x-java-applet" width="800" height="600">
            <param name="code" value="ConverterApplet" />
            <param name="archive" value="ConverterApplet.jar" />
            Applet failed to run.  No Java plug-in was found.
        </object>

    </body>
</html> 

尝试在Internet Explorer中打开该HTML页面时(Chrome和Firefox似乎无法使用,甚至IE也需要特殊权限),我收到错误“ java.lang.noClassDefFoundError:com / itextpdf / text / element”。

我还可以说的是:

  • 我只有一个JAR文件用于itextpdf。 其版本为5.1.0,因为2.1.7不包括特定代码需要的所有软件包。 没有其他与itextpdf类似的JAR文件。
  • 我在项目文件夹的WEB-INF / lib文件夹中拥有所有JAR文件
  • lib文件夹中的所有JAR文件也位于CLASSPATH中。
  • 我有导出为“ ConverterApplet.jar”的代码的更新版本,该文件也位于项目的根文件夹和CLASSPATH中。
  • 我尝试使用浏览器Chrome,Firefox,Opera,Edge和Internet Explorer。 只有最后一个甚至使我有可能看到(无效的)小程序,所有其他人都说“未找到插件”。

除了上面列出的要点外,我在网上找不到任何其他帮助。 我真的不知道要得到这样的错误还有什么问题,特别是因为Java代码本身可以在Eclipse内运行,但不能在外部运行。 任何帮助将是真正的感谢。

==编辑== .classpath文件:

    <?xml version="1.0" encoding="UTF-8"?>
<classpath>
    <classpathentry kind="src" path="src"/>
    <classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.8"/>
    <classpathentry kind="lib" path="C:/Users/silve/Documents/Eclipse_Launch/Converter/ConverterApplet.jar"/>
    <classpathentry kind="lib" path="C:/Users/silve/Documents/Eclipse_Launch/Converter/dom4j-1.6.1.jar"/>
    <classpathentry kind="lib" path="C:/Users/silve/Documents/Eclipse_Launch/Converter/openxml4j-1.0-beta.jar"/>
    <classpathentry kind="lib" path="C:/Users/silve/Documents/Eclipse_Launch/Converter/poi-3.9.jar"/>
    <classpathentry kind="lib" path="C:/Users/silve/Documents/Eclipse_Launch/Converter/poi-ooxml-3.8.jar"/>
    <classpathentry kind="lib" path="C:/Users/silve/Documents/Eclipse_Launch/Converter/poi-ooxml-schemas-3.9.jar"/>
    <classpathentry kind="lib" path="C:/Users/silve/Documents/Eclipse_Launch/Converter/xmlbeans-2.5.0.jar"/>
    <classpathentry kind="lib" path="C:/Users/silve/Documents/Eclipse_Launch/Converter/itextpdf-5.5.12.jar"/>
    <classpathentry kind="output" path="bin"/>
</classpath>

新的HTML文件:

<DOCTYPE! html>
<html lang="DE-CH">
    <head>
        <title>Testseite</title>
    </head>

    <body>
        <h1>Titel</h1>

        <object type="application/x-java-applet" width="800" height="600">
            <param name="code" value="ConverterApplet" />
            <param name="archive" value="~/ConverterApplet.jar" />
            <param name="dom_archive" value="~/dom4j-1.6.1.jar" />
            <param name="itext_archive" value="~/itextpdf-5.5.12.jar" />
            <param name="openxml_archive" value="~/openxml4j-1.0-beta.jar" />
            <param name="poi_archive" value="~/poi-3.9.jar" />
            <param name="ooxml_archive" value="~/poi-ooxml-3.8.jar" />
            <param name="schemas_archive" value="~/poi-ooxml-schemas-3.9.jar" />
            <param name="mxmlbeans_archive" value="~/xmlbeans-2.5.0" />

            Applet failed to run.  No Java plug-in was found.
        </object>

    </body>
</html> 

现在,我收到IE的错误“ NoClassFound”。

我在项目文件夹的WEB-INF / lib文件夹中拥有所有JAR文件

浏览器无法直接访问该位置的jar(通过在浏览器地址栏中放入Jar的完整路径并按Enter来尝试获取),或者通过扩展JVM。

lib文件夹中的所有JAR文件也位于CLASSPATH中。

CLASSPATH到底是什么?

但这不是唯一的问题。

<param name="archive" value="ConverterApplet.jar" />

需要在archive元素中明确引用iText jar(以及与applet相关的每个jar)。

我真的不知道要得到这样的错误还有什么问题,特别是因为Java代码本身可以在Eclipse内运行,但不能在外部运行。

编写一个applet并将其部署到Internet上以用于一般用途,是大约相当困难的问题。 换句话说,当“它在IDE中运行正常,只需要部署它”时,工作就完成了一半。

编辑

.classpath是项目主根目录中的文件

该文件仅对您的IDE有用。 浏览器(或使用浏览器启动小程序时的JVM)无法访问或解决该问题。

<object type="application/x-java-applet" width="800" height="600">
        <param name="code" value="ConverterApplet" />
        <param name="archive" value="~/ConverterApplet.jar" />
        <param name="dom_archive" value="~/dom4j-1.6.1.jar" />
        ....

我对object元素有点生疏,但是AFAIR,将archive param用作applet元素的archive属性。

因此,下一行是开始出错的地方。 您的小应用程序本身可能会读取dom_archive属性,但JM不会考虑该存档位于运行时类路径中。 对于这两行,应该改为:

<object type="application/x-java-applet" width="800" height="600">
        <param name="code" value="ConverterApplet" />
        <param name="archive" value="~/ConverterApplet.jar ~/dom4j-1.6.1.jar .." />
        ....

在(单个) archive元素中用空格分隔的列表中命名每个 Jar。 然后将它们放在applet的运行时类路径上。

Java applet技术已被标记为不推荐使用。 默认情况下,许多浏览器都禁用Java applet。 看到

大约一年前,我们发表了一篇文章,宣布计划弃用JDK 9中的Java浏览器插件,这是因为浏览器供应商不再使用启动Java Applet所需的基于标准的NPAPI插件支持技术。

从那时起,Oracle开发团队就发布了JDK增强建议(JEP 289:弃用Applet API),其中包含有关JDK 9中计划弃用步骤的技术细节。

此外,Apple Safari和Mozilla Firefox的开发人员宣布了更新的时间表,以从其浏览器中删除基于标准的插件支持,从而消除了嵌入Java和其他基于插件的技术的可能性。 按照他们的时间表,从将于2017年3月发布的Mozilla Firefox 52开始,Mozilla Firefox的32位版本将不再为基于标准的插件支持提供必需的API。 用于Microsoft Windows的Mozilla Firefox的64位版本在不支持大多数基于NPAPI的插件(包括Java)的情况下启动。

我的建议是,您迁移到Oracle或OpenJDK博客中描述的不同技术之一。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM