`
cpu
  • 浏览: 168479 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Java在Linux平台编译出错,都是rt.jar惹的祸

    博客分类:
  • Java
阅读更多
    给公司项目做集成,发现项目在windows平台下能编译,在linux平台下编译报错。
原因是:<bootclasspath>${java.home}\lib\rt.jar</bootclasspath> 中的 "\" ,在linux平台不能编译。 把它改成 “/”, 其它开发人员用的 Eclipse会出错。
    最好的解决办法是不用这个“rt.jar”,(本人看到别人项目引用这个包,会感觉项目特别重量)。
    删除这个包,发现只有一个文件报错,程序包com.sun.image.codec.jpeg不存在。 一个验证码图片相关类用到了这个文件。


<plugin>
	<artifactId>maven-compiler-plugin</artifactId>
	<configuration>
		<encoding>UTF-8</encoding>
		<compilerArguments>
		  <verbose />
                  <bootclasspath>${java.home}\lib\rt.jar</bootclasspath>
		</compilerArguments>
	</configuration>
</plugin>


解决办法(转载)
转载:http://superich2008.iteye.com/blog/2047830

失败提示信息为:程序包com.sun.image.codec.jpeg不存在
这个类文件的位置在jre/lib/rt.jar

而我们设置的java_home下面的lib/dt.jar中没有这个文件,导致编译失败。通过配置maven-compiler-plugin插件可以解决此问题。



复制代码
<plugin>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>2.3.2</version>
                <configuration>
                    <source>1.6</source>
                    <target>1.6</target>
                    <encoding>UTF-8</encoding>
                    <optimize>true</optimize>  
                    <debug>true</debug>  
                    <showDeprecation>true</showDeprecation>  
                    <showWarnings>false</showWarnings>
                    <compilerArguments>
                        <verbose />
                        <bootclasspath>${java.home}/lib/rt.jar;${java.home}/lib/jce.jar</bootclasspath>
                    </compilerArguments>
                </configuration>
            </plugin>

复制代码



在windows下面用;分隔,linux下面用:分隔。

方案-:

  查询网上的解决方案,但是仍然报编译失败。后经过查找,最终定位问题。

  原因是由于编译的依赖JDK版本过高引起的。从JDK1.7开始,中com.sun.image.codec.jpeg这个类被删除,所以编译总是报错,解决方案,编译的JDK版本设置为JDK1.6或者以下版本,编译通过。

方案二:

  解决代码API引用问题。

  原始代码:

复制代码
        ByteArrayOutputStream out = null;
        byte[] b = null;
        try {
            BufferedImage bi = ImageIO.read(is);
            Image Itemp = bi.getScaledInstance(wdith, height, BufferedImage.SCALE_SMOOTH);
            BufferedImage thumbnail = new BufferedImage(wdith, height, BufferedImage.TYPE_INT_RGB);
            thumbnail.getGraphics().drawImage(Itemp, 0, 0, null);
            
            out = new ByteArrayOutputStream();
            
            // 绘图
            JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out);
            JPEGEncodeParam param = encoder.getDefaultJPEGEncodeParam(thumbnail);
            param.setQuality(1.0f, false);
            encoder.encode(thumbnail);
            out.flush();
            b = out.toByteArray();
            out.close();
            bi.flush();
            bi = null;
        } catch (IOException e) {
            logger.error(Util.stackTrace2String(e));
        }finally{
            if(out != null){
                try {
                    out.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }

复制代码
改变实现方式:

复制代码
        ByteArrayOutputStream out = null;
        byte[] b = null;
        try {
            BufferedImage bi = ImageIO.read(is);
//            Image Itemp = bi.getScaledInstance(wdith, height, BufferedImage.SCALE_SMOOTH);
//            BufferedImage thumbnail = new BufferedImage(wdith, height, BufferedImage.TYPE_INT_RGB);
//            thumbnail.getGraphics().drawImage(Itemp, 0, 0, null);
            
            out = new ByteArrayOutputStream();
            
            // 绘图
//            JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out);
//            JPEGEncodeParam param = encoder.getDefaultJPEGEncodeParam(thumbnail);
//            param.setQuality(1.0f, false);
//            encoder.encode(thumbnail);
            
            ImageIO.write(bi, "jpg", out);
            
            out.flush();
            b = out.toByteArray();
            out.close();
            bi.flush();
            bi = null;
        } catch (IOException e) {
            logger.error(Util.stackTrace2String(e));
        }finally{
            if(out != null){
                try {
                    out.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }

复制代码
即可解决报错问题。
分享到:
评论

相关推荐

    jce.jar和rt.jar .zip

    在给定的"jce.jar和rt.jar .zip"压缩包中,包含两个重要的JAR(Java Archive)文件:rt.jar和jce.jar。这两个文件在Java生态系统中扮演着至关重要的角色。 rt.jar,全称Runtime Library JAR,是Java运行时库的集合...

    java,jdk中rt.jar包

    在JDK中,`rt.jar`是一个至关重要的文件,它包含了Java标准类库的所有核心类。这个压缩包文件列表中的"rt"很可能就是指的`rt.jar`。 `rt.jar`这个名字是"Runtime"的缩写,顾名思义,它包含了Java运行时环境所需的...

    java-decompiler.jar java反编译

    上述命令表示将文件 d:/my.jar 进行反编译,**生成一个新的 my.jar**,存放在目录 d:/decompiled。 **虽然新的 my.jar 也是 .jar 后缀,但它里面的文件是 .java 格式,而非 .class 格式。** 直接将新 my.jar 解压...

    jdk1.8重新编译rt_debug.jar(亲测可用)

    jdk1.8重新编译rt_debug.jar(亲测可用)https://blog.csdn.net/cherrycheng_/article/details/51004386 打包步骤

    rt.jar的源码

    《深入解析rt.jar源码——基于JDK 1.8》 ...总的来说,rt.jar源码是Java开发者的宝贵资源,它揭示了Java平台的核心机制。通过深入学习rt.jar,我们可以不断提升自己的编程技能,成为一名更优秀的Java开发者。

    rt.jar源文件

    "rt.jar源文件"是Java开发中的核心组件之一,它包含了Java标准库(JDK)的大部分核心类的源代码。这些源代码对于深入理解Java平台的工作原理、学习和调试Java程序至关重要。rt.jar通常位于Java安装目录的jre/lib或...

    java-rt.jar.zip

    在Java应用程序的编译过程中,`javac`编译器会将源代码编译成字节码(`.class`文件),但实际执行时需要依赖`rt.jar`中的类。当JVM启动时,它会加载`rt.jar`内的所有类,使得程序能够正常运行。因此,如果你在没有...

    jdk源码调试重编译rt.jar包

    关于调试jdk源码显示源码变量值的rt.jar重编译包

    用于反编译jar为JAVA代码java -jar cfr-0.152.jar xx.jar -outputdir 路径

    标题和描述提到了一个使用名为CFR(Class File Reader)的工具来反编译.jar文件到原始的JAVA源代码的过程。 CFR是一个开源的Java反编译器,它能够将.class文件或.jar文件转换为接近原始的Java源代码形式。其版本号...

    dt-rt-tools的jar包

    标题中的"dt-rt-tools的jar包"提及了三个重要的Java类库文件:dt.jar、rt.jar和tools.jar。这些文件在Java开发中扮演着核心角色,尤其对于JDK(Java Development Kit)的使用者来说至关重要。 1. **dt.jar**: "dt...

    ant jenkins java rt.jar

    使用持续集成,自动发布系统时,用apache-ant-1.9.4编译项目,报缺少jar包 rt.jar

    java rt.jar.zip

    总之,Java RT.jar是Java平台的核心组件,包含了Java开发语言的基本功能和Android开发中部分依赖的API。对于任何Java或Android开发者来说,深入理解并熟练运用rt.jar中的类和方法都是提升开发能力的关键步骤。

    JDK中rt.jar、tools.jar和dt.jar作用.docx

    不过,需要注意的是,随着Java版本的更新,一些Swing类已经被包含在rt.jar中,因此在较新的Java版本中,dt.jar的重要性相对降低。 除了这三个jar文件,JRE的lib目录下还有其他一些重要的jar,如jce.jar(Java ...

    dx.jar和d8.jar工具

    在Android开发领域,dx.jar和d8.jar是两个非常重要的工具,它们主要负责将Java字节码转换为Dalvik字节码,这是Android系统运行应用所必需的格式。本文将详细探讨这两个工具的功能、用途以及它们之间的差异。 首先,...

    opencv-4.5.5编译后的jar包和linux平台的so文件

    Java开发者借助`opencv-455.jar` 可以方便地在这些AI项目中集成计算机视觉功能,而`libopencv_java455.so` 则确保了这些功能在Linux环境下的高效执行。 在实际使用过程中,开发者需要注意几个关键点: 1. **系统...

    反编译打开classes.dex.dex2jar.jar

    总之,`classes.dex.dex2jar.jar`的反编译过程是通过`dex2jar`将`.dex`转换为`.jar`,再用`jd-gui`展示反编译出的Java源代码。这是一项对Android开发者极其有用的技术,可以帮助他们理解APK内部的运作机制,但同时也...

    Java rt.jar 源码分析

    2. **JVM与字节码**:rt.jar中的每个类都对应一个字节码文件,这些字节码在Java虚拟机(JVM)上运行。分析源码可以揭示JVM如何解析和执行字节码,以及JIT(Just-In-Time)编译器如何将字节码优化为本地机器代码。 3...

    反编译工具,可以将android生成的framework.jar反编译为class,并且用jd-gui 查看修改是否编译进来

    在Android开发领域,有时我们需要对系统框架或者第三方库进行深入研究,这往往涉及到对已编译的二进制代码(如`.jar`或`.dex`文件)进行反编译。标题和描述提到的是一种这样的场景,即利用反编译工具将Android的`...

    利用 fernflower 反编译 jar包

    在IT行业中,有时候我们需要查看Java应用程序的源代码,但这些代码通常被编译成字节码(.class文件)并打包成.jar文件。在这种情况下,反编译工具就显得尤为重要,其中FernFlower是一款广泛使用的Java反编译器。本篇...

    linux下java环境gdal编译好的文件

    首先,`gdal.jar`是GDAL的Java绑定,它允许Java程序通过JNI(Java Native Interface)调用GDAL的C++接口。这个JAR文件包含了GDAL的Java类和方法,使得开发者可以在Java代码中处理地理空间数据,如栅格和矢量数据。 ...

Global site tag (gtag.js) - Google Analytics