/jooby

A modular micro web framework for Java and Kotlin

Primary LanguageJavaApache License 2.0Apache-2.0

Maven Central javadoc Become a Patreon Build Status coveralls.io codecov.io Google Group Join the chat at https://gitter.im/jooby-project/jooby Follow us on twitter

∞ do more, more easily

Jooby a modular micro web framework for Java and Kotlin:

Java:

import org.jooby.Jooby;

public class App extends Jooby {

  {
    get("/", () -> "Hey Jooby!");
  }

  public static void main(final String[] args) {
    run(App::new, args);
  }
}

Kotlin:

import org.jooby.*

class App: Kooby({
  get {
    "Hello Jooby!"
  }
})

fun main(args: Array<String>) {
  run(::App, *args)
}

features

  • Simple, effective and easy to learn

  • Fast development cycles: run, debug and reload your application using devtools available for Maven and Gradle

  • Script routes: annotation and reflection free programming model using lambdas. Similar to express.js, Sinatra, etc..

  • MVC routes: annotation and reflection programming model using controller classes. Similar to Spring, Jersey, etc..

  • Multi-server: Jetty, Netty and Undertow

  • Multi-protocol: HTTP, HTTPS, HTTP 2.0, Server-Sent Events and Web-Socket

  • Modular. Make it full-stack via the extensive module eco-system

  • Ready for the modern web with the asset management tools

found this project useful ❤️

  • Support by clicking the ⭐ button on the upper right of this page. ✌️

  • Buy Edgar a beer!

want to contribute?

  • Fork the project on Github, and clone that to your workstation
  • Read about building Jooby
  • Wondering what to work on? See task/bug list and pick up something you would like to work on.
  • Write unit tests.
  • Create an issue or fix one from issues.
  • If you know the answer to a question posted to our group - don't hesitate to write a reply.
  • Share your ideas or ask questions on the jooby group - don't hesitate to write a reply - that helps us improve javadocs/FAQ.
  • If you miss a particular feature - browse or ask on the group - don't hesitate to write a reply, show us some sample code and describe the problem.
  • Write a blog post about how you use or extend jooby.
  • Please suggest changes to javadoc/exception messages when you find something unclear.
  • If you have problems with documentation, find it non intuitive or hard to follow - let us know about it, we'll try to make it better according to your suggestions. Any constructive critique is greatly appreciated. Don't forget that this is an open source project developed and documented in spare time.

author

Edgar Espina

license

Apache License 2