Java程序打包成带参数的jar文件实例代码
这里我们通过ApacheCommonsCLI来完成目标功能,废话不多说直接上代码
所需的maven依赖
commons-cli commons-cli 1.4
这里我们贴出主类代码
Optionsopts=newOptions();
opts.addOption("h",false,"help");
OptionportOption=OptionBuilder.withArgName("args")
.withLongOpt("port").hasArg()
.create("p");
opts.addOption(portOption);
OptionfileOption=OptionBuilder.withArgName("args")
.withLongOpt("file").hasArg()
.create("f");
opts.addOption(fileOption);
OptionkafkaHostOption=OptionBuilder.withArgName("args")
.withLongOpt("kafkaHost").hasArg()
.create("kH");
opts.addOption(kafkaHostOption);
OptionkafkaPortOption=OptionBuilder.withArgName("args")
.withLongOpt("kafkaPort").hasArg()
.create("kP");
opts.addOption(kafkaPortOption);
OptionkafkaTopicOption=OptionBuilder.withArgName("args")
.withLongOpt("kafkaTopic").hasArg()
.create("kT");
opts.addOption(kafkaTopicOption);
BasicParserparser=newBasicParser();
CommandLinecl;
try{
cl=parser.parse(opts,args);
if(cl.getOptions().length>0){
if(cl.hasOption('h')){
HelpFormatterhf=newHelpFormatter();
hf.printHelp("Options",opts);
}else{
//Stringip=cl.getOptionValue("i");
Stringport=cl.getOptionValue("p");
Stringfile=cl.getOptionValue("f");
StringkafkaHost=cl.getOptionValue("kH");
StringkafkaPort=cl.getOptionValue("kP");
StringkafkaTopic=cl.getOptionValue("kT");
GetInfogetInfo=newGetInfo();
getInfo.getAndZgrab(file,port,kafkaHost,kafkaPort,kafkaTopic);
}
}else{
System.out.println("参数为空");
}
}catch(Exceptione){
e.printStackTrace();
}
记得将上述代码放到main函数中,将解析args[],这样将程序打包成jar文件后就可以实现我们的需求了。
执行命令:
java-jarjarName.jar-ffilename-pport-kHkafkaHost-kPkafkaPort-kTkafkaTopic
如果忘记了都需要传递什么参数,可以通过java-jarjarName.jar-h获取参数内容
总结
以上所述是小编给大家介绍的Java程序打包成带参数的jar文件实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。