" classpath:shiro.ini")

(5) iniSecuritymanagerFactory est la classe d'implémentation pour créer securityManager en mode ini
(2)1 IniSecurityManagerFactory类:2 creatSecuritymanager(ini){3 SecurityManager securityManager = createSecurityManager(ini);4 return securityManager;5 }
1 private SecurityManager createSecurityManager(Ini ini) { 2 //null 3 Ini.Section mainSection = ini.getSection(MAIN_SECTION_NAME); 4 if (CollectionUtils.isEmpty(mainSection)) { 5 6 //try the default: null 7 mainSection = ini.getSection(Ini.DEFAULT_SECTION_NAME); 8 } 9 return createSecurityManager(ini, mainSection);10 }
(4) Définir l'association entre les objets via mainSession et l'objet objet par défaut
1 private SecurityManager createSecurityManager(Ini ini, Ini.Section mainSection) { 2 //{securityManager=DefaultSecurityManager,iniRealm=IniRealm} 3 Map defaults = createDefaults(ini, mainSection); 4 Map objects = buildInstances(mainSection, defaults); 5 6 SecurityManager securityManager = getSecurityManagerBean(); 7 boolean autoApplyRealms = isAutoApplyRealms(securityManager); 8 if (autoApplyRealms) { 9 //realms and realm factory might have been created - pull them out first so we can initialize the securityManager:10 Collection realms = getRealms(objects);11 //set them on the SecurityManager12 if (!CollectionUtils.isEmpty(realms)) {13 applyRealmsToSecurityManager(realms, securityManager);14 }15 }16 return securityManager;17 }
1 private Map buildInstances(Ini.Section section, Map defaults) { 2 this.builder = new ReflectionBuilder(defaults); 3 return this.builder.buildObjects(section); 4 } 5 //类ReflectionBuilder 6 //通过mainSection创建对象并关联 7 public Map buildObjects(Map kvPairs) { 8 ..... 9 LifecycleUtils.init(objects.values());10 }
1 //类IniRealm 2 private void processDefinitions(Ini ini) { 3 Ini.Section usersSection = ini.getSection(USERS_SECTION_NAME); 4 processUserDefinitions(usersSection); 5 } 6 //通过userSection解析user模块 7 protected void processUserDefinitions(Map userDefs) { 8 for (String username : userDefs.keySet()) { 9 ........10 account = new SimpleAccount(username, password, getName());11 add(account);12 ........13 }14 }15 protected void add(SimpleAccount account) {16 String username = getUsername(account);17 USERS_LOCK.writeLock().lock();18 try {19 this.users.put(username, account);20 }finally {21 USERS_LOCK.writeLock().unlock();22 }

À ce stade, l'association d'objets est créée et l'initialisation d'IniRealm est terminée ! Ensuite, regardez le diagramme de structure de DefaultSecurityManager :


afterRealmsSet(); est principalement utilisé pour définir les attributs de domaine de l'authentificateur et de l'autorisateur :
1 applyRealmsToSecurityManager(realms, securityManager){2 ((RealmSecurityManager) securityManager).setRealms(realms);3 }4 //在类RealmSecurityManager中5 public void setRealms(Collection realms) {6 this.realms = realms;7 afterRealmsSet();8 }
//3. Obtenez le sujet et créez le jeton d'authentification du nom d'utilisateur/mot de passe (c'est-à-dire l'identité de l'utilisateur). /credential)
1 //获取主题对象 2 public static Subject getSubject() {3 Subject subject = ThreadContext.getSubject();//第一次null4 if (subject == null) {5 subject = (new Subject.Builder()).buildSubject();6 ThreadContext.bind(subject);7 }8 return subject;9 }(2) Utiliser le contexte du thème pour créer un thème
1 public static class Builder{ 2 SubjectContext subjectContext; 3 SecurityManager securityManager; 4 public Builder(SecurityManager securityManager) { 5 if (securityManager == null) { 6 throw new NullPointerException("SecurityManager method argument cannot be null."); 7 } 8 this.securityManager = securityManager; 9 this.subjectContext = newSubjectContextInstance();//DefaultSubjectContext(初始化一个backMap集合)10 if (this.subjectContext == null) {11 throw new IllegalStateException("Subject instance returned from 'newSubjectContextInstance' " +12 "cannot be null.");13 }14 this.subjectContext.setSecurityManager(securityManager);15 }16 public Subject buildSubject() {17 return this.securityManager.createSubject(this.subjectContext);18 }19 }
1 public Subject createSubject(SubjectContext context) { 2 SecurityManager securityManager = context.resolveSecurityManager(); 3 Session session = context.resolveSession(); 4 boolean sessionCreationEnabled = context.isSessionCreationEnabled(); 5 PrincipalCollection principals = context.resolvePrincipals(); 6 boolean authenticated = context.resolveAuthenticated(); 7 String host = context.resolveHost(); 8 9 return new DelegatingSubject(principals, authenticated, host, session, sessionCreationEnabled, securityManager);10 }
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!

ByteCodeachievesPlatformIndependanceBeBeingExEcutedByaVirtualmachine (VM), permettant à la codétorunonanyplatformwiththeappo pourpropriév.forexample, javabytecocecanrunonanydevicewithajvm, permettre de "writeonce, runanywhere" fonctionnalité.

Java ne peut pas atteindre l'indépendance de la plate-forme à 100%, mais son indépendance de la plate-forme est implémentée via JVM et ByteCode pour s'assurer que le code s'exécute sur différentes plates-formes. Les implémentations spécifiques incluent: 1. Compilation dans ByteCode; 2. Interprétation et exécution de JVM; 3. Cohérence de la bibliothèque standard. Cependant, les différences de mise en œuvre de JVM, les différences de système d'exploitation et de matériel et la compatibilité des bibliothèques tierces peuvent affecter l'indépendance de sa plate-forme.

Java réalise l'indépendance de la plate-forme via "Écrire une fois, exécuter partout" et améliore la maintenabilité du code: 1. Réutilisation du code élevé et réduit le développement en double; 2. Coût de maintenance faible, une seule modification est requise; 3. L'efficacité de collaboration d'équipe élevée est élevée, pratique pour le partage des connaissances.

Les principaux défis confrontés à la création d'un JVM sur une nouvelle plate-forme comprennent la compatibilité matérielle, la compatibilité du système d'exploitation et l'optimisation des performances. 1. Compatibilité matérielle: il est nécessaire de s'assurer que le JVM peut utiliser correctement l'ensemble d'instructions de processeur de la nouvelle plate-forme, tel que RISC-V. 2. Compatibilité du système d'exploitation: le JVM doit appeler correctement l'API système de la nouvelle plate-forme, comme Linux. 3. Optimisation des performances: les tests de performances et le réglage sont nécessaires, et la stratégie de collecte des ordures est ajustée pour s'adapter aux caractéristiques de la mémoire de la nouvelle plate-forme.

Javafxefficativement adressée à la gestion de la consultation de la réalisation de temps à useraPlatform-agnosticscenegraphandcssyling.1)

JVM fonctionne en convertissant le code Java en code machine et en gérant les ressources. 1) Chargement de classe: Chargez le fichier .class en mémoire. 2) Zone de données d'exécution: gérer la zone de mémoire. 3) Moteur d'exécution: interpréter ou compiler les bytecode d'exécution. 4) Interface de la méthode locale: interagir avec le système d'exploitation via JNI.

JVM permet à Java de courir sur les plates-formes. 1) JVM charge, valide et exécute Bytecode. 2) Le travail de JVM comprend le chargement des classes, la vérification du bytecode, l'exécution d'interprétation et la gestion de la mémoire. 3) JVM prend en charge les fonctionnalités avancées telles que la charge de classe dynamique et la réflexion.

Les applications Java peuvent s'exécuter sur différents systèmes d'exploitation via les étapes suivantes: 1) Utiliser la classe de fichiers ou de chemins pour traiter les chemins de fichier; 2) Définir et obtenir des variables d'environnement via System.getenv (); 3) Utilisez Maven ou Gradle pour gérer les dépendances et tester. Les capacités multiplateforme de Java reposent sur la couche d'abstraction de JVM, mais nécessitent toujours une manipulation manuelle de certaines caractéristiques spécifiques au système d'exploitation.


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Navigateur d'examen sécurisé
Safe Exam Browser est un environnement de navigation sécurisé permettant de passer des examens en ligne en toute sécurité. Ce logiciel transforme n'importe quel ordinateur en poste de travail sécurisé. Il contrôle l'accès à n'importe quel utilitaire et empêche les étudiants d'utiliser des ressources non autorisées.

Version crackée d'EditPlus en chinois
Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code

SublimeText3 Linux nouvelle version
Dernière version de SublimeText3 Linux

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

PhpStorm version Mac
Le dernier (2018.2.1) outil de développement intégré PHP professionnel
