锘??xml version="1.0" encoding="utf-8" standalone="yes"?>
鐜錛?/strong>sun jdk1.5.0_15 + tomcat 5.0.28
鍘熸湰浠ヤ負鑷繁鐜╀簡eclipse鍜宮yeclipse榪欎箞澶氬勾錛屼竴鍚戦」鐩殑閰嶇疆鍙戝竷鐢╩yeclipse铏界劧娌℃湁椹捐交灝辯啛錛屼絾鏄嚦灝戜笉浼氳闅鵑亾錛岃繖嬈$‘鍊掑湪浜嗚繖涓猨dk 1.5鍙妕omcat 5.0.28鐨勭幆澧冧笂銆傝皝鍙互鍓嶄竴鐩存病鏈夎瘯榪囧湪tomcat5.0.28涓婂彂甯僺truts2鍛紝鍒氬ソ鐜板湪瀹㈡埛璇翠竴瀹氳鐢╯truts2錛屽垰濂借嚜宸變篃鎯沖伩鍋挎柊錛屽嵈鍋垮埌浜嗚繖涓嫤澶淬傚紑濮嬭繕浠ヤ負鏄嚜宸辯敤myelipse deploy鐨勯棶棰橈紝緇撴灉鍗翠笉鏄紝涓哄暐鍒漢鐨則omcat5.5灝辮兘濂藉ソ鐨剅un鍛紵搴熻瘽涓嶅皯璇達紝鐜板湪灝辯湅浠ヤ笅exception錛?/span>
瀹屾暣鐨凟xception錛?br />
Exception starting filter struts2
javax.xml.transform.TransformerFactoryConfigurationError: Provider org.apache.xalan.processor.TransformerFactoryImpl not found
at javax.xml.transform.TransformerFactory.newInstance(Unknown Source)
at com.opensymphony.xwork2.util.DomHelper$DOMBuilder.<clinit>(DomHelper.java:167)
at com.opensymphony.xwork2.util.DomHelper.parse(DomHelper.java:115)
at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.loadConfigurationFiles(XmlConfigurationProvider.java:786)
at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.loadDocuments(XmlConfigurationProvider.java:132)
at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.init(XmlConfigurationProvider.java:100)
at com.opensymphony.xwork2.config.impl.DefaultConfiguration.reload(DefaultConfiguration.java:130)
at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:52)
at org.apache.struts2.dispatcher.Dispatcher.init_PreloadConfiguration(Dispatcher.java:398)
at org.apache.struts2.dispatcher.Dispatcher.init(Dispatcher.java:455)
at org.apache.struts2.dispatcher.FilterDispatcher.init(FilterDispatcher.java:201)
at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:225)
at org.apache.catalina.core.ApplicationFilterConfig.setFilterDef(ApplicationFilterConfig.java:308)
at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:79)
at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:3698)
at org.apache.catalina.core.StandardContext.start(StandardContext.java:4349)
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:823)
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:807)
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:595)
at org.apache.catalina.core.StandardHostDeployer.install(StandardHostDeployer.java:277)
at org.apache.catalina.core.StandardHost.install(StandardHost.java:832)
at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:701)
at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:432)
at org.apache.catalina.startup.HostConfig.start(HostConfig.java:983)
at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:349)
at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1091)
at org.apache.catalina.core.StandardHost.start(StandardHost.java:789)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1083)
at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:478)
at org.apache.catalina.core.StandardService.start(StandardService.java:480)
at org.apache.catalina.core.StandardServer.start(StandardServer.java:2313)
at org.apache.catalina.startup.Catalina.start(Catalina.java:556)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:585)
at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:287)
at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:425)
閿欒鍘熷洜錛?
璁や負鏄敱浜巎dk1.5 涓?tomcat5.0涔嬮棿鐨勫叧浜?TransformerFactoryImpl 綾葷殑鍐茬獊閫犳垚鐨勩?/strong>
tomcat-5.0.28\common\endorsed涓嬫湁涓や釜jar鍖咃細xercesImpl.jar鍜?strong>xml-apis.jar錛屽叾涓殑綾?strong> javax.xml.transform.TransformerFactory 涓巎dk1.5涓殑綾?strong>org.apache.xalan.processor.TransformerFactoryImpl鍏跺疄鏄悓涓涓被銆?br />
in tomcat java is called with the following argument:
-Djava.endorsed.dirs="X:\my_app\Portal\tomcat\common\endorsed"
In this directory you find two jar files: xercesImpl.jar and xml-apis.jar needed by tomcat and that must be loaded before all xmsl stuff present in the jdk (1.4 naming problem). And in the file xml-apis.jar the TransformerFactoryImpl is set to "org.apache.xalan.processor.TransformerFactoryImpl".
瑙e喅鍔炴硶錛?br />
1. 灝?strong>xml-apis.jar縐誨嚭endorsed鏂囦歡澶廣?br />
2. 鐢▁alan緋誨垪jar鍖呮浛鎹㈠師鏉ョ殑xercesImpl.jar鍜?strong>xml-apis.jar銆?br />
xalan緋誨垪jar鍖咃細serializer.jar銆亁alan.jar銆亁ercesImpl.jar鍜寈ml-apis.jar銆?br />
3. For other application, just check this file or dom3-xml-apis.jar in your class path.
錛堜互涓婂弬鑰?a href="http://m.tkk7.com/allen-zhe/">灝忕珛椋炲垁鐨?a class="postTitle2" id="viewpost1_TitleUrl" href="http://m.tkk7.com/allen-zhe/archive/2007/03/02/101373.html">TransformerFactoryImpl not found exception涓鏂囷紝涔熻阿璋綔鑰呰В絳旇繖涓毦棰橈級