Understanding and Designing with EJB

Slides:



Advertisements
Similar presentations
J0 1 Marco Ronchetti - Basi di Dati Web e Distribuite – Laurea Specialistica in Informatica – Università di Trento.
Advertisements

12 Copyright © 2005, Oracle. All rights reserved. Implementing Business Tasks with Session EJBs.
11 Copyright © 2005, Oracle. All rights reserved. Creating the Business Tier: Enterprise JavaBeans.
Technische universität dortmund Service Computing Service Computing Prof. Dr. Ramin Yahyapour IT & Medien Centrum 12. November 2009.
EJB Entity Beans. Entity Beans Data versus logic Used to represent an instance rather than a collection of data (depending on underlying storage) Represents.
6/1/20151 Luca Simone Software Engineering 2 a.a. 2001/2002.
1 Softsmith Open Learning - EJB 21-Nov Enterprise Java Beans Introduction –Application ServerApplication Server –Java 2 Enterprise EditionJava.
Distributed System Using Java 2 Enterprise Edition (J2EE) B.Ramamurthy.
Copyright W. Howden1 Lecture 19: Intro to O/O Components.
CS 483 Enterprise and Web Application Programming
Emmanuel Cecchet et al.  Performance Scalability of J2EE application servers.  Test effect of: ◦ Application Implementation Methods ◦ Container Design.
Distributed System Using Java 2 Enterprise Edition (J2EE)
Chapter 10 EJB Concepts of EJB Three Components in Creating an EJB Starting/Stopping J2EE Server and Deployment Tool Installation and Configuration of.
EJB. Component Characteristics An enterprise Bean typically contains business logic that operates on the enterprise’s data. An enterprise Bean’s instances.
1 J2EE Components. 2 Application Servers relieve the programming burden for business distributed components. They provide support for system level services.
1 Session Bean Chuyên đề Lập trình Java & J2EE Chương 14 Biên soạn: Th.S Nguyễn văn Lành.
EJB.
Entity Beans BMP Celsina Bignoli
Middleware Technology (J2EE/EJB) Entity Bean. 2 Introduction to Entity Beans Persistence Concepts Entity beans are persistent objects that can be stored.
Lecture 8 Advanced Topics in Enterprise JavaBeans.
Advanced Java Session 7 New York University School of Continuing and Professional Studies.
Container-Managed Persistence (CMP) Entity Beans Lesson 3A / Slide 1 of 42J2EE Server Components Objectives In this lesson, you will learn to: Identify.
Enterprise JavaBeans Umer Farooq CS6704: Design Patterns & Component FrameworksFebruary 25, 2002.
1 Stateful Session Beans Stateless Session Beans Michael Brockway Sajjad Shami Northumbria University School of Computing, Engineering & Information Sciences.
Distributed Systems 1 Master of Information System Management Distributed Systems Persistence.
Enterprise Java Bean Matt. 2 J2EE 3 J2EE Overview.
The Triad of Beans I Oleh: Dini Addiati ( ) Fahrurrozi Rahman ( Y) Irfan Hilmy ( ) Salman Azis A ( ) Aziiz Surahman.
Enterprise JavaBeans. Lesson 1: Introduction to Server-Side Component Software.
Introduction to J2EE Architecture Portions by Kunal Mehta.
EJB Framework.  As we know, EJB is the center of the J2EE architecture that provides a sturdy framework for building enterprise applications. The major.
Message-Driven Beans and EJB Security Lesson 4B / Slide 1 of 37 J2EE Server Components Objectives In this lesson, you will learn about: Identify features.
Java Server Pages A JSP page is a text-based document that contains two types of text: static template data, which can be expressed in any text-based format,
J2EE Structure & Definitions Catie Welsh CSE 432
Session Beans -) stateless -) stateful. Session Beans A session bean represents a single client inside the J2EE server. To access an application that.
© jGuru.com Enterprise JavaBeans Fundamentals.
1 Java EE Programming Enterprise JavaBeans. 2 Topics J2EE Overview Enterprise JavaBeans Overview Enterprise Entity Beans Case Study How to build them.
Creating competitive advantage Copyright © 2003 Enterprise Java Beans Presenter: Wickramanayake HMKSK Version:0.1 Last Updated:
EJB Overview: Constraint Types and Enforcement in JBoss Elissa Newman Fluid Meeting 6/3/04.
Entity Beans & Persistence Chris Alexander CS 486 Spring 2001.
© FPT SOFTWARE – TRAINING MATERIAL – Internal use 04e-BM/NS/HDCV/FSOFT v2/3 JSP Application Models.
Introduction to EJB. What is an EJB ?  An enterprise java bean is a server-side component that encapsulates the business logic of an application. By.
Java Programming: Advanced Topics 1 Enterprise JavaBeans Chapter 14.
Enterprise Java Beans N.V.RAJASEKHAR REDDY. Definition of EJB EJBs are the components that are the set of classes and interfaces deployed within a container.
Copyright © 2002 ProsoftTraining. All rights reserved. Enterprise JavaBeans.
13 Copyright © 2004, Oracle. All rights reserved. Managing Persistent Data in the Business Tier Entity EJBs.
Enterprise JavaBeans. Lesson 1: Introduction to Server-Side Component Software.
Java Programming: Advanced Topics 1 Building Web Applications Chapter 13.
Advanced Java Session 7 New York University School of Continuing and Professional Studies.
EJB Enterprise Java Beans JAVA Enterprise Edition
EJB. Introduction Enterprise Java Beans is a specification for creating server- side scalable, transactional, multi-user secure enterprise-level applications.
14 Copyright © 2004, Oracle. All rights reserved. Achieving State Management in the Business Tier.
©NIIT Session Beans Lesson 1B/ Slide 1 of 37J2EE Server Components Objectives In this lesson, you will learn to: Describe the characteristics of session.
Entity Bean Chuyên đề Lập trình Java & J2EE Chương 15
EJB (Enterprise Java Beans)
Introduction to J2EE Architecture
Structure of Enterprise Java Beans
J2EE Application Development
Distributed System Using Java 2 Enterprise Edition (J2EE)
Understanding and Designing with EJB
Luca Simone Software Engineering 2 a.a. 2001/2002
Objectives In this lesson, you will learn to:
Enterprise Java Beans Bina Ramamurthy 1/13/2019 B.Ramamurthy.
Entity Beans B.Ramamurthy 2/17/2019 BR.
Knowledge Byte In this section, you will learn about:
Component-based Applications
Component Technology Bina Ramamurthy 2/25/2019 B.Ramamurthy.
Understanding and Designing with EJB
Enterprise Java Beans Bina Ramamurthy 4/5/2019 B.Ramamurthy.
Enterprise Java Beans.
Knowledge Byte In this section, you will learn about:
Presentation transcript:

