javac编译外部jar包

这个有个很简单到解决办法,不过我也是尝试了很多方法,然后发现这个最好!


1. 找到安装jre目录的文件夹,我用到是ubuntu10.10,有些人用windows的也是一样到。
例如,我的是在:/usr/lib/jvm/java-6-openjdk/jre/
注意:ubuntu安装java jdk的时候,默认是安装到上面所示到那个文件夹里面到。


2. 然后找到jre目录下到/lib/ext文件夹,把外部jar包全部拷贝到ext文件夹下,然后运行javac的时候,javac就会自动把外部jar包找到,然后编译。
例如:我的是把jar包放到文件夹:/usr/lib/jvm/java-6-openjdk/jre/lib/ext下,无论多少个,都一样


3. 但是我运行.class的时候,产生了一个exception in thread main java.lang.noclassdeffounderror wrong name的错误,然后这个错误到解决方法来自下http://blog.sina.com.cn/s/blog_61eaa72b0100sdo5.html
找了好久才找到解决这个exception到办法!!我表示原作者真到是太给力了!!!不过现在已经不知道原作者是谁了,真是遗憾!
以下文章转载自:http://blog.csdn.net/studyvcmfc/archive/2009/06/05/4246086.aspx
----------------------------------------
不含包层次的HelloWorld.java

  public class HelloWorld{ public static void main(String[] args) { System.out.println("Hello World!"); }}

  保存在E:\java\src下,使用javac命令编译:

  E:\java\src>javac HelloWorld.java

  运行:

  E:\java\src>java HelloWorld

  屏幕打印出:

  Hello World!

  初学者常犯的错误

  1. 运行时,带了.class后缀

  如果你试图使用如下命令:

  E:\java\src>java HelloWorld.class

  系统会误认为你运行的是HelloWorld包下的名为class的类文件,会到系统的CLASSPATH下(一般都包括当前目录)企图寻找 HelloWorld.class.class这样的类,这样的类当然不存在了;并且也不可能存在,因为class是关键字,不能作为一个类的名字。所以会报如下错误信息:

  Exception in thread "main" java.lang.NoClassDefFoundError: HelloWorld/class

  2. 文件名大小写错误

  对于像Windows这样的系统,编译时可以不关心大小写。比如编译HelloWorld.java时,也可以使用:

  E:\java\src>javac helloworld.java

  也可以编译通过,但产生的类文件仍然是和源文件相符的:HelloWorld.class。

  但在运行时一定要注意大小写,比如试图使用如下命令运行:

  E:\java\src>java helloworld

  将报类似于1中的错误:

  Exception in thread "main" java.lang.NoClassDefFoundError: helloworld (wrong name: HelloWorld)

  包含包层次的HelloWorld.java

  比如上面的HelloWorld.java修改如下:

   package org.javaresearch;public class HelloWorld{ public static void main(String[] args) { System.out.println("Hello World!"); }}

  编译时有两种方法

  1. 直接编译

  E:\java\src>javac HelloWorld.java

  此时在当前目录下输出HelloWorld.class。此时,运行不能使用上面相同的方法,使用:

  E:\java\src>java HelloWorld

  运行时,出现如下错误:

  Exception in thread "main" java.lang.NoClassDefFoundError: HelloWorld (wrong name: org/javaresearch/HelloWorld)

  从上述错误信息你也可以看到,系统可以找到HelloWorld类(因为当前路径包含在CLASSPATH中,具体为什么会提示wrong name,有兴趣的朋友参见Java语言规范),但这个类属于org.javaresearch包。所以,你要做的就是按照上述包层次,相应的创建目录层次,把上面生成的HelloWorld.class放到E:\java\src\org\javaresearch\目录下。运行:

  E:\java\src >java org.javaresearch.HelloWorld

  系统打印出:

  Hello World!

  这儿要注意的是,不能使用java org\javaresearch\HelloWorld来运行,此时同样会出现如下错误:

  Exception in thread "main" java.lang.NoClassDefFoundErrorrg\javaresearch\HelloWorld (wrong name: org/javaresearch/HelloWorld)

  哈哈,是不是有点怪怪的,那没办法。以后对Java的包有更深的认识时,就会明白了。

  2. 使用 -d <directory>编译选项

  是不是觉得上面的编译方法有点麻烦,能不能自动在当前路径(或任意指定的路径)下生成包层次呢?有!使用-d <directory>编译选项就能做到。

  E:\java\src >javac -d . HelloWorld.java

  此时,在当前目录下就生成了一个org\javaresearch目录,并且输出的.class文件也在里面。运行:

  E:\java\src >java org.javaresearch.HelloWorld

  系统打印:Hello World!

  如果你想把生成的类文件集中存放在一个目录中,比如:E:\java\classes下,那么你首先创建这个目录,然后编译时:

  E:\java\src >javac -d E:\java\classes HelloWorld.java

  就可以把生成的类文件放到E:\java\classes目录下,并且按照包层次相应的创建目录路径。你可以在E:\java\classes\org \ javaresearch下找到HelloWorld.class文件。此时使用如下命令可以正确运行(注意如果要用到其它类,请在CLASSPATH中设好):

  E:\java\classes >java org.javaresearch.HelloWorld

   一个数据库连接类中要引用第三方工具包,包因数据库的不同而不同.用javac命令编译运行:
  x86下,cmd进入dos环境.
  定位到要编译的类所在目录,编译DBAccess.java,假设第三方包也在当前目录.
  编译:javac -classpath classes12.jar.; DBAccess.java
  运行:java -classpath classes12.jar.; DBAccess
  ok.
  数据库连接字符串:
  oracle:jdbc:oracle:thin:localhost:orcl;scott;scott
  sqlserver2000:
  sqlserver2005:
  MySQL:
  String url= "jdbc:mysql://localhost:3306/myDB?user=soft&password=soft1234&useUnicode=true&characterEncoding=8859_1";
  
  SQL Server 2000:
  String url = "jdbc:microsoft:sqlserver://localhost:1433;User=nlc; Password=nlc;DatabaseName=nlc";
  
  SQL Server 2005:
  String url = "jdbc:sqlserver://[serverName[\instanceName][:portNumber]][;property=value[;property=value]] ";
  
  ORACLE:
  String url = "jdbc:oracle:thin:@localhost:1521:orcl";
  
  DB2:
  String url="jdbc:db2://192.9.200.108:6789/数据库名"
  
  Sybase:
  cn = DriverManager.getConnection( "jdbc:sybase:Tds:本地机为localhost,其它的为相应的IP地址:2638", 用户名, 密码);
  
  Informix:
  Class.forName("com.informix.jdbc.IfxDriver");
  String url = "jdbc:informix-sqli://123.45.67.89:1533/myDB:INFORMIXSERVER=myserver;
  user=testuser;password=testpassword";
  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值