sh脚本执行Java程序

来源:互联网 发布:input 只读 获取数据 编辑:程序博客网 时间:2024/06/05 04:22
1、不引用Jar包或者资源文件夹

最简单的程序Hello World。

首先创建Hello.java

public class Hello {public static void main(String[] args) {System.out.println("Hello World");}}
编译生成Hello.class文件。下面写用sh脚本执行Hello

将以上生成的Hello.class文件拷贝至主文件夹,然后新建一个脚本文件ex.sh

#!/bin/bashcd /home/xyw//usr/lib/jvm/jdk1.7.0_21/bin/java Hello
说明:

cd /home/xyw/ 定位到Hello.class 文件所在的目录

/usr/lib/jvm/jdk1.7.0_21 是jdk的安装目录

Hello 是要执行的java程序

保存,对ex.sh 添加执行权限

chmod 777 ex.sh
执行ex.sh

./ex.sh
打印出Hello World

2、引用jar包或资源文件夹

在用java编写数据库程序时,往往会引用数据引擎的jar包,例如Mysql数据库,需要mysql-connector-java-5.1.24-bin.jar或者你编写的程序中不仅仅包含src源码文件,还有资源文件夹,下面总结如何在脚本文件中包含这些需要引用的文件。

新建一个java文件:Test.java

import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.Statement;public class Test {public static final String DBDRIVER = "org.gjt.mm.mysql.Driver";public static final String DBURL = "jdbc:mysql://127.0.0.1:3306/test";public static final String DBUSER = "root";public static final String DBPASS = "1234";public static void main(String[] args) throws Exception {Connection conn = null;Statement stat = null;ResultSet rs = null;Class.forName(DBDRIVER);String sql = "SELECT * FROM keyword";conn = DriverManager.getConnection(DBURL, DBUSER, DBPASS);stat = conn.createStatement();rs = stat.executeQuery(sql);while(rs.next()){System.out.println(rs.getInt(1) + ": " + rs.getString(2));}}}
这是一个基本的调用mysql数据的程序。编译,生成Test.class

将Test.class 文件置于:/home/xyw/任务/xx  文件夹下。

方法(1)

将mysql-connector-java-5.1.24-bin.jar包解压,将解压得到的com org 文件夹一起拷贝到/home/xyw/任务/xx  文件夹下,使Test.class 和com org 处在同一个目录中。编写脚本:

#!/bin/bashcd /home/xyw/任务/xx/usr/lib/jvm/jdk1.7.0_21/bin/java Test  
同样保存,添加执行权限,运行,得到查询结果。

方法(2):推荐使用

不解压mysql-connector-java-5.1.24-bin.jar,使用java -cp 命令指定文件类搜索路径

#!/bin/bashcd /home/xyw/任务/xx/usr/lib/jvm/jdk1.7.0_21/bin/java  -cp .:./mysql-connector-java-5.1.24-bin.jar Test
当前目录xx下有:Test.class 、mysql-connector-java-5.1.24-bin.jar
java 的cp命令功能如下:(cp和class path功能相同)

-cp <目录和 zip/jar 文件的类搜索路径>

-classpath <目录和 zip/jar 文件的类搜索路径>
                  用 : 分隔的目录, JAR 档案 和 ZIP 档案列表, 用于搜索类文件。

多个目录或者文件之间用冒号:分割。下面解析/usr/lib/jvm/jdk1.7.0_21/bin/java  -cp .:./mysql-connector-java-5.1.24-bin.jar Test 这句命令的含义

同样,/usr/lib/jvm/jdk1.7.0_21 指出jdk的安装目录。-cp后面的第一个. 表示当前目录,目的是在当前目录下查找类Test,如果没有这个. 会报错:"错误: 找不到或无法加载主类 Test"。中间的冒号起到间隔作用。./是在当前目录下的子目录,即在mysql-connector-java-5.1.24-bin.jar文件中搜索。最后是要执行的Test类。

我犯了一个错误,将Test放在-cp之前了,所以导致mysql-connector-java-5.1.24-bin.jar根本没有被搜索,一直不成功。所以切记:-cp 命令是直接跟在java 之后。

方法(3):推荐使用

将源码文件制作成jar包,将该jar包和需要引用的资源文件jar包放置在相同或者不同目录下(即下文制作jar包中:2引用jar包-方法(2)),在sh脚本命令中,执行制作的jar包。

