项目自动化建构工具gradle 入门3——生一个exe的helloWorld

前两次呢,我们能够用一个外部的jar 来实现输出helloWorld。但问题是我每次都要用java -jar 来执行,这样我们自己玩还可以,让用户玩就不好了。所以我们生成一个exe给他们吧。这次我们仍然打印一个helloWorld,照例直接上代码,

1、进入目录D:\work\gradle\exe,新建文件build.gradle,键入内容:

 1 apply plugin: 'application' // 引入java插件,
 2 
 3 repositories {    // 从哪里找jar包
 4     flatDir {    
 5         // 先看下build.gradle文件所在目录下的 libs目录中有没有
 6         dirs 'libs'
 7     }
 8     maven {        
 9         //如果目录中木有,则找url对应的maven仓库,下面是阿里的maven仓库,速度杠杆的。
10         url "http://maven.aliyun.com/nexus/content/groups/public/"
11     }
12     //mavenCentral()    //如果都木有,则取maven的官方仓库吧,只是这个速度要看人品
13 }
14 dependencies {    
15     // 我们代码里需要用到的jar,可以引入不用,但是用了必须引入。
16     compile 'log4j:log4j:1.2.17'    //编译时需要的jar
17     testCompile 'junit:junit:4.11'    //编译测试文件所需要的
18 }
19 mainClassName = 'log.Hello'

2、进入目录D:\work\gradle\exe\src\main\java\log,新建文件Hello.java,键入内容:

1 package log;
2 import org.apache.log4j.Logger;
3 public class Hello{
4     private static Logger logger = Logger.getLogger(Hello.class);  
5     public static void main(String [] args){
6         logger.info("hello,world. welcome to gradle");  
7     }
8 }

3、进入目录D:\work\gradle\exe\src\main\resources,新建文件log4j.properties,键入内容:

 1  ### 设置###
 2 log4j.rootLogger = debug,stdout
 3 
 4 ### 输出信息到控制抬 ###
 5 log4j.appender.stdout = org.apache.log4j.ConsoleAppender
 6 log4j.appender.stdout.Target = System.out
 7 log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
 8 log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n
 9 
10 ### 输出DEBUG 级别以上的日志到=E://logs/error.log ###
11 log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
12 log4j.appender.D.File = d://logs/log.log
13 log4j.appender.D.Append = true
14 log4j.appender.D.Threshold = DEBUG 
15 log4j.appender.D.layout = org.apache.log4j.PatternLayout
16 log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
17 
18 ### 输出ERROR 级别以上的日志到=E://logs/error.log ###
19 log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
20 log4j.appender.E.File =d://logs/error.log 
21 log4j.appender.E.Append = true
22 log4j.appender.E.Threshold = ERROR 
23 log4j.appender.E.layout = org.apache.log4j.PatternLayout
24 log4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
log4j.properties

4、进入目录D:\work\gradle\exe,cmd下键入指令:gradle assemble

5、进入目录D:\work\gradle\exe\build\distributions,我们看到有了文件exe.zip 和exe.tar。这就是需要发布的文档了。

我们尝试把exe.zip解压看看,是不是有目录bin、lib。我们进入bin目录,使用cmd执行该exe.bat 是不是有了执行结果。

ok,到此我们就完成了所有的代码。


 

 

下面照例解释为啥这么写:

步骤1:build.gradle中第一行我们使用的不是java了,而变成了 application。这个插件干的活就是生成可执行的文档并打包。

在最后一行,我们使用 mainClassName 指定哪个类是可执行代码的入口类。

  记住,这两个都是必须的,少了可是会报错的。

其他的部分和<项目自动化建构工具gradle 入门2——log4j输出helloWorld> 中的解释是一样的。

 

步骤2,3,4就不用解释了。

posted @ 2017-01-01 19:00  老李走江湖  阅读(1430)  评论(0编辑  收藏  举报