迷失北京

          BlogJava 聯(lián)系 聚合 管理
            60 Posts :: 0 Stories :: 13 Comments :: 0 Trackbacks

          [Struts2]嚴(yán)重: Dispatcher initialization failed java.lang.RuntimeException      

                今天天非常的冷,在網(wǎng)絡(luò)中心(我經(jīng)常蝸居的地方)凍的手都快不能打字了。不過大好的時(shí)間不能浪費(fèi)呀,于是重新琢磨一下struts2。struts2是暑假的時(shí)候?qū)W習(xí)的,但是只是開學(xué)的時(shí)候做個(gè)一個(gè)項(xiàng)目,后來一直沒用,所以現(xiàn)在忘得也算是差不多了?。〔贿^讓人郁悶的是,在搭建的時(shí)候就報(bào)錯(cuò)了。非常的郁悶呀!具體的錯(cuò)誤代碼是這樣的:

          嚴(yán)重: Dispatcher initialization failed
          java.lang.RuntimeException: java.lang.reflect.InvocationTargetException
          	at com.opensymphony.xwork2.inject.ContainerImpl$MethodInjector.inject(ContainerImpl.java:295)
          	at com.opensymphony.xwork2.inject.ContainerImpl$ConstructorInjector.construct(ContainerImpl.java:431)
          	at com.opensymphony.xwork2.inject.ContainerBuilder$5.create(ContainerBuilder.java:207)
          	at com.opensymphony.xwork2.inject.Scope$2$1.create(Scope.java:51)
          	at com.opensymphony.xwork2.inject.ContainerBuilder$3.create(ContainerBuilder.java:93)
          	at com.opensymphony.xwork2.inject.ContainerBuilder$7.call(ContainerBuilder.java:487)
          	at com.opensymphony.xwork2.inject.ContainerBuilder$7.call(ContainerBuilder.java:484)
          	at com.opensymphony.xwork2.inject.ContainerImpl.callInContext(ContainerImpl.java:574)
          	at com.opensymphony.xwork2.inject.ContainerBuilder.create(ContainerBuilder.java:484)
          	at com.opensymphony.xwork2.config.impl.DefaultConfiguration.createBootstrapContainer(DefaultConfiguration.java:252)
          	at com.opensymphony.xwork2.config.impl.DefaultConfiguration.reloadContainer(DefaultConfiguration.java:193)
          	at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:66)
          	at org.apache.struts2.dispatcher.Dispatcher.init_PreloadConfiguration(Dispatcher.java:371)
          	at org.apache.struts2.dispatcher.Dispatcher.init(Dispatcher.java:415)
          	at org.apache.struts2.dispatcher.ng.InitOperations.initDispatcher(InitOperations.java:69)
          	at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.init(StrutsPrepareAndExecuteFilter.java:51)
          	at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:275)
          	at org.apache.catalina.core.ApplicationFilterConfig.setFilterDef(ApplicationFilterConfig.java:397)
          	at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:108)
          	at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:3800)
          	at org.apache.catalina.core.StandardContext.start(StandardContext.java:4450)
          	at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791)
          	at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771)
          	at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:526)
          	at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:987)
          	at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:909)
          	at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:495)
          	at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1206)
          	at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:314)
          	at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
          	at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
          	at org.apache.catalina.core.StandardHost.start(StandardHost.java:722)
          	at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
          	at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)
          	at org.apache.catalina.core.StandardService.start(StandardService.java:516)
          	at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
          	at org.apache.catalina.startup.Catalina.start(Catalina.java:583)
          	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:597)
          	at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288)
          	at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)
          Caused by: java.lang.reflect.InvocationTargetException
          	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:597)
          	at com.opensymphony.xwork2.inject.ContainerImpl$MethodInjector.inject(ContainerImpl.java:293)
          	... 42 more
          Caused by: java.lang.ExceptionInInitializerError
          	at com.opensymphony.xwork2.ognl.OgnlValueStackFactory.setContainer(OgnlValueStackFactory.java:85)
          	... 47 more
          Caused by: java.lang.IllegalArgumentException: Javassist library is missing in classpath! Please add missed dependency!
          	at ognl.OgnlRuntime.<clinit>(OgnlRuntime.java:165)
          	... 48 more
          Caused by: java.lang.ClassNotFoundException: javassist.ClassPool
          	at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1387)
          	at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1233)
          	at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:320)
          	at java.lang.Class.forName0(Native Method)
          	at java.lang.Class.forName(Class.java:169)
          	at ognl.OgnlRuntime.<clinit>(OgnlRuntime.java:162)
          	... 48 more
          2010-12-30 16:10:56 org.apache.catalina.core.StandardContext filterStart
          嚴(yán)重: Exception starting filter struts2
          java.lang.reflect.InvocationTargetException - Class: com.opensymphony.xwork2.inject.ContainerImpl$MethodInjector
          File: ContainerImpl.java
          Method: inject
          Line: 295 - com/opensymphony/xwork2/inject/ContainerImpl.java:295:-1
          	at org.apache.struts2.dispatcher.Dispatcher.init(Dispatcher.java:428)
          	at org.apache.struts2.dispatcher.ng.InitOperations.initDispatcher(InitOperations.java:69)
          	at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.init(StrutsPrepareAndExecuteFilter.java:51)
          	at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:275)
          	at org.apache.catalina.core.ApplicationFilterConfig.setFilterDef(ApplicationFilterConfig.java:397)
          	at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:108)
          	at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:3800)
          	at org.apache.catalina.core.StandardContext.start(StandardContext.java:4450)
          	at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791)
          	at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771)
          	at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:526)
          	at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:987)
          	at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:909)
          	at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:495)
          	at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1206)
          	at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:314)
          	at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
          	at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
          	at org.apache.catalina.core.StandardHost.start(StandardHost.java:722)
          	at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
          	at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)
          	at org.apache.catalina.core.StandardService.start(StandardService.java:516)
          	at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
          	at org.apache.catalina.startup.Catalina.start(Catalina.java:583)
          	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:597)
          	at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288)
          	at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)
          Caused by: java.lang.RuntimeException: java.lang.reflect.InvocationTargetException
          	at com.opensymphony.xwork2.inject.ContainerImpl$MethodInjector.inject(ContainerImpl.java:295)
          	at com.opensymphony.xwork2.inject.ContainerImpl$ConstructorInjector.construct(ContainerImpl.java:431)
          	at com.opensymphony.xwork2.inject.ContainerBuilder$5.create(ContainerBuilder.java:207)
          	at com.opensymphony.xwork2.inject.Scope$2$1.create(Scope.java:51)
          	at com.opensymphony.xwork2.inject.ContainerBuilder$3.create(ContainerBuilder.java:93)
          	at com.opensymphony.xwork2.inject.ContainerBuilder$7.call(ContainerBuilder.java:487)
          	at com.opensymphony.xwork2.inject.ContainerBuilder$7.call(ContainerBuilder.java:484)
          	at com.opensymphony.xwork2.inject.ContainerImpl.callInContext(ContainerImpl.java:574)
          	at com.opensymphony.xwork2.inject.ContainerBuilder.create(ContainerBuilder.java:484)
          	at com.opensymphony.xwork2.config.impl.DefaultConfiguration.createBootstrapContainer(DefaultConfiguration.java:252)
          	at com.opensymphony.xwork2.config.impl.DefaultConfiguration.reloadContainer(DefaultConfiguration.java:193)
          	at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:66)
          	at org.apache.struts2.dispatcher.Dispatcher.init_PreloadConfiguration(Dispatcher.java:371)
          	at org.apache.struts2.dispatcher.Dispatcher.init(Dispatcher.java:415)
          	... 29 more
          Caused by: java.lang.reflect.InvocationTargetException
          	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:597)
          	at com.opensymphony.xwork2.inject.ContainerImpl$MethodInjector.inject(ContainerImpl.java:293)
          	... 42 more
          Caused by: java.lang.ExceptionInInitializerError
          	at com.opensymphony.xwork2.ognl.OgnlValueStackFactory.setContainer(OgnlValueStackFactory.java:85)
          	... 47 more
          Caused by: java.lang.IllegalArgumentException: Javassist library is missing in classpath! Please add missed dependency!
          	at ognl.OgnlRuntime.<clinit>(OgnlRuntime.java:165)
          	... 48 more
          Caused by: java.lang.ClassNotFoundException: javassist.ClassPool
          	at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1387)
          	at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1233)
          	at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:320)
          	at java.lang.Class.forName0(Native Method)
          	at java.lang.Class.forName(Class.java:169)
          	at ognl.OgnlRuntime.<clinit>(OgnlRuntime.java:162)
          	... 48 more
          

            

          這是什么意思呢??于是到網(wǎng)上查呀查.....終于找到癥結(jié)了!因?yàn)槲疑壛藄truts的版本,升級到了struts2.2.1。struts2.2運(yùn)行除了那幾個(gè)基本必備的之外,還需要一個(gè)javassist-3.7.ga 這樣的包文件。這個(gè)包的作用:Javassist是一個(gè)開源的分析、編輯和創(chuàng)建Java字節(jié)碼的類庫。原來如此,浪費(fèi)了一個(gè)多小時(shí)的時(shí)間,不過錯(cuò)誤還是弄明白了,挺爽的....

                                                                                                                                                         

          posted on 2010-12-30 16:24 王康 閱讀(4676) 評論(4)  編輯  收藏

          Feedback

          # re: [Struts2]嚴(yán)重: Dispatcher initialization failed java.lang.RuntimeException 2013-03-02 01:01 spodiu
          謝謝樓上的。我也通過了。  回復(fù)  更多評論
            

          # re: [Struts2]嚴(yán)重: Dispatcher initialization failed java.lang.RuntimeException[未登錄] 2013-07-17 13:03 lei
          謝謝,我用2.3也是這個(gè)問題,已經(jīng)搞定了  回復(fù)  更多評論
            

          # re: [Struts2]嚴(yán)重: Dispatcher initialization failed java.lang.RuntimeException 2013-09-23 17:52 RitaZhou
          @lei
          請問大俠,2.3的問題是如何解決的?  回復(fù)  更多評論
            

          # re: [Struts2]嚴(yán)重: Dispatcher initialization failed java.lang.RuntimeException 2015-04-11 21:02 cd
          大神耶  回復(fù)  更多評論
            


          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 荥经县| 德格县| 青浦区| 肇州县| 环江| 泰安市| 收藏| 亚东县| 扬中市| 珠海市| 岚皋县| 金湖县| 马龙县| 两当县| 奉化市| 永吉县| 望奎县| 长乐市| 西华县| 信阳市| 灌阳县| 望谟县| 屯昌县| 昭通市| 新昌县| 长丰县| 金塔县| 应城市| 车致| 江都市| 织金县| 双城市| 贵德县| 阿拉善盟| 剑川县| 天津市| 方正县| 龙游县| 新郑市| 普宁市| 麟游县|