


Explication détaillée des méthodes d'injection inconnues dans Java Spring
Avant-propos
L'utilisation du fichier XML pour la configuration dans le fichier de configuration Spring permet en fait à Spring d'exécuter le code correspondant, par exemple :
L'utilisation de l'élément
permet en fait à Spring d'exécuter le constructeur sans paramètre ou paramétré. L'utilisation de l'élément
Mais les programmes Java peuvent aussi avoir d'autres types d'instructions : appeler des méthodes getter, appeler des méthodes ordinaires, accéder à des champs de classes ou d'objets, etc., et Spring fournit également cette instruction. syntaxe de configuration correspondante :
Appelez la méthode getter : utilisez PropertyPathFactoryBean
-
Appelez la valeur Filed de la classe ou de l'objet : utilisez FiledRetrievingFactoryBean
Appelez des méthodes ordinaires : utilisez MethodInvokingFactoryBean
pour injecter la Propertyvaleur
PropertyPathFactoryBean d'un autre Bean est utilisée. valeur d'attribut du Bean cible (en fait la valeur renvoyée en appelant la méthode getter). La valeur obtenue peut être injectée dans d'autres Beans, ou un nouveau Bean peut être défini directement. Regardez le fichier de configuration suivant :
<bean id="person" class="com.abc.Person"> <property name="age" value="30" /> <property name="son"> <!-- 使用嵌套Bean定义属性值 --> <bean class="com.abc.service.Son"> <property name="age" value="11" /> </bean> </property> </bean> <bean id="son2" class="com.abc.service.Son"> <!-- age属性不是直接注入,而是将person中的son的age属性赋值给son2的age属性 --> <property name="age"> <!-- 注意这里使用的是PropertyPathFactoryBean --> <bean id="person.son.age" class="org.springframework.beans.factory.config.PropertyPathFactoryBean" /> </property> </bean>
Les attributs de la classe Person et de la classe Son sont visibles à partir du fichier de configuration, qui ne sont plus donnés. Le programme principal est le suivant :
public class Test { public static void main(String args[]) { ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml"); System.out.println("age=" + ac.getBean("son2", Son.class).getAge()); } }
Résultat de sortie :
age=11
La valeur de l'attribut de l'instance du Bean. Non seulement vous pouvez injecter un autre Bean, mais vous pouvez également le définir directement. la valeur d'attribut de l'instance du Bean en tant qu'instance, cela se fait également via PropertyPathFactoryBean. Ajoutez cette section au fichier de configuration ci-dessus :
<bean id="son1" class="org.springframework.beans.factory.config.PropertyPathFactoryBean"> <!-- 确定目标Bean,表明son1来自哪个Bean的组件 --> <property name="targetBeanName" value="person" /> <!-- 确定属性,表明son1来自目标Bean的哪个属性 --> <property name="propertyPath" value="son" /> </bean>
Exécutez la classe Test ci-dessus, remplacez son2 par son1, et le résultat sera le même.
Injecter les valeurs Field d'autres Beans
Grâce à la classe FieldRetrievingFactoryBean, vous pouvez injecter les valeurs Field d'autres Beans dans d'autres Beans, ou définir directement de nouveaux Beans. Voici un fragment de configuration :
<bean id="son" class="com.abc.service.Son"> <property name="age"> <bean id="java.sql.connection.TRANSACTION_SERIALIZABLE" class="org.springframework.beans.factory.config.FieldRetrievingFactoryBean" /> </property> </bean>
Le programme de test principal est similaire à celui défini ci-dessus et n'est plus fourni ici. Les résultats d'exécution sont les suivants :
age=8
Dans cette configuration, l'objet fils La valeur de age est égale à la valeur de java.sql.Connection.TRANSACTION_SERIALIZABLE. Dans la définition ci-dessus, lors de la définition du bean factory FieldRetrievingFactoryBean, l'identifiant spécifié n'est pas l'identifiant unique de l'instance du Bean, mais l' expression du Field spécifié (la valeur à retirer).
Remarque : le champ peut être soit statique, soit amorphe. L'expression Field spécifiée dans l'extrait de configuration ci-dessus est une valeur Field statique et est donc accessible directement via le nom de la classe. Si la valeur Field n'est pas statique, elle doit être accessible via un Bean qui existe déjà dans le conteneur - c'est-à-dire que la première phrase de l'expression Field doit être un Bean qui existe déjà dans le conteneur.
Les valeurs de champ peuvent également être définies comme des instances de Bean. Par exemple, ajoutez le paragraphe suivant au fichier de configuration :
<bean id="age" class="org.springframework.beans.factory.config.FieldRetrievingFactoryBean"> <!-- targetClass指定Field所在的目标类 --> <property name="targetClass" value="java.sql.Connection" /> <!-- targetField指定Field名 --> <property name="targetField" value="TRANSACTION_SERIALIZABLE" /> </bean>
Ajoutez la sortie suivante au programme principal :
System.out.println("age=" + ac.getBean("age"));
Le résultat de l'exécution est le même que ci-dessus.
Lorsque vous utilisez FieldRetrievingFactoryBean pour obtenir la valeur Field, vous devez spécifier les deux attributs suivants :
targetClass ou targetObject : utilisé pour spécifier le emplacement de la valeur du champ respectivement La cible fatiguée ou l'objet cible. Si le Field à obtenir est statique, utilisez targetClass pour spécifier la cible ; si le Field est non statique, utilisez targetObject pour spécifier l'objet cible
targetField : Spécifiez la classe cible ou Champ de l'objet cible Nom
Si Field est un champ statique, il existe une manière plus concise d'écrire :
<bean id="age" class="org.springframework.beans.factory.config.FieldRetrievingFactoryBean"> <!-- value指定哪个类的哪个静态域值 --> <property name="staticField" value="java.sql.Connection.TRANSACTION_SERIALIZABLE" /> </bean>
Injecter la valeur de retour d'une autre méthode Bean
Le bean usine Pass MethodInvokingFactoryBean peut injecter la valeur de retour de la méthode cible comme valeur de propriété du bean. Ce Bean d'usine est utilisé pour obtenir la valeur de retour de la méthode spécifiée, qui peut être soit une méthode statique, soit une méthode d'instance ; cette valeur peut être injectée dans l'attribut spécifié de l'instance du Bean spécifiée, ou elle peut être directement définie comme un Instance de haricot. Regardez l'exemple :
<bean id="valueGenerator" class="com.abc.util.ValueGenerator" /> <bean id="son1" class="com.abc.service.Son"> <property name="age"> <!-- 获取方法返回值:调用valueGenerator的getValue方法 --> <bean class="org.springframework.beans.factory.config.MethodInvokingFactoryBean"> <property name="targetObject" ref="valueGenerator" /> <property name="targetMethod" value="getValue" /> </bean> </property> </bean>
Ce qui suit est le ValueGenerator :
public class ValueGenerator { public int getValue() { return 2; } public static int getStaticValue () { return 3;} }
Le programme de test imprime toujours la valeur de l'âge dans son1, le code est omis, le résultat est le suivant suit :
age=2
Si vous souhaitez appeler une méthode statique, modifiez la configuration comme suit :
<bean id="son1" class="com.abc.service.Son"> <property name="age"> <!-- 获取方法返回值:调用valueGenerator的getStaticValue方法 --> <bean class="org.springframework.beans.factory.config.MethodInvokingFactoryBean"> <property name="targetClass" value="com.abc.util.ValueGenerator" /> <property name="targetMethod" value="getStaticValue" /> </bean> </property> </bean>
Le résultat du test est :
age=3
Depuis Java prend en charge la surcharge, seule la spécification du nom de la méthode ne suffit pas pour déterminer quelle méthode appeler. La configuration ci-dessus peut l'appeler avec succès car les deux méthodes de ValueGenerator n'ont aucun paramètre. S’il y a des paramètres dans la méthode, comment les configurer ? Ajoutez le contenu suivant au fichier de configuration :
<bean id="sysProps" class="org.springframework.beans.factory.config.MethodInvokingFactoryBean"> <property name="targetClass" value="java.lang.System" /> <property name="targetMethod" value="getProperties" /> <bean> <bean id="javaVersion" class="org.springframework.beans.factory.config.MethodInvokingFactoryBean"> <!-- 指向上面的sysProps Bean --> <property name="targetObject" value="sysProps" /> <property name="targetMethod" value="getProperty" /> <!-- 这里配置参数 --> <property name="arguments"> <!-- 使用list元素列出调用方法的多个参数 --> <list> <value>java.version</value> </list> </property> <bean>
L'exemple ci-dessus équivaut à appeler la méthode getProperty de java.lang.System avec "java.version" comme paramètre. La valeur de retour créera un. nouvel objet nommé javaVersion Beans. Cela équivaut à :
javaVersion = java.lang.System.getProperty("java.version");
Comme Field dans l'article précédent, si la méthode à appeler est une méthode statique, il existe une méthode plus concise :
<bean id="myBean" class="org.springframework.beans.factory.config.MethodInvokingFactoryBean"> <!-- 使用staticMethod属性,直接指定目标类的目标方法 --> <property name="staticMethod" value="com.abc.util.ValueGenerator.getStaticValue" /> </bean>
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!

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

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Sujets chauds

Guide du nombre parfait en Java. Nous discutons ici de la définition, comment vérifier le nombre parfait en Java ?, des exemples d'implémentation de code.

Guide de Weka en Java. Nous discutons ici de l'introduction, de la façon d'utiliser Weka Java, du type de plate-forme et des avantages avec des exemples.

Guide du nombre de Smith en Java. Nous discutons ici de la définition, comment vérifier le numéro Smith en Java ? exemple avec implémentation de code.

Dans cet article, nous avons conservé les questions d'entretien Java Spring les plus posées avec leurs réponses détaillées. Pour que vous puissiez réussir l'interview.

Java 8 présente l'API Stream, fournissant un moyen puissant et expressif de traiter les collections de données. Cependant, une question courante lors de l'utilisation du flux est: comment se casser ou revenir d'une opération FOREAK? Les boucles traditionnelles permettent une interruption ou un retour précoce, mais la méthode Foreach de Stream ne prend pas directement en charge cette méthode. Cet article expliquera les raisons et explorera des méthodes alternatives pour la mise en œuvre de terminaison prématurée dans les systèmes de traitement de flux. Lire plus approfondie: Améliorations de l'API Java Stream Comprendre le flux Forach La méthode foreach est une opération terminale qui effectue une opération sur chaque élément du flux. Son intention de conception est

Guide de TimeStamp to Date en Java. Ici, nous discutons également de l'introduction et de la façon de convertir l'horodatage en date en Java avec des exemples.

Les capsules sont des figures géométriques tridimensionnelles, composées d'un cylindre et d'un hémisphère aux deux extrémités. Le volume de la capsule peut être calculé en ajoutant le volume du cylindre et le volume de l'hémisphère aux deux extrémités. Ce tutoriel discutera de la façon de calculer le volume d'une capsule donnée en Java en utilisant différentes méthodes. Formule de volume de capsule La formule du volume de la capsule est la suivante: Volume de capsule = volume cylindrique volume de deux hémisphères volume dans, R: Le rayon de l'hémisphère. H: La hauteur du cylindre (à l'exclusion de l'hémisphère). Exemple 1 entrer Rayon = 5 unités Hauteur = 10 unités Sortir Volume = 1570,8 unités cubes expliquer Calculer le volume à l'aide de la formule: Volume = π × r2 × h (4

PHP et Python ont chacun leurs propres avantages, et le choix doit être basé sur les exigences du projet. 1.Php convient au développement Web, avec une syntaxe simple et une efficacité d'exécution élevée. 2. Python convient à la science des données et à l'apprentissage automatique, avec une syntaxe concise et des bibliothèques riches.
