Server Plugin
Mustache
必要な依存関係: io.ktor:ktor-server-mustache
コード例: mustache
Nativeサーバーのサポート: ✖️ KtorはKotlin/Nativeをサポートしており、追加のランタイムや仮想マシンなしでサーバーを実行できます。
Ktorでは、Mustacheプラグインをインストールすることで、アプリケーション内でMustacheテンプレートをビューとして使用できます。
依存関係を追加する
Mustacheを使用するには、ビルドスクリプトにktor-server-mustacheアーティファクトを含める必要があります。
Kotlin
Groovy
XML
Mustacheをインストールする
アプリケーションにMustacheプラグインをインストールするには、指定された
モジュール
のモジュールを使用すると、ルートをグループ化してアプリケーションを構造化できます。
install関数に渡します。以下のコードスニペットは、Mustacheをインストールする方法を示しています。 - ...
embeddedServer関数呼び出し内。 - ... 明示的に定義された
module内(これはApplicationクラスの拡張関数です)。
kotlin
kotlin
installブロック内で、MustacheテンプレートをロードするためのMustacheFactoryを設定できます。
Mustacheを設定する
テンプレートの読み込みを設定する
テンプレートをロードするには、MustacheFactoryをmustacheFactoryプロパティに割り当てる必要があります。例えば、以下のコードスニペットは、Ktorが現在のクラスパスに対するtemplatesパッケージ内のテンプレートを探すように設定します。
kotlin
import com.github.mustachejava.DefaultMustacheFactory
import io.ktor.server.application.*
import io.ktor.server.mustache.Mustache
import io.ktor.server.mustache.MustacheContent
fun Application.module() {
install(Mustache) {
mustacheFactory = DefaultMustacheFactory("templates")
}
}レスポンスでテンプレートを送信する
index.hbsテンプレートがresources/templatesにあるとします。
html
<html>
<body>
<h1>Hello, {{user.name}}</h1>
</body>
</html>ユーザーのデータモデルは次のようになります。
kotlin
data class User(val id: Int, val name: String)指定されたルートにテンプレートを使用するには、MustacheContentをcall.respondメソッドに次のように渡します。
kotlin
get("/index") {
val sampleUser = User(1, "John")
call.respond(MustacheContent("index.hbs", mapOf("user" to sampleUser)))
}