Ejb est désigné sous le nom de Enterprise Java Bean Component, également appelé composants logiciels c?té serveur?; il sera principalement utilisé comme logique métier des applications. Les conteneurs Web utilisés pour les environnements d'exécution incluent les composants logiciels, la sécurité informatique, la gestion du cycle de vie des servlets, le traitement des transactions et les services Web. EJb est le style d'architecture écrit dans les langages de programmation Java exécutés c?té serveur du réseau informatique. a suivi le modèle client-serveur dans les applications. De plus, ejb est la technologie du bean Java permettant de distribuer les composants Web c?té client. Il possède la fonctionnalité appelée composants réutilisables dans plusieurs applications Web.
Commencez votre cours de développement de logiciels libres
Développement Web, langages de programmation, tests de logiciels et autres
Syntaxe?:
La syntaxe de base du modèle EJB dans la programmation Java comme suit.
import javax.ejb.*; import java packages; class classname { Main? method() { -----Some programming logics---- } }
Les codes ci-dessus sont des étapes de base pour développer l'application à l'aide de packages ejb.
Comment utiliser les EJB dans Java Works??
- Dans EJB, la classe du bean Java utilisera plus d'une annotation pour les spécifications ejb, ce qui sera utile pour satisfaire les exigences des utilisateurs en fonction de l'objectif commercial. EJB a un ensemble de versions différent et a suivi des fonctionnalités telles que JNDI. (interface de répertoire de noms Java). L'une des ressources des serveurs jndi est le service d'annuaire utilisé pour localiser ou allouer la ressource, comme les services ejb, source de données et file d'attente JMS. Les serveurs ont un nom de schéma par défaut pour les ressources jndi, mais il doit être remplacé si nous modifions le nom de la partie configuration.
- EJB fonctionnera sur les beans Java?; il a deux types différents 1. Beans de session et 2. Beans pilotés par message Beans de session. Les beans session seront utilisés pour les interactions client-serveur?; il encapsule la logique métier de l'application via un programme par lequel l'invocation du client sera effectuée soit par une machine locale, soit par un bean de machine distante qui sera utilisé par le client à l'aide de services Web. Les beans de session seront trois catégories différentes?: 1. Beans Stateless, 2.Stateful et 3.Singleton.Stateless. Lorsque le client utilise ce type de beans, il n'y a pas d'état permanent dans les conteneurs Web, ils sont donc très rapides en termes de performances thread-safe par rapport aux beans avec état. Ces beans sont partagés avec plusieurs clients en même temps.
- Les beans avec état peuvent stocker les états dans des conteneurs?; une fois que le client termine la session, ces états sont également détruits dans le serveur. Beans Singleton, il dispose d'une session d'instance unique pour tout le cycle de vie de cette application?; ces beans partageaient également les états avec plusieurs clients. Ces beans sont thread-safe, les développeurs les utiliseront donc plus facilement et leurs performances seront également plus rapides que celles des beans avec état.
- Message Driven Beans (MDB) est le type de bean qui est utilisé comme type de message asynchrone comme les écouteurs de message JMS, mais il recevra la réponse au message sous forme de messages JMS au lieu d'événements. Nous pouvons mapper les messages à l'aide des services jndi chaque fois que le message re?oit le conteneur appelle les beans MDB en utilisant la méthode onMessage() pour un processus ultérieur. L'ensemble du processus du MDB utilisant la méthode onMessage() sera une seule transaction. Si supposons que le processus de message soit une restauration, le message du destinataire est à nouveau délivré.
Exemples d'implémentation d'EJB en Java
Voici les exemples mentionnés?:
Exemple n°1
Interface?:
package JPAEJB; import java.util.List; import javax.ejb.Remote; @Remote public interface CustomerInterface { void addBooks(String name); List getBooks(); }
Mise en ?uvre?:
import java.util.ArrayList; import java.util.List; import javax.ejb.Stateless; import JPAEJB.CustomerInterface; @Stateless public class CustomerClass implements CustomerInterface { List<String>books; public CustomerClass() { books = new ArrayList<String>(); } public void addBooks(String name) { books.add(name); } public List<String> getBooks() { return books; } }
Interface client?:
import JPAEJB.CustomerInterface; import java.io.BufferedReader; import java.io.FileInputStream; import java.io.IOException; import java.io.InputStreamReader; import java.util.List; import java.util.Properties; import javax.naming.InitialContext; import javax.naming.NamingException; public class CustomerInterfaceImplem { BufferedReader brConsoleReader = null; Properties p; InitialContext c; { p = new Properties(); try { p.load(new FileInputStream("jndi.properties")); } catch (IOException ex) { ex.printStackTrace(); } try { c = new InitialContext(p); } catch (NamingException ex) { ex.printStackTrace(); } brConsoleReader = new BufferedReader(new InputStreamReader(System.in)); } public static void main(String[] args) { CustomerInterfaceImplem cust = new CustomerInterfaceImplem(); cust.testStatelessEjb(); } private void show() { System.out.println("Welcome to my domain"); System.out.print("Options \n1. Add the Books\n2. Exit \nEnter your Choice: "); } private void StatelessEjb() { try { intc = 1; CustomerInterface cust = (CustomerInterface)ctx.lookup("CustomerInterface/remote"); while (c != 2) { String books; show(); String str = brConsoleReader.readLine(); c = Integer.parseInt(str); if (c == 1) { books = brConsoleReader.readLine(); cust.addBooks(books); }elseif (c == 2) { break; } } List<String>books1 = cust.getBooks(); System.out.println(books1.size()); for (inti = 0; i<books1.size(); ++i) { System.out.println((i+1)+". " + books1.get(i)); } CustomerInterface cust1 = (CustomerInterface)ctx.lookup("cust/remote"); List<String>books2 = cust.getBooks(); System.out.println(books2.size()); for (inti = 0; i<books2.size(); ++i) { System.out.println((i+1)+". " + books2.get(i)); } } catch (Exception e) { System.out.println(e.getMessage()); e.printStackTrace(); } finally { try { if(brConsoleReader !=null) { brConsoleReader.close(); } } catch (IOException ex) { System.out.println(ex.getMessage()); } } } }
Exemple de sortie?:
Exemple n°2
EJB dans les services Web?:
package JPAEJB; import java.util.List; import Customers.CustomerInterfaceImplem; public class Ejbclients{ public static void main(String[] args) { for(CustomerInterface cust:getBooks()) { System.out.println(cust.getBooks()); } } private static List <CustomerInterface> getBooks() { CustomerInterfaceImplem s = new CustomerInterfaceImplem(); CustomerInterface c = s.getCustomerInterfacePort(); return c.getBooks(); } }
Exemple #3
Sécurité des EJB?:
import javax.ejb.* @Stateless @DeclareRoles({"customer""books"}) public class CustSecurity implements CustomerInterface { @RolesAllowed({"books"}) public void delete(CustomerInterface cust) { System.out.println("customer delete the books"); } @PermitAll public void showBooks(CustomerInterface cust) { System.out.println("customer viewed the books"); } @DenyAll public void deleteAll() { System.out.println("customer delete all the books in libraries"); } }
XML de sécurité?:
<?xml version="1.0"encoding="UTF-8"?> <!DOCTYPE sun-ejb-jar PUBLIC "-//Sun Microsystems, Inc.//DTD Application Server 9.0 EJB 3.0//EN""http://www.sun.com/software/appserver/dtds/sun-ejb-jar_3_0-0.dtd"> <ejb-jar> <security-role-mapping> <role-name>customer</role-name> <group-name>customer-groups</group-name> </security-role-mapping> <security-role-mapping> <role-name>Books</role-name> <group-name>Books-group</group-name> </security-role-mapping> <enterprise-beans/> </ejb-jar>
Explication?: Les trois exemples ci-dessus sont le même résultat. Nous avons utilisé différentes fonctionnalités de l'ejb. Premier exemple que nous utilisons, le client ajoutera et supprimera les livres en utilisant jndi (interface de répertoire de noms Java) deuxième exemple que nous utilisons. le service Web pour le client a effectué les opérations via le Web. Dans le dernier exemple, nous avons utilisé la sécurité supplémentaire.
Conclusion
Généralement, les EJB agissent comme une interface en dehors des applications de logique métier?; il offre davantage de fonctionnalités de compatibilité avec les navigateurs en termes de sécurité par rapport à d'autres frameworks de logique métier. Il gère également les transactions au niveau du système.
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