Understanding and Designing with EJB B.Ramamurthy Based on j2eetutorial documentation. http://java.sun.com/j2ee/tutorial/1_3-fcs/index.html 1/11/2019

Review Request/Response Model Distributed Objects: stubs and skeleton providing location transparency Naming and Lookup: registry and binding Server-side technology: servlets (project1) Web applications: can be written entirely using Java Server Pages (static and dynamic content and data access can be provided); JSP is wrapper on servlet technology. Concept of initial context:The starting point for resolution of names for naming and directory operations. Data base access: using Java Data Base Connectivity 1/11/2019

When to use EJB For large scale applications: where resources and data are distributed. When the application is run on servers at many locations. Where scalability is critical. Where transactions are required to ensure data integrity When a variety of clients need to handled. 1/11/2019

Types of Enterprise Bean: Session Session bean: represents a single client inside the J2EE server. Session represents an interactive session. When a client terminates the session bean terminates/is no longer associated with the client. Stateful session bean: maintains a conversational state for the duration of a session. Ex: items reviewed in a session at some sites Stateless session bean: does not maintain a conversational state. Ex: computing a formula for a given value 1/11/2019

Types of Enterprise Bean: Entity An entity bean represents a business object in a persistent storage mechanism. Ex: customers, orders, and products. Each entity bean typically has an underlying table in a relational database (business data), and each instance of the bean corresponds to a row in that table. Transactional and recoverable on a server crash. 1/11/2019

Types of Enterprise Bean: Message-Driven A message driven bean is an enterprise bean that allows J2EE applications to process messages asynchronously. It acts as a JMS listener, which is similar to an event listener except that it receives messages instead of events. The messages can be sent by any J2EE component: an application client, another enterprise bean, or a web component, or a non-J2EE system using JMS. Retain no data or conversational state. 1/11/2019

Contents of an Enterprise Bean Interfaces: The remote and home interface for remote access. Local and local home accesses for local access. Enterprise bean class: Implements the methods defined in the above interfaces. Deployment descriptor: An XML file that specifies information about the bean such as its type, transaction attributes, etc. Helper classes: non-bean classes needed by the enterprise bean class such as utility and exception classes. 1/11/2019

Naming Conventions Item Syntax Example Enterprise Bean Name (DD) <name>EJB AccountEJB EJB JAR display name (DD) AccountJAR Enterprise bean class <name>Bean AccountBean Home interface <name>Home AccountHome Remote interface <name> Account Local home interface Local<name>Home LocalAccountHome Local interface Local<name> LocalAccount Abstract Schema (DD) 1/11/2019

