Pustike Web provides API for creating application using RESTful Web Services with a central servlet DispatcherServlet
, having an API similar to JAX-RS. Applications developed using this library can be deployed in any Servlet container like other web frameworks.
The WebServletContextListener
and a DispatcherServlet
need to be declared and mapped according to the Servlet specification by using Java configuration or in web.xml. During servlet context initialization, the dependency injector should be configured using the ServletModule
and other application specific modules. Application modules register resource controller classes annotated with @Path
specifying relative path to the context. The DispatcherServlet
delegates incoming client requests, by matching their request path pattern, to the respective controller class which does the actual processing.
Controller methods can retrieve data from the servlet request by declaring parameter annotations with respective keys. It also includes the JSON data reader/writer with java object mapping that supports option to use specified fields only, based on requested data context.
Following are some of its key features:
DispatcherServlet
with an API similar to JAX-RS.@Path
to specify the relative path.@GET
, @PUT
, @POST
, @DELETE
, @HEAD
.@Consumes
.@Produces
(used for content negotiation).@PathParam
, @QueryParam
, @BeanParam
, @CookieParam
, @FormParam
, @HeaderParam
, JsonParam
. A default value can be specified using @DefaultValue
which is used when the key is not found.RequestScope
and SessionScope
are made available for binding resource classes when configuring the injector.Dependencies
This library requires Java 17 and following modules:
Group Id | Artifact Id | Version |
---|---|---|
jakarta.inject | jakarta.inject-api | 2.0.0 |
io.github.pustike | pustike-inject | 2.0.0 |
jakarta.json | jakarta.json-api | 2.1.2 |
io.github.pustike | pustike-json | 0.3.0 |
jakarta.servlet | jakarta.servlet-api | 6.0.0 |
org.eclipse.jetty.ee10 | jetty-ee10-servlet (optional) | 12.0.0 |
Documentation:
Download:
The most recent release is v0.9.0 (2023-08-29), and it is available from Maven central repository.
To add it as a dependency in Maven builds, use the following:
<dependency>
<groupId>io.github.pustike</groupId>
<artifactId>pustike-web</artifactId>
<version>0.9.0</version>
</dependency>
Or, download the latest JAR(~60kB) from Maven Central.
License: This library is published under the Apache License, Version 2.0