Undress AI Tool
Images de déshabillage gratuites

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.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à 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

Laravel prend en charge l'utilisation des requêtes SQL natives, mais la liaison des paramètres doit être préférée pour assurer la sécurité; 1. Utilisez DB :: SELECT () pour exécuter SELECT Queries avec la liaison des paramètres pour empêcher l'injection SQL; 2. Utilisez DB :: Update () pour effectuer des opérations de mise à jour et renvoyer le nombre de lignes affectées; 3. Utilisez db :: insert () pour insérer des données; 4. Utilisez DB :: Delete () pour supprimer les données; 5. Utilisez DB :: Instruction () pour exécuter des instructions SQL sans ensembles de résultats tels que Create, Alter, etc.; 6. Il est recommandé d'utiliser Whereraw, Selectraw et d'autres méthodes dans QueryBuilder pour combiner les expressions natives pour améliorer la sécurité

Utilisez JUnit5 et Mockito pour isoler efficacement les dépendances pour les tests unitaires. 1. Créez un objet simulé via @Mock, @InjectMocks Inject L'instance testée, @ExtendWith Activer la Mockito Extension; 2. Utiliser quand (). ThereraTurn () pour définir le comportement de simulation, vérifiez () pour vérifier le nombre d'appels et de paramètres de méthode; 3. Peut simuler les scénarios d'exception et vérifier la gestion des erreurs; 4. Recommander l'injection du constructeur, éviter une sur-simulation et maintenir l'atomicité des tests; 5. Utiliser Asssertall () pour fusionner les affirmations, et @nest organise les scénarios de test pour améliorer la maintenabilité et la fiabilité des tests.

