SimpleStart
本文将会建立一个基本的HTTP服务器,并监听8080端口,对于任何发往该服务器以及端口的请求,服务器会返回一个Hello World字符串。与Start部分不同的是:
SimpleStart将会使用IDE,也就是集成开发环境来简化开发流程;
SimpleStart将会使用Gradle,而非Maven来简化相关设置。
首先去JetBrain官方网站:www.jetbrains.com 免费下载集成开发环境(IDE)IntelliJ IDEA,有两个版本,社区版(Community)和终极版(Ultimate),后者需要付费使用,相比起前者而言,多了很多Java EE的支持,幸运的是,我们不需要使用这些貌似很牛逼其实无用的功能,用社区版就好了。下载后安装。
随后修改build.gradle为:
version '1.0-SNAPSHOT'
apply plugin: 'java'
sourceCompatibility = 1.8
targetCompatibility = 1.8//新增
repositories {
mavenCentral()
}
dependencies {
compile 'io.vertx:vertx-core:3.4.2'//新增 vert.x core的依赖
}
//以下部分新增
jar {
manifest {
attributes "Main-Class": "io.example.Main"//指定Main函数所在的类
from {
configurations.compile.collect { it.isDirectory() ? it : zipTree(it) }
}
}
然后我们在src/main/java/io/example
目录(是的,您需要新建io和example两级文件夹)下新建两个java文件,分别是Main.java
和MyFirstVerticle.java
,代码如下:
Main.java
MyFirstVerticle.java
package io.example;
import io.vertx.core.AbstractVerticle;
/**
* Created by chengen on 26/04/2017.
*/
public void start() {
vertx.createHttpServer().requestHandler(req -> {
req.response()
.putHeader("content-type", "text/plain")
}).listen(8080);
}
}
随后打开浏览器,在浏览器的地址栏中输入:http://localhost:8080/ 便可看到熟悉的Hello World!啦。
我们也可以使用Launcher
来替代Main
类,这也是官方推荐的方式,修改build.gradle
如下:
然后在src/main/java/io/example
目录下新增MainVerticle.java
文件,代码如下:
package io.example;
import io.vertx.core.AbstractVerticle;
/**
* Created by chengen on 26/04/2017.
*/
public class MainVerticle extends AbstractVerticle {
public void start() {
vertx.deployVerticle(MyFirstVerticle.class.getName());
然后重新打包后执行,便可再次看到Hello World!。
jar文件本质上就是一个zip文件,可以用打开zip的压缩工具解压,读者可自行解压拆开jar包,看看相关依赖的文件是否在里面。比如例子中的代码除了生成io.example.MyFirstVerticle.class和io.example.MainVerticle.class文件以外,还同时将依赖的io.vertx.core中的内容压入jar包。