我正在研究一个利用Apache FOP的Servlet。
输入的.fo文件将转换为PDF文件。一些输入文件引用
外部图像;如果这些都不可用,则变压器会给出
像这样的消息:
07.07.2013 22:53:01 org.apache.fop.fo.flow.ExternalGraphic bind
SCHWERWIEGEND: Image not available: sunset.jpg
为了处理这种情况,我实现了一个ErrorListener:
import javax.xml.transform.ErrorListener;
class MyErrorListener implements ErrorListener {
int warnings;
int fatals;
int errors;
StringBuilder sb = new StringBuilder();
@Override
public void warning(TransformerException e) throws TransformerException {
warnings++;
sb.append(e.getMessageAndLocation() + "\n");;
}
@Override
public void fatalError(TransformerException e)
throws TransformerException {
fatals++;
sb.append(e.getMessageAndLocation() + "\n");;
}
@Override
public void error(TransformerException e) throws TransformerException {
errors++;
sb.append(e.getMessageAndLocation() + "\n");;
}
String getMessages() {
return sb.toString();
}
}
在转换开始之前,此类的一个实例已附加到转换器:
TransformerFactory tFactory = TransformerFactory.newInstance();
transformer = tFactory.newTransformer();
MyErrorListener el = new MyErrorListener();
transformer.setErrorListener(el);
transformer.transform(new StreamSource(tempFile2),
new SAXResult(fop.getDefaultHandler()));
但是不要调用任何已实现的错误,警告或fatalError方法
在侦听器中,转换器不断将错误报告给stderr。
我什至尝试将监听器附加到工厂:
tFactory.setErrorListener(el);
但没有成功。
知道我的代码有什么问题吗?还是缺少的图像低于报告水平?
最佳答案
该错误来自XSL-FO处理器,而不是XSLT处理器。撒克逊人知道您的ErrorListener,但不知道该错误。 FOP知道错误,但不知道ErrorListener。