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(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。