![](/img/trans.png)
[英]java.lang.NoClassDefFoundError : 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”。
我还可以说的是:
除了上面列出的要点外,我在网上找不到任何其他帮助。 我真的不知道要得到这样的错误还有什么问题,特别是因为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.