In the computer and internet environment, authentication ensures that the identity of a user can be proven and verified against a system. This could prevent unauthorized access to the API. This decision is necessary so that only the requests made by the client to the API is allowed.
To better validate this decision we need to take a closer look at aspects such as access control and rights assignment. In an environment with multiple users, administration is required. The administration must ensure that no unauthorized persons have access to the API and must also ensure that new users can be created and managed. In the following scenarios are listed to understand why such a management is needed:
You can use the sources to provide a little insight on authentication methods.
The decision must be guaranteed by a research on the Internet. Important points are, which authentication methods are generally available and which ones are recommended by the Spring-Boot community on the Internet.
Facts for the decision are:
OAuth 2.0 Protocol Flow
+--------+ +---------------+
| |--(A)- Authorization Request ->| Resource |
| | | Owner |
| |<-(B)-- Authorization Grant ---| |
| | +---------------+
| |
| | +---------------+
| |--(C)-- Authorization Grant -->| Authorization |
| Client | | Server |
| |<-(D)----- Access Token -------| |
| | +---------------+
| |
| | +---------------+
| |--(E)----- Access Token ------>| Resource |
| | | Server |
| |<-(F)--- Protected Resource ---| |
+--------+ +---------------+
Source: RFC: 6749, The OAuth 2.0 Authorization Framework
Additionally, there must be an implementation that returns a fresh token to the logged user after the current token expires.
There are two ways to implement access control and rights assignment. Self-implementation: In this case, the management of access control and rights assignment is completely self programmed.
The second option is via an Identity and Access Management solution. Identity and Access Management solution aimed at modern applications and services. It makes it easy to secure applications and services (APIs) with little to no code. In addition to this, this solution offers many interfaces e.g. to social logins. For the most part, there is configuration overhead with this solution. The implementation effort mentioned in the previous paragraph is omitted.
Here you can find a tutorial on how to integrate Keycloak into a Spring application.
Based on a thorough research on the Internet and by comparing completed or running projects, an Identity and Access Management solution is a beneficial solution. The service requires a small configuration effort to connect it to a Spring application. Keycloack is free, open source and there is currently no better solution.