The life cycles of enterprise beans An enterprise bean goes through various stages during its lifetime. Each type has different life cycle. 1/11/2019

Session bean Does not Exist Ready create remove Does not Exist create passivate Ready Passive activate 1/11/2019

Entity and Message-driven Bean Lifecycle Does not Exist Does not Exist Ready create remove setContext unsetContext Pooled onMessage ejbPassivate ejbActivate create remove Ready 1/11/2019

Designing an application Start with Remote interface methods. For completion write the Home interface. Implement these methods in a (session) bean class. Update build.xml “ant” file and compile using ant <target> Use the deploy tool to deploy the application on your j2EE server and set up the configuration. Write a client (preferably a web client) to test your enterprise application. Lets go through converter application. Your assignment is to make it a more meaningful and useful converter. 1/11/2019

MidTerm Review Web application design: n-tier design from word problem. Represent using block diagram, use case and class diagram. Stepwise explanation; project 1 J2EE Application model: application model Enterprise beans: Session, entity and message-driven beans: characteristics and life cycle Enterprise integration: Ch.1-5 of your text 1/11/2019

Session Bean Home interface Remote interface Bean class Deployment descriptor Can be stateless (ex: converter) or stateful (ex: cart) Stateless: container can maintain a pool of instances of session bean and reuse them for many client requests. Stateful: instance pooling can be done but what to with the state? Activate and passivate the instances by storing and restoring them from secondary memory. 1/11/2019

Cart Stateful Session Bean One or more ejbCreate methods (void methods) providing flexibility of instantiating the bean with various starting states. Business methods: addBook, removeBook, getContents Data (state): string customerId, string CustomerName, Vector contents 1/11/2019

Client calls + bean and container response Client gets naming context. Client looks up the remote object interface. Narrows it to IIOP object and then casts it to CartHome to set “home” variable. Creates bean: Cart shoppingCart = home.create(“Bina”, “1234”); EJB container instantiates the enterprise bean. EJB container then calls the appropriate ejbCreate method in CartBean. Observe ejbCreate verifies the ID using an IDVerifier object. After successful creation and initialization of the bean the client can invoke business methods as follows: 1/11/2019

Cart Business Method calls shoppingCart.addBook(“J2EE in 21 days”); shoppingCart.removeBook(“Java 2: inside information”); booklist = shoppingCart.getContents(); Now the client can print out the vector booklist. 1/11/2019

Other Features Stored in the enterprise bean’s deployment descriptor, an environment entry is a name-value pair that allows you to customize the bean’s business logic without changing its source code. A enterprise bean that calculates discounts, may have an environment variable named discount percent. Before deploying the bean’s application one can use the deploy tool to assign the proper value for discount percent. Look at CheckerBean example. 1/11/2019

Entity Bean Data is at the heart of most business applications. In J2EE applications, entity beans represent the business objects that need persistence (need to be stored in a database.) You have choice of bean-managed persistence (BMP) and container-managed persistence (CMP). In BMP you write the code for database access calls. This may be additional responsibility but it gives control to the bean developer. 1/11/2019

Entity Bean with BMP: Example: SavingsAccount The state of the SavingsAccountEJB is stored in the savingsAccount table of a relational database. savingsAccount table could be created by a SQL statement as shown below: CREATE TABLE savingsAccount (id VARCHAR(3) CONSTRAINT pk_savingsaccount PRIMARY KEY, firstname VARCHAR(24), lastname VARCHAR(24), balance NUMERIC(10,2)); 1/11/2019

SavingsAccountEJB This contains: Remote interface (SavingsAccount) Home interface (SavingsAccountHome) Entity bean class (SavingsAccountBean) Utility class: InsufficientBalanceException And a client to test it: SavingsAccountClient 1/11/2019

Entity Bean class Implements EntityBean interface Zero or more ejbCreate and ejbPostCreate methods Finder methods Business methods Home methods 1/11/2019

Entity Bean Methods ejbCreate inserts the entity state into the database; initializes the instance variables and returns the primary key. ejbRemove will delete the record corresponding to the bean from the database. ejbLoad and ejbStore methods synchronize instance variables of an entity bean with the corresponding values stored in a database. ejbLoad refreshes the instance variables from the db and ejbStore writes variables to the database. Container does this not the client. ejbFinder allows client to locate entity beans. Find the collection of records with “Smith” as author. Business methods and home methods. 1/11/2019

SQL statements in SavingsAccountBean Method SQL Statement ejbCreate INSERT ejbFindPrimaryKey SELECT ejbFindByLastName ejbFindInRange ejbLoad ejbRemove DELETE ejbStore UPDATE 1/11/2019