问题描述
问题描述:用SpringMVC+red5流媒体服务器做个点播和直播的程序, 添加red5.jar ,出现:Class path contains multiple SLF4J bindings.详细提示:2013-4-25 18:05:17 org.apache.catalina.core.AprLifecycleListener init信息: The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: C:Program FilesMyEclipse 6.5bin;D:apache-tomcat-6.0.35bin2013-4-25 18:05:17 org.apache.coyote.http11.Http11Protocol init信息: Initializing Coyote HTTP/1.1 on http-802013-4-25 18:05:17 org.apache.catalina.startup.Catalina load信息: Initialization processed in 692 ms2013-4-25 18:05:17 org.apache.catalina.core.StandardService start信息: Starting service Catalina2013-4-25 18:05:17 org.apache.catalina.core.StandardEngine start信息: Starting Servlet Engine: Apache Tomcat/6.0.352013-4-25 18:05:17 org.apache.catalina.startup.HostConfig deployDescriptor信息: Deploying configuration descriptor host-manager.xml2013-4-25 18:05:18 org.apache.catalina.startup.HostConfig deployDescriptor信息: Deploying configuration descriptor manager.xml2013-4-25 18:05:18 org.apache.catalina.startup.HostConfig deployDirectory信息: Deploying web application directory docs2013-4-25 18:05:18 org.apache.catalina.startup.HostConfig deployDirectory信息: Deploying web application directory dwz2013-4-25 18:05:18 org.apache.catalina.startup.HostConfig deployDirectory信息: Deploying web application directory examples2013-4-25 18:05:18 org.apache.catalina.core.ApplicationContext log信息: ContextListener: contextInitialized()2013-4-25 18:05:18 org.apache.catalina.core.ApplicationContext log信息: SessionListener: contextInitialized()2013-4-25 18:05:18 org.apache.catalina.startup.HostConfig deployDirectory信息: Deploying web application directory ROOT2013-4-25 18:05:18 org.apache.catalina.startup.HostConfig deployDirectory信息: Deploying web application directory travel2013-4-25 18:05:19 org.apache.catalina.core.ApplicationContext log信息: Initializing Spring root WebApplicationContextlog4j:WARN No appenders could be found for logger (org.springframework.web.context.ContextLoader).log4j:WARN Please initialize the log4j system properly.SLF4J: Class path contains multiple SLF4J bindings.SLF4J: Found binding in [jar:file:/D:/apache-tomcat-6.0.35/webapps/travel/WEB-INF/lib/red5.jar!/org/slf4j/impl/StaticLoggerBinder.class]SLF4J: Found binding in [jar:file:/D:/apache-tomcat-6.0.35/webapps/travel/WEB-INF/lib/slf4j-log4j12-1.6.6.jar!/org/slf4j/impl/StaticLoggerBinder.class]SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.2013-4-25 18:05:23 org.apache.catalina.core.StandardContext listenerStart严重: Exception sending context initialized event to listener instance of class org.springframework.web.context.ContextLoaderListenerorg.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in ServletContext resource [/WEB-INF/applicationContext.xml]: Invocation of init method failed; nested exception is java.lang.UnsupportedClassVersionError: Bad version number in .class file (unable to load class org.slf4j.impl.StaticLoggerBinder)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1420)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:519)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456)at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:291)at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:288)at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:190)at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:563)at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:895)at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:425)at org.springframework.web.context.ContextLoader.createWebApplicationContext(ContextLoader.java:276)at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:197)at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:47)at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4206)at org.apache.catalina.core.StandardContext.start(StandardContext.java:4705)at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:799)at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:779)at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:601)at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:1079)at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:1002)at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:506)at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1317)at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:324)at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:142)at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1065)at org.apache.catalina.core.StandardHost.start(StandardHost.java:840)at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1057)at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:463)at org.apache.catalina.core.StandardService.start(StandardService.java:525)at org.apache.catalina.core.StandardServer.start(StandardServer.java:754)at org.apache.catalina.startup.Catalina.start(Catalina.java:595)at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)at java.lang.reflect.Method.invoke(Unknown Source)at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)Caused by: java.lang.UnsupportedClassVersionError: Bad version number in .class file (unable to load class org.slf4j.impl.StaticLoggerBinder)at org.apache.catalina.loader.WebappClassLoader.findClassInternal(WebappClassLoader.java:2822)at org.apache.catalina.loader.WebappClassLoader.findClass(WebappClassLoader.java:1159)at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1647)at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1526)at java.lang.ClassLoader.loadClassInternal(Unknown Source)at org.slf4j.LoggerFactory.bind(LoggerFactory.java:128)at org.slf4j.LoggerFactory.performInitialization(LoggerFactory.java:107)at org.slf4j.LoggerFactory.getILoggerFactory(LoggerFactory.java:295)at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:269)at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:281)at org.hibernate.cfg.Configuration.<clinit>(Configuration.java:152)at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)at java.lang.reflect.Constructor.newInstance(Unknown Source)at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:126)at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:104)at org.springframework.orm.hibernate3.LocalSessionFactoryBean.newConfiguration(LocalSessionFactoryBean.java:818)at org.springframework.orm.hibernate3.LocalSessionFactoryBean.buildSessionFactory(LocalSessionFactoryBean.java:549)at org.springframework.orm.hibernate3.AbstractSessionFactoryBean.afterPropertiesSet(AbstractSessionFactoryBean.java:211)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1477)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1417)... 36 more2013-4-25 18:05:23 org.apache.catalina.core.StandardContext start严重: Error listenerStart2013-4-25 18:05:23 org.apache.catalina.core.StandardContext start严重: Context [/travel] startup failed due to previous errors2013-4-25 18:05:23 org.apache.catalina.core.ApplicationContext log信息: Closing Spring root WebApplicationContext2013-4-25 18:05:23 org.apache.coyote.http11.Http11Protocol start信息: Starting Coyote HTTP/1.1 on http-802013-4-25 18:05:23 org.apache.jk.common.ChannelSocket init信息: JK: ajp13 listening on /0.0.0.0:80092013-4-25 18:05:23 org.apache.jk.server.JkMain start信息: Jk running ID=0 time=0/32 config=null2013-4-25 18:05:23 org.apache.catalina.startup.Catalina start信息: Server startup in 6017 ms当我删除 slf4j-log4j12-1.6.6.jar 的时候 又出现新的错误:2013-4-25 18:18:12 org.apache.catalina.core.AprLifecycleListener init信息: The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: C:Program FilesMyEclipse 6.5bin;D:apache-tomcat-6.0.35bin2013-4-25 18:18:13 org.apache.coyote.http11.Http11Protocol init信息: Initializing Coyote HTTP/1.1 on http-802013-4-25 18:18:13 org.apache.catalina.startup.Catalina load信息: Initialization processed in 687 ms2013-4-25 18:18:13 org.apache.catalina.core.StandardService start信息: Starting service Catalina2013-4-25 18:18:13 org.apache.catalina.core.StandardEngine start信息: Starting Servlet Engine: Apache Tomcat/6.0.352013-4-25 18:18:13 org.apache.catalina.startup.HostConfig deployDescriptor信息: Deploying configuration descriptor host-manager.xml2013-4-25 18:18:13 org.apache.catalina.startup.HostConfig deployDescriptor信息: Deploying configuration descriptor manager.xml2013-4-25 18:18:13 org.apache.catalina.startup.HostConfig deployDirectory信息: Deploying web application directory docs2013-4-25 18:18:13 org.apache.catalina.startup.HostConfig deployDirectory信息: Deploying web application directory dwz2013-4-25 18:18:13 org.apache.catalina.startup.HostConfig deployDirectory信息: Deploying web application directory examples2013-4-25 18:18:14 org.apache.catalina.core.ApplicationContext log信息: ContextListener: contextInitialized()2013-4-25 18:18:14 org.apache.catalina.core.ApplicationContext log信息: SessionListener: contextInitialized()2013-4-25 18:18:14 org.apache.catalina.startup.HostConfig deployDirectory信息: Deploying web application directory ROOT2013-4-25 18:18:14 org.apache.catalina.startup.HostConfig deployDirectory信息: Deploying web application directory travel2013-4-25 18:18:15 org.apache.catalina.core.ApplicationContext log信息: Initializing Spring root WebApplicationContextlog4j:WARN No appenders could be found for logger (org.springframework.web.context.ContextLoader).log4j:WARN Please initialize the log4j system properly.2013-4-25 18:18:18 org.apache.catalina.core.StandardContext listenerStart严重: Exception sending context initialized event to listener instance of class org.springframework.web.context.ContextLoaderListenerorg.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in ServletContext resource [/WEB-INF/applicationContext.xml]: Invocation of init method failed; nested exception is java.lang.UnsupportedClassVersionError: Bad version number in .class file (unable to load class org.slf4j.impl.StaticLoggerBinder)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1420)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:519)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456)at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:291)at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:288)at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:190)at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:563)at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:895)at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:425)at org.springframework.web.context.ContextLoader.createWebApplicationContext(ContextLoader.java:276)at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:197)at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:47)at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4206)at org.apache.catalina.core.StandardContext.start(StandardContext.java:4705)at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:799)at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:779)at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:601)at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:1079)at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:1002)at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:506)at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1317)at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:324)at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:142)at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1065)at org.apache.catalina.core.StandardHost.start(StandardHost.java:840)at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1057)at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:463)at org.apache.catalina.core.StandardService.start(StandardService.java:525)at org.apache.catalina.core.StandardServer.start(StandardServer.java:754)at org.apache.catalina.startup.Catalina.start(Catalina.java:595)at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)at java.lang.reflect.Method.invoke(Unknown Source)at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)Caused by: java.lang.UnsupportedClassVersionError: Bad version number in .class file (unable to load class org.slf4j.impl.StaticLoggerBinder)at org.apache.catalina.loader.WebappClassLoader.findClassInternal(WebappClassLoader.java:2822)at org.apache.catalina.loader.WebappClassLoader.findClass(WebappClassLoader.java:1159)at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1647)at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1526)at java.lang.ClassLoader.loadClassInternal(Unknown Source)at org.slf4j.LoggerFactory.bind(LoggerFactory.java:128)at org.slf4j.LoggerFactory.performInitialization(LoggerFactory.java:107)at org.slf4j.LoggerFactory.getILoggerFactory(LoggerFactory.java:295)at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:269)at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:281)at org.hibernate.cfg.Configuration.<clinit>(Configuration.java:152)at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)at java.lang.reflect.Constructor.newInstance(Unknown Source)at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:126)at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:104)at org.springframework.orm.hibernate3.LocalSessionFactoryBean.newConfiguration(LocalSessionFactoryBean.java:818)at org.springframework.orm.hibernate3.LocalSessionFactoryBean.buildSessionFactory(LocalSessionFactoryBean.java:549)at org.springframework.orm.hibernate3.AbstractSessionFactoryBean.afterPropertiesSet(AbstractSessionFactoryBean.java:211)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1477)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1417)... 36 more2013-4-25 18:18:18 org.apache.catalina.core.StandardContext start严重: Error listenerStart2013-4-25 18:18:18 org.apache.catalina.core.StandardContext start严重: Context [/travel] startup failed due to previous errors2013-4-25 18:18:18 org.apache.catalina.core.ApplicationContext log信息: Closing Spring root WebApplicationContext2013-4-25 18:18:19 org.apache.coyote.http11.Http11Protocol start信息: Starting Coyote HTTP/1.1 on http-802013-4-25 18:18:19 org.apache.jk.common.ChannelSocket init信息: JK: ajp13 listening on /0.0.0.0:80092013-4-25 18:18:19 org.apache.jk.server.JkMain start信息: Jk running ID=0 time=0/47 config=null2013-4-25 18:18:19 org.apache.catalina.startup.Catalina start信息: Server startup in 5916 ms求指点,谢谢。
解决方案
缺少jar包,通过运行你的项目,发现后台报错找不到类:logback下面的类,下载最新的logback的包,地址为:http://logback.qos.ch/download.html
解决方案二:
如果red5自带了slf,就把springmvc的删除看看。典型版本冲突。
解决方案三:
估计是red5.jar与slf4j-log4j12-1.6.6.jar中package和class重复造成的。你先用压缩软件打开red5.jar,然后删除org.slf4j.impl包,试试看会不会报错。
解决方案四:
java.lang.UnsupportedClassVersionError: Bad version number in .class file (unable to load class org.slf4j.impl.StaticLoggerBinder) Invocation of init method failed; nested exception is java.lang.UnsupportedClassVersionError: Bad version number in .class file (unable to load class org.slf4j.impl.StaticLoggerBinder) 即使用了不同版本的jdk编译的 造成不兼容估计你的slf4j太新了换成slf4j-api-1.5.6.jar试试https://red5.googlecode.com/files/Red5War_0.8.0.zip