2011-05-19 15 views
3

我正嘗試使用JAXB生成log4j XML解析工件。我使用的是DTD通過JAXB生成的工件無法解析log.xml

http://logging.apache.org/log4j/1.2/apidocs/org/ap.../log4j/xml/doc-files/log4j.dtd

和內嵌log.xml。我正在接受例外。我是所有這些技術的新手。請有人幫助解決這個問題。

異常在線程 「主」 javax.xml.bind.UnmarshalException: 意外元件 (URI: 「http://jakarta.apache.org/log4j/」, 本地: 「配置」) 。預期 元件是 < {}附加器>,< {}附加器-REF>,< {}類別>,< {} categoryFactory>,< {} connectionSource>,< {}的dataSource>,< {}的ErrorHandler>,< {}濾波器>,< {}佈局>,< {}水平>,< {}記錄器>,< {}記錄器-REF>,< {}的LoggerFactory>,< {} param>的< {}插件>,< {} priority>,< {} renderer>,< {} rollingPolicy>,< {} root>,< {} root-ref>,< {} triggeringPolicy> at co (加載程序.java:211) at com.sun.xml.internal.bind.v2.runtime.unmarshaller.Loader.reportError(Loader.java:206) at com.sun.xml.internal.bind.v2.runtime .unmarshaller.Loader.reportUnexpectedChildElement(Loader.java:83) 在 com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext $ DefaultRootLoader.childElement(UnmarshallingContext.java:965) 在 的com.sun .xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext._startElement(UnmarshallingContext.java:401) at com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallingContext.startElement(UnmarshallingContext.java:382) at com.sun.xml.internal.bind.v2.runtime.unmarshaller.SAXConnector。的startElement(SAXConnector.java:113) 在 org.apache.xerces.parsers.AbstractSAXParser.startElement(未知 來源)在 org.apache.xerces.impl.dtd.XMLDTDValidator.startElement(未知 來源)在 組織.apache.xerces.impl.XMLNSDocumentScannerImpl.scanStartElement(未知 來源)在 org.apache.xerces.impl.XMLNSDocumentScannerImpl $ NSContentDispatcher.scanRootElementHook(未知 來源)在 org.apache.xerces .impl.XMLDocumentFragmentScannerImpl $ FragmentContentDispatcher.dispatch(未知 來源)在 org.apache.xerces.impl.XMLDocumentFragmentScannerImpl.scanDocument(未知 來源)在 org.apache.xerces.parsers.XML11Configuration.parse(未知 來源)在 org.apache.xerces.parsers.XML11Configuration.parse(未知 源)處 org.apache.xerces.parsers.AbstractSAXParser org.apache.xerces.parsers.XMLParser.parse(未知 源)。在 org.apache.xerces.jaxp.SAXParserImpl $ JAXPSAXParser.parse(未知 來源)在 com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallerImpl.unmarshal0(UnmarshallerImpl解析(未知 來源)。的java:202) 在 com.sun.xml.internal.bind.v2.runtime.unmarshaller.UnmarshallerImpl.unmarshal(UnmarshallerImpl.java:175) 在 javax.xml.bind.helpers.AbstractUnmarshallerImpl.unmarshal(AbstractUnmarshallerImpl。的java:148) 在 javax.xml.bind.helpers.AbstractUnmarshallerImpl.unmarshal(AbstractUnmarshallerImpl.java:153) 在 javax.xml.bind.helpers.AbstractUnmarshallerImpl.unmarshal(AbstractUnmarshallerImpl.java:162) 在 javax.xml.bind.helpers.AbstractUnmarshallerImpl.unmarshal(AbstractUnmarshallerImpl.java:180)

log4jXML

<?xml version="1.0" encoding="UTF-8"?> 
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd"> 
<log4j:configuration debug="false" xmlns:log4j="http://jakarta.apache.org/log4j/"> 

    <appender name="ASYNC" class="org.apache.log4j.AsyncAppender"> 
     <appender-ref ref="DEFAULT"/> 
    </appender> 


    <appender name="STDOUT" class="org.apache.log4j.ConsoleAppender"> 
     <layout class="org.apache.log4j.PatternLayout"> 
      <param name="ConversionPattern" value="%d [%t] %-5p %c %x- %m%n"/> 
     </layout> 
    </appender> 

    <appender name="DEFAULT" class="org.apache.log4j.RollingFileAppender"> 
     <param name="File" value="/home/default.log" /> 
     <param name="Append" value="true" /> 
     <param name="maxFileSize" value="10MB" /> 
     <param name="maxBackupIndex" value="2" /> 
     <param name="encoding" value="UTF-8" /> 
     <layout class="org.apache.log4j.PatternLayout"> 
      <param name="ConversionPattern" value="%d [%t] %-5p %c %x- %m%n"/> 
     </layout> 
    </appender> 


    <appender name="DB_EXCEP" class="org.apache.log4j.FileAppender"> 
     <param name="File" value="/home/db_exception.log" /> 
     <param name="Append" value="true" /> 
     <param name="encoding" value="UTF-8" /> 
     <layout class="org.apache.log4j.PatternLayout"> 
      <param name="ConversionPattern" value="%d [%t] %-5p %c %x- %m%n"/> 
     </layout> 
    </appender> 

    <category name="com.common.db.ScriptRunner" additivity="false"> 
     <priority value="info" /> 
     <appender-ref ref="DB_EXCEP" /> 
    </category> 


    <category name="com.common.appsvr.current.admin" additivity="false"> 
     <priority value="info"/> 
     <appender-ref ref="DEFAULT"/> 
    </category> 

    <!-- ROOT CATEGORY --> 
    <root> 
     <priority value="debug"/> 
     <appender-ref ref="DEFAULT"/> 
     <!-- <appender-ref ref="STDOUT"/> --> 
    </root> 

</log4j:configuration> 

回答

1

UPDATE

與我原來的答覆的問題是由於您的問題中的格式錯誤。最初根元素是不可見的(現在已經更正),所以我認爲你已經提供了7個樣本文檔,而不是一個文檔和7個子元素:)。

