在一个web项目中,运行build.xml文件是出现Error starting Sun's native2ascii
问题,我找了各种可能的情况,其他同事都没有这个问题,很是郁闷,也是在网上
发现了这个解决方法,
复制JDK目录下的lib文件夹的tools.jar到JRE目录下的lib文件夹下的ext文件夹
(另外一个更好的办法就是把JRE的路径设置到JDK的目录下)
Copying %Java_Home%/lib/tools.jar to %Java_Home%/jre/lib/ext/tools.jar fixed this problem.
(a better approach is to set up JRE path to the directory JDK)
经过分析:
今天使用Maven创建Appfuse的时候,发现出现Error starting Sun's native2ascii
Maven指向的是JRE的目录,JRE目录下没有tools.jar,故找不到native2ascii
研究后发现Maven指定的是../相对路径按道理能通过找寻上一级文件夹从而找到jdk目录继而找到tools.jar包
因此一般情况下是用JDK里面的JRE不会出现这个问题.
通过上面分析判断项目配置的JRE不在JDK的目录,把tools.jar文件放到JRE目录lib文件夹的ext文件夹下
问题解决。
http://blog.csdn.net/yqlx521/article/details/6934487
在匆忙的情况下,从另外一台电脑上拷了个tools.jar过来,但编译时报错如下:
bad class file: C:/Program Files/Java/jre1.5.0_11/lib/rt.jar(java/lang/Object.class)
class file has wrong version 49.0, should be 48.0
Please remove or make sure it appears in the correct subdirectory of the classpath.
出现这个错误的是因为C:/Program Files/Java/jre1.5.0_11/lib目录底下tools.jar 的版本, 和 JVM jre1.5.0启动 的版本不一致所造成.
由于C:/Program Files/Java/jre1.5.0_11/lib 目录底下tools.jar 的版本是 1.4, 而 Tomcat 却选择 1.5 版本的 JVM.
所以会出现
"class file has wrong version 49.0, should be 48.0" 的 error message.
当中 49.0 即是指 Java 的 1.5 版本, 而 48.0 是指 Java 的 1.4 版本.
找到原因后,解决就很简单了,从网上download一个1.5或更高版本的tools.jar替换一下,然后编译通过。
那为什么会出现 tools.jar 的版本和 JVM 的版本不符的情况呢?
首先要说明, 于 tomcat/common/lib/ 目录底下的那个 tools.jar 其实不是 tomcat 原本有的. 其实那是当你安装 Tomcat 时, Tomcat 从你指定的 JDK 目录底下的 lib 目录抄过去的.
这个 tools.jar 有何用处? 那其实是 JDK 本身附有的jar档, 是用来方便我们写 Java 程序的 (eg. 方便编译 Java). 举例说, 平时我们用的 javac 命令, 其实本身就是一个由 java 写成的程序, 而那正正就是于 tools.jar里面.
那为什么 Tomcat 需要将 JDK 的 tools.jar 抄去自己那里? 那是因为 Tomcat 需要用 tools.jar 裡面的 javac 程序, 去编译我们写好的 JSP 档桉.
可是, 编译的时候, 也需要 Java 程序本身需要的 library (class files) 才可以. 那么 Tomcat 到哪里去找那这些 library 呢? 到哪里找, 其实是取决于Tomcat 本身选定哪个 JVM, 而这个我们是可以自行到 Tomcat Configure里的 Java 版面里设定的. Tomcat 是会到你所设定的那个 JVM 所属的那个 JRE 目录底下的 lib 目录找 library, 亦即是那个 rt.jar 档桉 (Java 的 library 是在里面的).
但有时候修改后,tomcat在eclipse下启动和startup.bat启动时正常,用tomcat.exe启动时却又出现这错误了
这个原因是因为你一台机子上装了两个不同的JDK版本,而系统默认当前版本是更高的1.5版本
而tomcat.exe启动时使用的就是系统设置的版本了,也就是1.5了,所以就要将当前版本改为1.4版本的
在注册表中修改:
HEKY_LOCAL_MACHINE-->SOFTWARE-->JavaSoft-->Java Runtime Environment 中的CurrentVersion改为1.4版本的
重启就OK了
关于错误Unsupported major.minor version 49.0
原因是JDK1.5编译的内容放到了JDK1.4等低版本下
设置
「Window」->「Preferences」->「Java」->「Compiler」->「JDK Compliance level」->「1.4」
即:
「窗口」->「首选项」->「Java」->「编译器」->「编译器一致性级别」->「1.4」
重新编译发布,OK搞定!