Javalin est un framework Web très léger pour Kotlin et Java qui prend en charge les requêtes WebSockets, HTTP2 et asynchrones. Les principaux objectifs de Javalin sont la simplicité, une excellente expérience de développement et une interopérabilité de premier ordre entre Kotlin et Java.
Javalin est plus une bibliothèque qu'un framework. Quelques points clés :
Vous n'avez pas besoin de prolonger quoi que ce soit
Il n'y a pas d'@Annotations
Il n'y a pas de reflet
Il n'y a pas d'autre magie ; juste du code.
La page Web du projet est javalin.io (la source est sur javalin/javalin.github.io).
Lire la documentation sur : javalin.io/documentation
Un résumé de la licence peut être trouvé sur TLDR Legal
Questions intéressantes
Nous disposons d'un serveur Discord très actif sur lequel vous pouvez obtenir de l'aide rapidement. Nous avons également un Slack (beaucoup moins actif) si vous préférez ça.
Les contributions sont les bienvenues, vous pouvez en savoir plus sur la contribution dans notre guide : CONTRIBUER
Veuillez envisager de parrainer ou de mettre en vedette Javalin si vous souhaitez soutenir le projet.
<dépendance> <groupId>io.javalin</groupId> <artifactId>javalin</artifactId> <version>6.3.0</version> </dépendance>
implémentation("io.javalin:javalin:6.3.0")
import io.javalin.Javalin;public class HelloWorld { public static void main(String[] args) { var app = Javalin.create(/*config*/) .get("/", ctx -> ctx.result("Bonjour tout le monde")) .start(7070); } }
importer io.javalin.Javalinfun main() { val app = Javalin.create(/*config*/) .get("/") { it.result("Hello World") } .start(7070) }
Cette section contient quelques exemples, pour la plupart simplement extraits de la documentation. Tous les exemples sont en Kotlin, mais vous pouvez les trouver en Java dans la documentation (ce ne sont que des changements de syntaxe).
Vous pouvez trouver plus d'exemples dans le référentiel javalin-samples.
importer io.javalin.Javalinimport io.javalin.apibuilder.ApiBuilder.*fun main() { val app = Javalin.create { config -> config.useVirtualThreads = vrai config.http.asyncTimeout = 10_000L config.staticFiles.add("/public") config.staticFiles.enableWebjars() config.router.apiBuilder { chemin("/utilisateurs") { obtenir (UserController :: getAll) poster (UserController :: créer) chemin("/{IDutilisateur}") { obtenir (UserController :: getOne) patch (UserController :: mise à jour) supprimer (UserController :: supprimer) } ws("/events", userController::webSocketEvents) } } }.start(7070) }
app.ws("/websocket/{chemin}") { ws -> ws.onConnect { ctx -> println("Connecté") } ws.onMessage { ctx -> val user = ctx.message<User>() // conversion de chaîne json en objet ctx.send(user) // convertir en chaîne json et renvoyer } ws.onClose { ctx -> println("Fermé") } ws.onError { ctx -> println("Erreur") } }
app.before("/some-path/*") { ctx -> ... } // s'exécute avant les requêtes vers /some-path/*app.before { ctx -> ... } // s'exécute avant toutes les requêtesapp .after { ctx -> ... } // s'exécute après toutes les requêtesapp.exception(Exception.class) { e, ctx -> ... } // s'exécute si Exceptionapp.error(404) { ctx -> .. . } // s'exécute si le statut est 404 (après tous les autres gestionnaires)app.wsBefore("/some-path/*") { ws -> ... } // s'exécute avant les événements ws sur /some-path/*app.wsBefore { ws -> .. . } } // s'exécute avant tous les ws eventsapp.wsAfter { ws -> ... } // s'exécute après tous les ws eventsapp.wsException(Exception.class) { e, ctx -> ... } // s'exécute si une exception n'est pas détectée dans ws gestionnaire
var todos = arrayOf(...) app.get("/todos") { ctx -> // mappe le tableau de Todos à la chaîne json ctx.json(toutes) } app.put("/todos") { ctx -> // mappe le corps de la requête (json) au tableau de Todos todos = ctx.body<Array<Todo>>() ctx.statut(204) }
app.post("/upload") { ctx -> ctx.uploadedFiles("files").forEach { uploadedFile -> FileUtil.streamToFile(uploadedFile.content(), "upload/${uploadedFile.filename()}") } }
Javalin dispose d'un système de plugins qui vous permet d'ajouter des fonctionnalités à la bibliothèque principale. Vous pouvez trouver une liste de plugins ici.
Installer un plugin est aussi simple que d'ajouter une dépendance à votre projet et de l'enregistrer auprès de Javalin :
Javalin.create {config -> config.registerPlugin(MonPlugin()) }
Certains des plugins les plus populaires sont :
Le plugin Javalin OpenAPI vous permet de générer une spécification OpenAPI 3.0 pour votre API au moment de la compilation.
Annotez vos routes avec @OpenApi
pour générer la spécification :
@OpenApi( résumé = "Obtenir tous les utilisateurs", opérationId = "getAllUsers", balises = ["Utilisateur"], réponses = [OpenApiResponse("200", [OpenApiContent(Array<User>::class)])], chemin = "/utilisateurs", méthodes = [HttpMethod.GET] )fun getAll(ctx : Contexte) { ctx.json(UserService.getAll()) }
Des implémentations de Swagger UI et ReDoc UI pour afficher la spécification générée dans votre navigateur sont également disponibles.
Pour plus d'informations, consultez le wiki Javalin OpenAPI.
Le plugin Javalin SSL vous permet de configurer facilement SSL pour votre serveur Javalin, prenant en charge une variété de formats tels que PEM, PKCS12, DER, P7B et JKS.
L'activation de SSL sur le port 443 est aussi simple que :
val plugin = SSLPlugin { conf -> conf.pemFromPath("/chemin/vers/cert.pem", "/chemin/vers/key.pem") }Javalin.create { javalinConfig -> javalinConfig.plugins.register(plugin) }.commencer()
Logo | Parrainer |
---|---|
@barbarysoftware (50 USD/m) | |
KabCash (50 USD/mois) |
Blake Mizerany, pour la création de Sinatra
Par Wendel, pour la création de Spark
Christian Rasmussen, pour être un gars formidable
Par Kristian Kummermo, également pour être un gars formidable