的log4j.dtd定義的元素名稱與他們冒號,如果底層的解析器設置,因爲它認爲該元素log4j:configuration真的是在命名空間http://jakarta.apache.org/log4j/命名configuration的元素名稱空間感知的,這是混淆了JAXB實現。

解決的辦法是強制JAXB實現使用非命名空間感知的解析器:

package log4j; 

import java.io.FileInputStream; 

import javax.xml.bind.JAXBContext; 
import javax.xml.bind.Marshaller; 
import javax.xml.bind.Unmarshaller; 
import javax.xml.bind.UnmarshallerHandler; 
import javax.xml.parsers.SAXParser; 
import javax.xml.parsers.SAXParserFactory; 

import org.xml.sax.InputSource; 
import org.xml.sax.XMLReader; 

public class Demo { 

    public static void main(String[] args) throws Exception { 
     SAXParserFactory spf = SAXParserFactory.newInstance(); 
     SAXParser sp = spf.newSAXParser(); 
     XMLReader xr = sp.getXMLReader(); 

     JAXBContext jc = JAXBContext.newInstance("log4j"); 
     Unmarshaller unmarshaller = jc.createUnmarshaller(); 
     UnmarshallerHandler unmarshallerHandler = unmarshaller.getUnmarshallerHandler(); 
     xr.setContentHandler(unmarshallerHandler); 

     FileInputStream xmlStream = new FileInputStream("src/log4j/file1.xml"); 
     InputSource xmlSource = new InputSource(xmlStream); 
     xr.parse(xmlSource); 

     Log4JConfiguration config = (Log4JConfiguration) unmarshallerHandler.getResult(); 

     Marshaller marshaller = jc.createMarshaller(); 
     marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true); 
     marshaller.marshal(config, System.out); 
    } 

} 

這裏是我做了工作:

獲取log4j.dtd我發現有3個log4j.dtd文件,我使用的文件是:

<log4j_home>/source/main/resources/org/apache/log4j/xml 

運行XJC

由於我們使用的XJC在DTD文件,而不是我們需要指定-dtd標誌的XML模式:

xjc -p log4j -d out -dtd log4j.dtd 

創建的JAXBContext

接下來,我使用我使用的log4j包創建JAXBContext d XJC產生:

JAXBContext jc = JAXBContext.newInstance("log4j"); 

演示代碼

import java.io.File; 

import javax.xml.bind.JAXBContext; 
import javax.xml.bind.Marshaller; 
import javax.xml.bind.Unmarshaller; 

public class Demo { 

    public static void main(String[] args) throws Exception { 
     JAXBContext jc = JAXBContext.newInstance("log4j"); 

     processXML(jc,"src/log4j/file1.xml"); 
     processXML(jc,"src/log4j/file2.xml"); 
     processXML(jc,"src/log4j/file3.xml"); 
     processXML(jc,"src/log4j/file4.xml"); 
     processXML(jc,"src/log4j/file5.xml"); 
     processXML(jc,"src/log4j/file6.xml"); 
     processXML(jc,"src/log4j/file7.xml"); 
    } 

    private static void processXML(JAXBContext jc, String fileName) throws Exception { 
     Unmarshaller unmarshaller = jc.createUnmarshaller(); 
     Object o = unmarshaller.unmarshal(new File(fileName)); 

     Marshaller marshaller = jc.createMarshaller(); 
     marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true); 
     marshaller.marshal(o, System.out); 
    } 
} 
+0

進口javax.xml.bind中。*; import java.io. *; import java.util。*; import log4j。*; 公共類我{ 公共靜態無效主要(字符串ARGS [])拋出異常 { 的JAXBContext JS = JAXBContext.newInstance( 「log4j的」); Unmarshaller u = js.createUnmarshaller(); Object xmlConf = u.unmarshal(new File(「log.xml」)); Marshaller m = js.createMarshaller(); m.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT,Boolean.TRUE); m.marshal(xmlConf,new FileOutputStream(「out.xml」)); } } – user760263 2011-05-20 06:06:20