dos或shell调用执行jar包中的main方法(适用于linux/windows/macosx)

1、linux/macosx下命令行调用jar包

启动jar包

此方式多用于springboot构建的jar

#直接启动(可以被crtl+c杀死程序)
java -jar xxx.jar
#后台启动
nohup java -jar xxx.jar &

执行jar包内的main方法

如果我们需要执行jar包内的某一个main方法,通常会使用如下的命令(相信互联网上大多数的帖子也会如此教你):

java -cp xxx.jar com.xxx.xxx.XxxMain start

实际上这种方式是行不通的,虽然不能说它是错误的。这种方式的结果依然类似于执行了java -jar xxx.jar,执行的还是jar包内的启动类中的main方法。如果说你的jar包中有更多的main方法,而你恰恰想执行除了默认启动类之外的其他main方法,那上面的命令是达成不了你的心愿的。

你需要做的是:将jar包解压成目录,需要能见到.class文件才行;
然后在上面的命令上改造一下,需要考虑解压之后的目录结构,需要将XxxMain.class所需要的所有依赖jar包加载上才行;
java -cp ./xxx/BOOT-INF/classes/:./xxx/BOOT-INF/lib/1.jar:./xxx/BOOT-INF/lib/2.jar... com.xxx.xxx.XxxMain start

举个实际的例子:

java -cp ./diggov/BOOT-INF/classes/:./diggov/BOOT-INF/lib/htmlunit-core-js-2.23.jar:./diggov/BOOT-INF/lib/spring-webmvc-5.3.16.jar:./diggov/BOOT-INF/lib/httpcore-4.4.15.jar:./diggov/BOOT-INF/lib/activation-1.1.jar:./diggov/BOOT-INF/lib/slf4j-api-1.7.36.jar:./diggov/BOOT-INF/lib/spring-expression-5.3.16.jar:./diggov/BOOT-INF/lib/sac-1.3.jar:./diggov/BOOT-INF/lib/jackson-datatype-jdk8-2.13.1.jar:./diggov/BOOT-INF/lib/websocket-client-9.4.45.v20220203.jar:./diggov/BOOT-INF/lib/fastjson-1.2.73.jar:./diggov/BOOT-INF/lib/httpmime-4.5.13.jar xxx.xxx.diggov.main.XxxMain start

XxxMain.class的目录结构应当是:./xxx/xxx/diggov/main/XxxMain.class

2、windows下命令行调用jar包

基本与shell一样,唯一的区别就是依赖的jar包分隔符:变成了;,其他不变。

!SESSION 2025-08-25 10:36:36.584 ----------------------------------------------- eclipse.buildId=unknown java.version=1.8.0_291 java.vendor=Oracle Corporation BootLoader constants: OS=win32, ARCH=x86_64, WS=win32, NL=zh_CN Framework arguments: -application test.rcp.application Command-line arguments: -application test.rcp.application -data D:\eclipse4/../runtime-test.rcp.application -dev file:D:/eclipse4/.metadata/.plugins/org.eclipse.pde.core/test.rcp.application/dev.properties -os win32 -ws win32 -arch x86_64 -consoleLog !ENTRY org.eclipse.osgi 4 0 2025-08-25 10:36:38.323 !MESSAGE Application error !STACK 1 java.lang.NoClassDefFoundError: org/cef/CefApp at test.rcp.Application.start(Application.java:17) at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:203) at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:137) at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:107) at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:400) at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:255) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) at java.lang.reflect.Method.invoke(Unknown Source) at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:659) at org.eclipse.equinox.launcher.Main.basicRun(Main.java:595) at org.eclipse.equinox.launcher.Main.run(Main.java:1501) at org.eclipse.equinox.launcher.Main.main(Main.java:1474) Caused by: java.lang.ClassNotFoundException: org.cef.CefApp cannot be found by test.rcp_1.0.0.qualifier at org.eclipse.osgi.internal.loader.BundleLoader.findClassInternal(BundleLoader.java:511) at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:422) at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:414) at org.eclipse.osgi.internal.loader.ModuleClassLoader.loadClass(ModuleClassLoader.java:153) at java.lang.ClassLoader.loadClass(Unknown Source) ... 14 more An error has occurred. See the log file D:\runtime-test.rcp.application\.metadata\.log.
最新发布
08-26
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

cgv3

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值