我们的项目是在windows下开发的,今天把项目部署到一台Linux机器上,结果立马出错了,验证码无法显示,查看了一下异常信息,异常信息如下:
java.lang.IncompatibleClassChangeError: Found class com.sun.image.codec.jpeg.JPEGImageEncoder, but interface was expected
上网搜了一下,有的说JDK版本问题,导致无法加载JPEGImageEncoder;也有说JRE环境变量出错的。
先看第一个问题,JDK版本问题。我用java -version查看了一下,发现是SUN的JDK,不是openJDK;那会不会是环境变量的问题呢?cat /etc/profile看了一下,发现。。环境变量没设错啊!!!
再看第二个问题,JRE设置问题。我查看了一下tomcat的启动信息,果然发现了不对的地方:
using JRE : /usr
我的JRE目录不在/usr目录下啊~~~看来应该是tomcat访问的jre路径不对,导致了不能支持com.sun包下的类。
这可如何是好╮(╯_╰)╭
经过我不懈的努力,终于找到一个技术贴,有高人说startup.sh执行会去加载catalina.sh,而catalina.sh又会去加载setclasspath.sh,所以在setclasspath.sh的文件顶部,配置一下JAVA_HOME和JRE_HOME就OK了,即:
export JAVA_HOME=/usr/java/jdk6
export JRE_HOME=/usr/java/jdk6/jre
保存后运行,果然生效了,再看原先的验证码问题,已经正常解决,呼呼呼呼~~~~
PS.在查找的过程中,搜到两篇博文讲tomcat的classpath设置和catalina.sh的作用,在此记录一下: