This is very much a work in progress and in the early stages. No code will be pushed to maven or supported in any way currently. Feel free to clone and install locally. Currently the website itself is not open souced but that is the eventual plan. The website is built using all the methods described on the site and in the examples. There is no backing blog framework.
Quick Example (full example Simple REST server in Undertow)
public static void createUser(HttpServerExchange exchange) {
User userInput = userRequests.user(exchange);
User user = userDao.create(userInput.getEmail(), userInput.getRoles());
if (null == user) {
ApiHandlers.badRequest(exchange, String.format("User %s already exists.", userInput.getEmail()));
return;
}
exchange.setStatusCode(StatusCodes.CREATED);
Exchange.body().sendJson(exchange, user);
}
public static void getUser(HttpServerExchange exchange) {
String email = userRequests.email(exchange);
User user = userDao.get(email);
if (null == user) {
ApiHandlers.notFound(exchange, String.format("User %s not found.", email));
return;
}
Exchange.body().sendJson(exchange, user);
}
public static final RoutingHandler ROUTES = new RoutingHandler()
.get("/users/{email}", timed("getUser", UserRoutes::getUser))
.post("/users", timed("createUser", UserRoutes::createUser))
.get("/metrics", timed("metrics", CustomHandlers::metrics))
.get("/health", timed("health", CustomHandlers::health))
.setFallbackHandler(timed("notFound", RoutingHandlers::notFoundHandler));
public static final HttpHandler ROOT = CustomHandlers.exception(EXCEPTION_THROWER)
.addExceptionHandler(ApiException.class, ApiHandlers::handleApiException)
.addExceptionHandler(Throwable.class, ApiHandlers::serverError);
public static void main(String[] args) {
SimpleServer server = SimpleServer.simpleServer(Middleware.common(ROOT));
server.start();
}
Check out issues to suggest topics, bug fixes, errors, or vote on issues. Reactions / comments may influence the order topics are added but no guarantees. Several topics will not be accepted here such as larger frameworks (Spring, Play, Jersey ...) as well as dependency injection. We will be more focused on rolling things yourself and solving practical problems. The coding style here may not fit with the norm but it should be very easy to convert any of the classes to be DI friendly.
A guide for building your own minimal embedded Java web server. A simple in order intro to a lot of uses cases for simple web development.
- Creating a local development environment with Docker Compose (MySQL, Elasticsearch)
- Configuring servers with Ansible
SLF4J is fairly standard and we chose to use Logback as our underlying implementation.
Typesafe config is a clean lightweight immutable configuration library. It offers several formats such as .properties
, .yml
, .json
as well as a human friendly json super set. It handles configuration inheritance, includes, data types (string, boolean, int, long, double, durations, arrays, ...), variabe substitution and many more features. Typesafe Config examples
Undertow is a very fast low level non blocking web server written in Java. It is very lightweight and has a very clean API that should be relatively easy for anyone who knows HTTP to pick up. Most custom code will be in the form of an HttpHandler which is a simple interface that can be used in a variety of ways.
- Writing Custom HttpHandlers
- Url Routing in Undertow
- Handling Exceptions in Undertow
- Creating Middleware in Undertow
- Simple REST server in Undertow
- Virtual Hosting in Undertow
- Webpack and npm with Java
- Sharing routes and running multiple webservers in a single JVM
- Configuring Security Headers in Undertow
- OkHttp Example REST client
- OkHttp Logging Interceptors
- OkHttpClient Trust All SSL Certificates
- Web Scraping with OkHttp and jsoup
HikariCP is a very fast lightweight Java connection pool. The API and overall codebase is relatively small (A good thing) and highly optimized. It also does not cut corners for performance like many other Java connection pool implementations.