ClassNotFoundException 在运行 JAR 时出现异常,在 IntelliJ IDEA 中运行时没有错误
我刚刚开始构建Java应用程序(我确实有.NET经验),我试图构建一个小型测试应用程序,其整个代码是这样的:
package com.company;
import com.microsoft.sqlserver.jdbc.SQLServerDataSource;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
public class Main {
    public static void main(String[] args) throws SQLException {
        System.out.println("Buna lume!");
        SQLServerDataSource ds = new SQLServerDataSource();
        ds.setIntegratedSecurity(true);
        ds.setServerName("localhost");
        ds.setPortNumber(1433);
        ds.setDatabaseName("Test");
        Connection con = ds.getConnection();
        String SQL = "SELECT * FROM Test WHERE ID = ?";
        PreparedStatement stmt = con.prepareStatement(SQL);
        stmt.setInt(1, 2);
        ResultSet rs = stmt.executeQuery();
        while (rs.next()) {
            System.out.println(rs.getInt(1) + ", " + rs.getString(2));
        }
        rs.close();
        stmt.close();
        con.close();
    }
}
如果我在IDE(IntelliJ IDEA 12.1.6 Community Edition)中运行该应用程序,并且SQL Server可用,则该应用程序可以正常运行。完全可以完成它应该做的事情。
SQL Server 驱动程序从 Microsoft 下载并添加为外部库。我已经创建了一个工件作为JAR文件:

现在,如果我在cliTest.jar(我的JAR)中包含sqljdbc4.jar,则生成的JAR是胖的(550kB,并且还包括该JAR中的类)。或者我可以排除它。无论哪种方式,运行
java -jar cliTest.jar
结果在
Buna lume!
Exception in thread "main" java.lang.NoClassDefFoundError: com/microsoft/sqlserv
er/jdbc/SQLServerDataSource
        at com.company.Main.main(Main.java:15)
Caused by: java.lang.ClassNotFoundException: com.microsoft.sqlserver.jdbc.SQLSer
verDataSource
        at java.net.URLClassLoader$1.run(Unknown Source)
        at java.net.URLClassLoader$1.run(Unknown Source)
        at java.security.AccessController.doPrivileged(Native Method)
        at java.net.URLClassLoader.findClass(Unknown Source)
        at java.lang.ClassLoader.loadClass(Unknown Source)
        at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
        at java.lang.ClassLoader.loadClass(Unknown Source)
        ... 1 more
我敢打赌我错过了一些非常基本的东西,但我只是无法弄清楚究竟是什么原因造成的。
LE1 :我尝试添加sqljdbc4.jar(尽管似乎没有必要)和sqljdbc_auth.dll包含在包含JAR的目录中,但仍然没有更改。
后来的编辑2:根据尼古拉的回答,我做了以下工作:
- 已删除现有工件
 - 创建了一个新的工件,如下所示:
 


..并得到这个:

构建 -> 构建工件 -> cliTest.jar -> Rebuild
CMD提示在包含以下内容的文件夹中:
[cliTest.jar生成了 566 KB]
java -jar cliTest.jar
现在我得到:
Exception in thread "main" java.lang.SecurityException: Invalid signature file d
igest for Manifest main attributes
    at sun.security.util.SignatureFileVerifier.processImpl(Unknown Source)
    at sun.security.util.SignatureFileVerifier.process(Unknown Source)
    at java.util.jar.JarVerifier.processEntry(Unknown Source)
    at java.util.jar.JarVerifier.update(Unknown Source)
    at java.util.jar.JarFile.initializeVerifier(Unknown Source)
    at java.util.jar.JarFile.getInputStream(Unknown Source)
    at sun.misc.URLClassPath$JarLoader$2.getInputStream(Unknown Source)
    at sun.misc.Resource.cachedInputStream(Unknown Source)
    at sun.misc.Resource.getByteBuffer(Unknown Source)
    at java.net.URLClassLoader.defineClass(Unknown Source)
    at java.net.URLClassLoader.access$100(Unknown Source)
    at java.net.URLClassLoader$1.run(Unknown Source)
    at java.net.URLClassLoader$1.run(Unknown Source)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at sun.launcher.LauncherHelper.checkAndLoadMain(Unknown Source)