Les génériques GO sont pris en charge depuis 1.18 et sont utilisés pour écrire du code générique pour le type de type. 1. La fonction générique imprimslice [tany] (s [] t) peut imprimer des tranches de tout type, telles que [] int ou [] cha?ne. 2. Grace au nombre de contraintes de type, les limites des types numériques tels que int et float, sum [tnumber] (tranche [] t) t La sommation s?re est réalisée. 3. La bo?te de type générique de structure [tany] struct {Valuet} peut encapsuler n'importe quelle valeur de type et être utilisée avec le constructeur newbox [tany] (VT) * Box [t]. 4. Ajouter SET (VT) et Get () T Méthodes T à boxer [t] sans

Table-Layout: Fixe obligera la largeur de la colonne de table à déterminer par la largeur de la cellule de la première ligne pour éviter le contenu affectant la disposition. 1. Définissez la table de table: fixe et spécifiez la largeur du tableau; 2. Définissez le rapport de largeur de colonne spécifique pour la première ligne th / td; 3. Utilisez White-Space: Nowrap, débordement: Hidden et Text-Overflow: EllipSis pour contr?ler le débordement du texte; 4. Applicable à la gestion des antécédents, aux rapports de données et à d'autres scénarios qui nécessitent une disposition stable et un rendu haute performance, qui peuvent effectivement empêcher la gigue de mise en page et améliorer l'efficacité du rendu.

JSON.loads () est utilisé pour analyser les cha?nes JSON dans les structures de données Python. 1. L'entrée doit être une cha?ne enveloppée de devis doubles et la valeur booléenne est vraie / fausse; 2. Prend en charge la conversion automatique de Null → Aucun, objet → Dict, Array → List, etc.; 3. Il est souvent utilisé pour traiter les cha?nes JSON renvoyées par l'API. Par exemple, Response_String peut être directement accessible après l'analyse par JSON.loads (). Lorsque vous l'utilisez, vous devez vous assurer que le format JSON est correct, sinon une exception sera lancée.

ChooseTheAPPROPROPPROPTROPEDEXTYPEBASTASEDUSECASE, telassinglefield, Compound, Multikey, Text, Geospatial, OrttLindexes.2.ApplyTheesrrulewHencreatingCompoundIndexesByOrderFieldsaseQuality, Sorture, Therange.3

Maven est un outil standard pour la gestion et la construction de projet Java. La réponse réside dans le fait qu'il utilise pom.xml pour normaliser la structure du projet, la gestion des dépendances, l'automatisation du cycle de vie de la construction et les extensions de plug-in; 1. Utilisez pom.xml pour définir GroupID, Arfactive, version et dépendances; 2. Commandes Master Core telles que MvnClean, compiler, tester, package, installer et déploier; 3. Utiliser la fonction de dépendance et les exclusions pour gérer les versions et les conflits de dépendance; 4. Organisez de grandes applications via la structure du projet multi-modules et sont gérées uniformément par le POM parent; 5

Dans Python, le transfert d'argument de la fonction est "passer la référence d'objet", c'est-à-dire 1. Pour les objets mutables (tels que les listes et les dictionnaires), les modifications in situ (telles que l'APPEND, la tranche d'affectation) dans la fonction affecteront directement l'objet d'origine; 2. Pour les objets immuables (tels que les entiers, les cha?nes), l'objet d'origine ne peut pas être modifié dans la fonction et la réaffectation ne créera qu'un nouvel objet; 3. Les paramètres transmettent une copie de la référence. Si la variable est rebelle dans la fonction (comme LST = [...]), la connexion avec l'objet d'origine ne sera pas affectée et la variable externe ne sera pas affectée. Par conséquent, la modification des objets mutables affecte les données d'origine, tandis que les objets immuables et la réaffectation ne le font pas, ce qui explique pourquoi la liste est visible à l'extérieur après modification dans la fonction, tandis que les changements entiers ne sont que localement.
