使用Eclipse打包jar包,指定了main class。
java -jar mongoCluster.jar
但是运行的时候报ClassNotFoundException NoClassDefFoundError
经查找,由Eclipse自动打包生成MANIFEST.MF不正确,正确的MANIFEST.MF如下
Manifest-Version: 1.0
Main-Class: net.java2000.test.jar.TestJar
Class-Path: spring.jar
lib/commons-logging-1.1.jar
这里特别说明一下
1)在 Class-Path: 后面有一个空格,切记
2)在 Class-Path: 后面写上你的jar 用空格分开
3)MANIFEST有严格的长度限制,如果class-path长了,就必须换行,
切记在上一行末尾一定要有一个空格,下一行的开头一定要有2个空格
4)最后一定要空2行,否则Eclipse打包时有可能把你的Class-Path 给忽略掉
实际上,上面的方法能在某些环境下起到一定作用,但是无法根除。
笔者试过在Windows上面可以找到jar,在Linux上面找不到jar的恶心情况。
stackoverflow上面有人说,其实是不可以把第三方jar打到自己的jar包里面。也不建议这么搞。
百度有如下的解决方法:
1) 使用 java -cp 来设置 classpath 对于 jar来说是无效的,因为根据jar的安全规定,其内部的Class-Path 会起作用,外部的会被屏蔽掉(注意是屏蔽掉,不是覆盖掉)
2) Java自身提供了一个设置classpath的方案,那就是使用命令行参数
-Xbootclasspath: 完全取代基本核心的Java class 搜索路径.
不常用,否则要重新写所有Java 核心class
-Xbootclasspath/a: 后缀在核心class搜索路径后面.常用!!
-Xbootclasspath/p: 前缀在核心class搜索路径前面.不常用,避免
引起不必要的冲突.
语法如下:
(分隔符与classpath参数类似,unix使用:号,windows使用;)
java -Xbootclasspath/a:spring.jar;lib/commons-logging-1.1.jar -jar MyProject.jar
3)当然,你把jar放到 {Java_home}/jre/lib/ext 这个目录下面也是可以的,应为JVM肯定会搜索这个目录。
相关推荐
动态加载jar包是一种在程序运行时按需引入外部库或者组件的技术,这使得应用程序更加灵活,可以适应不同的环境和需求。这种技术广泛应用于插件系统、框架开发以及服务升级等场景,因为它允许程序在不重启的情况下...
在操作excel表格时,因为存在Excel2003和Excel2007两种版本的excel表格,所有如果jar包引入不够,会报一些异常,如: 执行到这一样时:new XSSFWorkbook(stream); 异常:Caused by: java.lang....
标题中的“json_jar包”指的是一个Java应用程序的归档文件(JAR),这个JAR文件包含了处理JSON相关操作的库。在Java开发中,JAR文件是一个包含多个类文件和资源文件的压缩包,用于分发和运行Java应用程序或库。 ...
2. 如果你是通过命令行编译和运行Java程序,可以使用`-cp`或`-classpath`选项指定包含jar包的目录。 3. 在Maven或Gradle项目中,可以在pom.xml或build.gradle文件中声明依赖,这样构建工具会在运行时自动下载并添加...
确保所有必要的jar包都在classpath中,否则可能会遇到“ClassNotFoundException”或其他运行时错误。总的来说,Hive JDBC连接所需的jar包是一个完整的生态系统,涵盖了从Hive服务器通信到Hadoop文件系统访问的各个...
当你的Eclipse项目从一个版本升级到另一个版本时,可能会遇到某些jar包在新环境中找不到的情况,导致程序启动报错,如"ClassNotFoundException"或"NoSuchMethodError"等。 为了解决这个问题,有以下几种策略: 1. ...
标题提到的“连接数据库SQL Server的三个jar包”是Java应用程序与SQL Server交互的关键组件。这包括msbase.jar、mssqlserver.jar和msutil.jar,它们都是由Microsoft为Java开发的SQL Server JDBC驱动程序的一部分。...
DB2数据库驱动9.7版的jar包是Java开发者用于连接IBM DB2数据库的重要组件。在Java编程环境中,为了能够与DB2数据库进行交互,如执行SQL查询、更新数据或管理数据库对象,需要引入特定的驱动程序。在这个案例中,我们...
在使用Oracle JDBC Jar包时,开发者需要确保引入了正确的驱动版本,以匹配运行的Oracle数据库版本。同时,需要了解如何配置数据源,创建`DataSource`对象,以及如何使用`Connection`、`Statement`和`ResultSet`等...
在本案例中,我们关注的是以下四个JDBC驱动的jar包: 1. msbase.jar:这个文件是SQL Server JDBC驱动的基础组件,包含了驱动程序的一些核心功能。它提供了基础的数据库连接、查询和事务处理等能力。 2. ...
在实际开发中,为了使用这些JAR文件,你需要将它们添加到Java项目的类路径中,这样编译器和运行时环境才能找到并加载所需的类。在Java代码中,你可以通过`Class.forName()`方法注册驱动,然后使用`DriverManager.get...
确保在运行Java程序之前,将所有必要的Jar包添加到类路径(classpath)中,或者如果你使用的是Maven或Gradle,将它们作为项目的依赖管理。 总之,连接Hive需要正确配置和理解涉及的JDBC驱动、Hive服务、Hadoop组件...
在本案例中,我们关注的是"sql server 驱动jar包",它包含了一个关键的文件"msbase.jar"。这个jar(Java Archive)文件是微软为SQL Server提供的JDBC驱动的一部分,用于允许Java应用程序通过JDBC接口与SQL Server...
在这个主题中,我们将详细探讨如何使用Java和JSP与SQL Server 2012进行交互,并关注描述中提到的三个关键JAR包:msbase.jar、mssqlserver.jar和msutil.jar。 首先,让我们了解这三个JAR文件的作用: 1. msbase.jar...
使用这些jar包,开发者可以编写Java代码,利用JDBC API来建立与Oracle数据库的连接、执行SQL语句、处理结果集等。例如,以下是一个简单的示例: ```java import java.sql.Connection; import java.sql....
本篇将详细阐述"jdbcSQLServer_jar包"相关的知识点,帮助你理解和应用这个jar包来连接SQLServer数据库。 首先,JDBC是Java API,它为Java程序员提供了与各种数据库进行通信的统一接口。通过JDBC,开发者无需关心...
javax依赖包,还有四个jar包。用于解决高版本jdk提示AVA.LANG.CLASSNOTFOUNDEXCEPTION: JAVAX.XML.BIND.JAXBEXCEPTION。使用方法在博文里。直接把包放在lib文件夹下即可。
- **调试**:当遇到运行时错误,比如`ClassNotFoundException`,可以快速定位问题是否源于类路径配置。 - **依赖分析**:在理解项目依赖关系时,找出所有使用特定类的`jar`包,有助于优化构建过程。 - **代码迁移**...
当flink on yarn模式运行时,发生如下异常信息,需要将压缩包中的4个依赖jar包放入flink安装路径下的lib目录下。 Exception in thread "main" java.lang.NoClassDefFoundError: ...
SQL2005Jar包是针对Microsoft SQL Server 2005数据库系统的一组Java类库,主要用于在Java应用程序中与SQL Server 2005进行交互。这些JAR(Java Archive)文件包含了驱动程序和其他必要的组件,使得开发人员能够在...