setp1:制作jar包。见下文2、引用jar包之方法(2)

step2:将制作的jar包Test.jar 和引用的jar包mysql-connector-java-5.1.24-bin.jar放置在同一个目录下,假设为:/home/xyw

setp3:写脚本命令:

!#/bin/bashcd /home/xyw/usr/lib/jvm/jdk1.7.0_21/bin/java -jar Test.jar
分析:java命令会执行Test.jar 包,首先会找到jar包中Manifest文件,确定Main-Class指定的要执行的主方法,再根据Class-Path 指定的资源路径寻找运行需要的资源包,执行Test方法。
下面就具体介绍一下如何制作jar包。

拓展:制作可执行的jar包

1、不引用jar包以及资源文件

还是以第一个Hello.class 为例。Hello.class存在于目录:/home/xyw/任务/xx 内

将Hello.class制成可执行的jar文件。

step1:制作jar文件

jar cvf Hello.jar Hello.class
setp2:修改MANIFEST.MF文件

打开MANIFEST.MF文件,你看到的是:

Manifest-Version: 1.0Created-By: 1.7.0_21 (Oracle Corporation)
添加包含main方法的类:Main-Class: Test

即:

Manifest-Version: 1.0Created-By: 1.7.0_21 (Oracle Corporation)Main-Class: Test
注意:Main-Class冒号后面一定要有一个空格,然后再写类名称

保存,更新一下jar包,执行jar包

java -jar Hello.jar
输出:Hello World
2、引用jar包

以Test.class 文件为例。Test.class 文件存在于目录:/home/xyw/任务/xx 内

因为Test.class 依赖于mysql-connector-java-5.1.24-bin.jar包,更具体一点,是依赖与这个包中的com文件夹和org文件夹

方法(1):

只将com和org文件夹和Test.class添加到可执行的jar包中。

setp1:将mysql-connector-java-5.1.24-bin.jar解压缩,将得到的com和org文件夹放到/home/xyw/任务/xx 目录下。

当前/home/xyw/任务/xx 目录下文件(夹)包括:Test.class 、com、org

setp2:制作jar包

jar cvf Test.jar Test.class com/ org/
得到一个包含:Test.class 、META-INF、com、org 的jar包

step3:修改MANIFEST.MF文件

Manifest-Version: 1.0Created-By: 1.7.0_21 (Oracle Corporation)Main-Class: Test
保存,更新jar包,执行

java -jar Test.jar
方法(2):推荐方法
在方法1中,我们把com和org文件都从mysql-connector-java-5.1.24-bin.jar添加到了jar包中,也可以将mysql-connector-java-5.1.24-bin.jar单独存放,但是得在MANIFEST.MF文件中添加mysql-connector-java-5.1.24-bin.jar的路径。

setp1:将mysql-connector-java-5.1.24-bin.jar和Test.class 放置于相同的目录下,假设为/home/xyw/任务/xx。

step2:将Test.class添加到jar包

jar cvf Test.jar Test.class 
step3:修改MANIFEST.MF文件

Manifest-Version: 1.0Created-By: 1.7.0_21 (Oracle Corporation)Main-Class: TestClass-Path: ./mysql-connector-java-5.1.24-bin.jar
说明:Class-Path:是执行这个jar包的Main-Class对应的类时,类包的搜索路径。.表示当前jar所在的路径。./mysql-connector-java-5.1.24-bin.jar表示的是,和当前Test.jar 包在同一路径下的mysql-connector-java-5.1.24-bin.jar包。可以将引用的包和当前jar不放在同一目录下,假设mysql-connector-java-5.1.24-bin.jar放置在/home/xyw/目录下,则Class-Path应改为:Class-Path: /home/xyw/mysql-connector-java-5.1.24-bin.jar

注意:多个jar包之间用空格分开,每行最多72个字符,换行继续必须以空格开头(引用自:http://qyongkang.iteye.com/blog/1666640)

保存,执行

java -jar Test.jar

总结:

推荐方法:

1、sh脚本执行java程序,将引用包和源码放在同一个文件目录下,java命令通过指定-cp 运行程序。

2、制作可执行jar包,将jar包和引用包放置在同一目录下,使用Class-Path指定引用包目录。

本文为xyw_Eliot 原创,转载请注明出处:http://blog.csdn.net/xyw_eliot/article/details/8828182

原创粉丝点击