Ktor 入门
前言
最近要使用 netty
作为消息推送,之前一直想着集成在 Springboot
中使用,但是转念一想,netty
本身就可以作为服务器,为什么不再开一个服务呢?于是就想到了使用 Ktor
构建一个服务。
Ktor
是一个使用强大的 Kotlin 语言在互联系统中构建异步服务器与客户端的框架。并且正在努力的向其他平台构建,比如 JavaScript
,iOS
和 Android
,且逐步尝试支持原生环境( Native
)。
使用 Ktor
可以很快的写出一个 HelloWorld
工欲善其事必先利其器
ktor
是以 kotlin
为基础的一个异步框架,那么开发采用 IDEA 成了我们更加友好的选择。
在 IDEA 中 setting
Plugins
中的 MarketPlace 搜索 Ktor 。我们安装这个插件将更快的初始化我们的项目。
完成了基础工作,就可以开始我们的 Ktor
之旅了。
Hello World
暂时不需要选择任何模块。之后便可以下一步 下一步等,直到项目建立。
在 gradle
界面选择 auto-import
此时只要耐心等待所有的依赖安装完成
如果多次安装失败可以修改一下gradle的地址,将原有地址注释掉,修改为 阿里镜像。这样安装速度会很快,而且不容易失败
repositories {
mavenLocal()
//jcenter()
maven { url 'https://maven.aliyun.com/nexus/content/groups/public'
}
当项目构建完成的时候,在 src
目录下 Application.kt
中已经为我们生成了部分代码。
fun main(args: Array<String>): Unit = io.ktor.server.netty.EngineMain.main(args)
@Suppress("unused") // Referenced in application.conf
@kotlin.jvm.JvmOverloads
fun Application.module(testing: Boolean = false) {
}
开始编写我们的代码。
在 Application.module
中,编写我们要使用的路由。
fun Application.module(testing: Boolean = false) {
routing {
get("/") {
call.respondText("Hello World")
}
}
}
启动项目,访问 http://127.0.0.1:8080
此时就可以看到我们的 Hello World
。
routing
是 Ktor 中的核心模块,所以我们可以直接去使用。
构建一个 HTML 页面
ktor 中有 HTML DSL ,所以我们可以直接使用 Kotlin代码构建一个 html 页面。添加 html dsl 依赖
compile "io.ktor:ktor-html-builder:$ktor_version"
之后就可以愉快的写 dsl 了
get("/") {
call.respondHtml {
head {
title {
+"Ktor 入门"
}
}
body {
a {
href = "http://127.0.0.1:8080/register"
+"注册"
}
form {
action = "http://127.0.0.1:8080/user/login"
method=FormMethod.post
input {
type = InputType.text
value = ""
name="username"
}
input {
type = InputType.password
value = ""
name="password"
}
input {
type = InputType.submit
value = "登录"
}
}
}
}
}
重新启动一下
此时 我们的页面就出现了。
目前这个 表单无法访问 action 地址 已向 ktor 提交 Issues
用Locations路由
但是当我们的路由很多的时候,如果都写在一个文件里,不仅仅文件回变得很大,而且不利于维护和团队协作。所以有了另一个模块 locations
。
首先要安装这个模块,在 gradle
中添加,注 :功能目前还是实验性功能
dependencies {
compile "io.ktor:ktor-locations:$ktor_version"
}
安装完成后启动我们的模块。
fun Application.module(testing: Boolean = false) {
install(Locations) // 启用 Locations
routing {
// ...
}
}
首先是编写 route 采用 class 的形式
@Location("/user")
class User {
@Location("/login")
data class UserLogin(val username: String, val password: String)
@Location("/register")
data class UserRegister(val username: String, val password: String)
}
该代码目前必须和 Application
在一起。
我们这样就编写了我们的路由和子路由。
新建一个 UserController.kt
fun Route.user() {
post<User.UserLogin> {
call.respondText("登录成功")
}
post<User.UserRegister> { user ->
run {
call.respondText("用户 ${user.username} ${user.password}")
}
}
}
并且在我们的 Application
文件中声明该路由即可。
routing {
// …………
user()
//…………
}
此时访问的时候就可以访问到我们的子路由。
参考资料
Ktor 中文网 https://ktor.kotlincn.net/
打个广告
开发的小程序 生活小程序
相关内容
如果你觉得这篇文章对你有所帮助,欢迎赞赏~
赞赏