Maison >Java >javaDidacticiel >Un guide pour implémenter l'authentification unique avec Java JAAS
Comment utiliser le guide d'enregistrement des points de production réels Java JAAS. Dans le texte principal, je suis un guide général et je suis JAAS, comment organiser et utiliser JAAS, et depuis lors, j'utilise la technique pour l'utilisation réelle de divers éléments. Si vous êtes débutant, vous ne pourrez pas lire le texte.
L'authentification unique (SSO) est un mécanisme qui vous permet d'utiliser le même nom d'utilisateur et le même mot de passe pour vous connecter à plusieurs applications. JAAS vous permet d'utiliser diverses méthodes pour configurer SSO. La méthode la plus courante consiste à utiliser Kerberos. Kerberos est un système d'authentification distribué permettant d'authentifier les utilisateurs sur un réseau. Kerberos permet aux utilisateurs de se connecter une seule fois et d'accéder à toutes les autres applications du même domaine Kerberos.
Le processus d'authentification et d'autorisation à l'aide de JAAS comprend les étapes suivantes :
L'exemple de code ci-dessous est un code permettant d'authentifier un utilisateur à l'aide de JAAS.
import javax.security.auth.Subject; import javax.security.auth.login.LoginContext; public class JAASAuthentication { public static void main(String[] args) { // ログインコンテキストを作成します。 LoginContext loginContext = new LoginContext("LoginModule"); // ログインします。 loginContext.login(); // サブジェクトを取得します。 Subject subject = loginContext.getSubject(); // サブジェクトに含まれるプリンシパルをすべて表示します。 for (Principal principal : subject.getPrincipals()) { System.out.println(principal.getName()); } // ログアウトします。 loginContext.loGout(); } }
L'exemple de code suivant utilise JAAS pour récupérer les informations d'autorisation utilisateur.
import javax.security.auth.Subject; import javax.security.auth.login.LoginContext; import javax.security.auth.authorization.Policy; import javax.security.auth.authorization.PolicyProvider; public class JAASAuthorization { public static void main(String[] args) { // ログインコンテキストを作成します。 LoginContext loginContext = new LoginContext("LoginModule"); // ログインします。 loginContext.login(); // サブジェクトを取得します。 Subject subject = loginContext.getSubject(); // ポリシープロバイダーを取得します。 PolicyProvider policyProvider = PolicyProvider.getPolicyProvider(); // ポリシーを取得します。 Policy policy = policyProvider.getPolicy(subject, null); // ポリシーに含まれるパーミッションをすべて表示します。 for (Permission permission : policy.getPermissions()) { System.out.println(permission.getName()); } // ログアウトします。 loginContext.logout(); } }
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!