前两次呢,我们能够用一个外部的jar 来实现输出helloWorld。但问题是我每次都要用java -jar 来执行,这样我们自己玩还可以,让用户玩就不好了。所以我们生成一个exe给他们吧。这次我们仍然打印一个helloWorld,照例直接上代码,
1、进入目录D:\work\gradle\exe,新建文件build.gradle,键入内容:
apply plugin: 'application' // 引入java插件, repositories { // 从哪里找jar包
flatDir {
// 先看下build.gradle文件所在目录下的 libs目录中有没有
dirs 'libs'
}
maven {
//如果目录中木有,则找url对应的maven仓库,下面是阿里的maven仓库,速度杠杆的。
url "http://maven.aliyun.com/nexus/content/groups/public/"
}
//mavenCentral() //如果都木有,则取maven的官方仓库吧,只是这个速度要看人品
}
dependencies {
// 我们代码里需要用到的jar,可以引入不用,但是用了必须引入。
compile 'log4j:log4j:1.2.17' //编译时需要的jar
testCompile 'junit:junit:4.11' //编译测试文件所需要的
}
mainClassName = 'log.Hello'
2、进入目录D:\work\gradle\exe\src\main\java\log,新建文件Hello.java,键入内容:
package log;
import org.apache.log4j.Logger;
public class Hello{
private static Logger logger = Logger.getLogger(Hello.class);
public static void main(String [] args){
logger.info("hello,world. welcome to gradle");
}
}
3、进入目录D:\work\gradle\exe\src\main\resources,新建文件log4j.properties,键入内容:
### 设置###
log4j.rootLogger = debug,stdout ### 输出信息到控制抬 ###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n ### 输出DEBUG 级别以上的日志到=E://logs/error.log ###
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = d://logs/log.log
log4j.appender.D.Append = true
log4j.appender.D.Threshold = DEBUG
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n ### 输出ERROR 级别以上的日志到=E://logs/error.log ###
log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
log4j.appender.E.File =d://logs/error.log
log4j.appender.E.Append = true
log4j.appender.E.Threshold = ERROR
log4j.appender.E.layout = org.apache.log4j.PatternLayout
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就不用解释了。