public interface Realm
Realms usually have a 1-to-1 correspondence with a datasource such as a relational database, file system, or other similar resource. As such, implementations of this interface use datasource-specific APIs to determine authorization data (roles, permissions, etc), such as JDBC, File IO, Hibernate or JPA, or any other Data Access API. They are essentially security-specific DAOs.
Because most of these datasources usually contain Subject (a.k.a. User) information such as usernames and
passwords, a Realm can act as a pluggable authentication module in a
PAM configuration. This allows a Realm to
perform both authentication and authorization duties for a single datasource, which caters to the large
majority of applications. If for some reason you don't want your Realm implementation to perform authentication
duties, you should override the
supports(org.apache.shiro.authc.AuthenticationToken) method to always
Because every application is different, security data such as users and roles can be represented in any number of ways. Shiro tries to maintain a non-intrusive development philosophy whenever possible - it does not require you to implement or extend any User, Group or Role interfaces or classes.
Instead, Shiro allows applications to implement this interface to access environment-specific datasources and data model objects. The implementation can then be plugged in to the application's Shiro configuration. This modular technique abstracts away any environment/modeling details and allows Shiro to be deployed in practically any application environment.
Most users will not implement the Realm interface directly, but will extend one of the subclasses,
AuthorizingRealm, greatly reducing the effort requird
to implement a Realm from scratch.
|Modifier and Type||Method and Description|
Returns an account's authentication-specific information for the specified token, or null if no account could be found based on the token.
Returns the (application-unique) name assigned to this
Returns true if this realm wishes to authenticate the Subject represented by the given
Realm. All realms configured for a single application must have a unique name.
boolean supports(AuthenticationToken token)
AuthenticationTokeninstance, false otherwise.
If this method returns false, it will not be called to authenticate the Subject represented by
the token - more specifically, a false return value means this Realm instance's
getAuthenticationInfo(org.apache.shiro.authc.AuthenticationToken) method will not be invoked for that token.
token- the AuthenticationToken submitted for the authentication attempt
This method effectively represents a login attempt for the corresponding user with the underlying EIS datasource. Most implementations merely just need to lookup and return the account data only (as the method name implies) and let Shiro do the rest, but implementations may of course perform eis specific login operations if so desired.
token- the application-specific representation of an account principal and credentials.
AuthenticationException- if there is an error obtaining or constructing an AuthenticationInfo object based on the specified token or implementation-specific login behavior fails.
Copyright © 2004–2019 The Apache Software Foundation. All rights reserved.