SlideShare a Scribd company logo
1 of 32
MVC Design Pattern
June 2015
Design Patterns
• A pattern is a proven solution to a problem in a context.
• Christopher Alexander says each pattern is a three-part rule which
expresses a relation between a certain context, a problem, and a
solution.
• Design patterns represent a solutions to problems that arise when
developing software within a particular context.
i.e Patterns = problems.solution pairs in a context
Background
• Started in 1987 by Ward Cunningham and Ken Beck who were
working with Smalltalk and designing GUIs.
• Popularized by Gamma, Helm, Johnson and Vlissides (The
gang of four, Go4)
• The three of Go4 were working on frameworks (E++,Unidraw,
HotDraw)
• Design pattern use a consistent documentation approach
• Design pattern are granular and applied at different levels
such as frameworks, subsystems and sub-subsystems
• Design patterns are often organized as creational, structural or
behavioral
Categorizing Pattern
Patterns, then, represent expert solutions to
recurring problems in a context and thus have
been captured at many levels of abstraction
and in numerous domains. Numerous
categories are:
• Design
• Architectural
• Analysis
• Creational
• Structural
• Behavioral
Sun’s J2EE Framework
• Components Containers and Connectors:
Hiding Complexity, Enhancing Portability
• Components are the key focus of application
developers
• Containers intercede between clients and
components, providing services
transparently to both, including transaction
support and resource pooling.
• Connectors sit beneath the J2EE platform,
defining a portable service API to plug into
existing enterprise vendor offerings.
J2EE
• Components
▫ Enterprise Java Beans (EJB)
▫ Java Server Pages (JSP)
▫ Servlets
• Containers (service providers)
▫ Web container
▫ Bean Container
• Connectors (connection service providers)
J2EE and Design Patterns
• J2EE: AN OPERATING SYSTEM FOR THE WEB Enterprise
web applications, which live on networks and are
accessible through browsers, are redefining Enterprise
Web Software. This is the next wave of computing.
• The J2EE architecture is built to enable
component developers to use a Model View
Controller (MVC) Design Pattern.
Details of MVC Design Pattern
• Name (essence of the pattern)
▫ Model View Controller MVC
• Context (where does this problem occur)
▫ MVC is an architectural pattern that is used when
developing interactive application such as a shopping
cart on the Internet.
• Problem (definition of the reoccurring difficulty)
▫ User interfaces change often, especially on the internet
where look-and-feel is a competitive issue. Also, the
same information is presented in different ways. The
core business logic and data is stable.
MVC continued
• Solution (how do you solve the problem)
▫ Use the software engineering principle of “separation of concerns” to
divide the application into three areas:
 Model encapsulates the core data and functionality
 View encapsulates the presentation of the data there
can be many views of the common data
 Controller accepts input from the user and makes
request from the model for the data to produce a new
view.
MVC Structure for J2EE
MVC Architecture
• The Model represents the structure of the data in the application,
as well as application-specific operations on those data.
• A View (of which there may be many) presents data in some form
to a user, in the context of some application function.
• A Controller translates user actions (mouse motions, keystrokes,
words spoken, etc.) and user input into application function calls on
the model, and selects the appropriate View based on user
preferences and Model state.
Example of MVC Design Pattern
• Let’s investigate this statement by looking at a
small application that demonstrates MVC on
J2EE
Java Pet Store- MVC Design Pattern
 The Java Pet Store is a reference application that
demonstrates J2EE technologies.
 It demonstrates interaction between Java Server Pages
(JSP's), custom Tag Libraries, JavaBeans, and Enterprise
Java Beans.
 It demonstrates a real-world approach to application
development, where the presentation of data is separated
from the process of obtaining data from objects which
interact with the enterprise or database tier.
 The Pet Store application implements MVC (Model-View-
Controller) design, and demonstrates one way to design an
application that should scale well.
Multi Tier Architecture
 The Java Pet Store design is divided into multiple tiers:
A. Client tier
B. Web tier
C. Enterprise JavaBeans tier
D. Enterprise Information System tier.
 These tiers are not necessarily arranged hierarchically.
 Each tier may communicate directly with other tiers, or indirectly by
way of intermediate tiers.
J2EE Architecture Tiers
A. Details of Client Tier
• The Client tier is responsible for presenting data to the user,
interacting with the user, and communicating with the other tiers of
the application.
• The Client tier is the only part the application the user ever sees.
• The Client tier communicates with other tiers by way of well-defined
interfaces.
• A separate Client tier in the design provides flexibility and
extensibility.
A. Details of Client Tier
• In The Java Pet Store Client tier consists mainly of a browser displaying
Web pages generated from server-side JSP pages in the Web tier.
• Future new clients can be written using technologies or languages that do
not yet even exist, since they must conform only to the interface for
communicating with other tiers
B. Web Tier
• The Web tier is responsible for performing all Web-related
processing, such as serving HTML, instantiating Web page
templates, and formatting JSP pages for display by browsers.
• The Web tier in the Java Pet Store does all of these, and takes on the
Controller functions for the Web application, caching model data
interpreting user inputs, selecting appropriate Views based on
application flow, and managing database connections.
C. EJB Tier
• Enterprise JavaBeans are software business components which
extend servers to perform application-specific functionality.
• The interface between these components and their containers is
defined in the EJBs specification.
• Essentially, the EJBs tier provides a component model for access to
distributed system services and persistent data.
C. EJB Tier
• Both stand-alone clients and Web applications in the Web tier can
use EJB components hosted by the EJBs tier.
• It also simplifies application component development, because
details about system issues such as persistence, reentrancy,
transactions, remote access, and so on, are all handled by the
container.
D.Enterprise Information System
(EIS) Tier
• The EIS tier is the enterprise information infrastructure.
• Members of the EIS tier typically include enterprise information planning
(ERP) systems, transaction processing monitors, relational database
management systems, and legacy enterprise applications.
• Access to the EIS tier is usually transactional, to ensure that data are
consistent across application boundaries.
• The EIS tier also enforces security and offers scalability.
MVC supports Modular Design
 Has set of modules, each tightly coupled internally, and
loosely coupled between modules.
 Each module has an interface that defines the module's
functional requirements and provides a place where third-
party products may be integrated.
 The Java Pet Store demo modules are:
 User Account
 Product Catalog
 Order Processing
 Messaging
 Inventory
 Control
 The Modular design supports the design goal of reusable
software.
Java Pet store- MVC
• Views
▫ JSP pages, composed with templates and
displayed in an HTML browser
• Controller
▫ maps user input from the browser to request
events, and forwards those events to the Shopping
Client Controller in the EJB tier.
• Model
▫ EJB Tier
MVC Details in Java Pet store
• Model represents the structure of the data in the application, as well as
application-specific operations on data
- CartModel, InventoryModel, CustomerEJB, and others
• Views are Java server pages (JSPs)
▫ rendered from the web container to the browser, stand-alone
applications that provide View functionality, and interfaces to
spreadsheet programs, such as the StarOfficeTM suite.
• Controller is server side java program (Servlet)
▫ MainServlet.java, which dispatches browser requests to other
controller objects, such as ShoppingClientController.java,
AdminClientController.java, and their related support classes.
Views:Java Server Page (JSP)
• http://java.sun.com/products/jsp/
• Technology for developing dynamic web sites
that replaces CGI
• Thought of as a server-side scripting tool
• Contains HTML and Java code (scripts)
• Is compiled into a servlet and executes on the
server.
Controller Servlet
• A java class that runs on the server
• Extends http Servlet
• Runs in a container class
(servlet/JSP engine)
• Application servers (Jrun, WebLogic) have the
containers
• This has the logic for the application
EJBs
• Enterprise Java Beans Connect Servlets to the
back end database
• Examples of EJBs in Java Pet store are:
AccountHandler, ModelUpdateManager,
ShoppingClientControllerHome, CartHandler,
ShoppingClientControllerEJB, SigninHandler,
OrderHandler
Advantages of MVC
• Separating Model from View (that is, separating
data representation from presentation)
- easy to add multiple data presentations for
the same data,
-facilitates adding new types of data
presentation as technology develops.
-Model and View components can vary
independently enhancing maintainability,
extensibility, and testability.
Advantages of MVC design Pattern
• Separating Controller from View (application behavior from
presentation)
- permits run-time selection of appropriate
Views based on workflow, user preferences,
or Model state.
• Separating Controller from Model (application behavior from data
representation)
- allows configurable mapping of user actions
on the Controller to application functions on
the Model.
Consequences or Benefits
• We make changes without bringing down the
server.
• We leave the core code alone
• We can have multiple versions of the same data
displayed
• We can test our changes in the actual
environment.
• We have achieved “separation of concerns”
References
• Home of the patterns community
http://hillside.net/
• Adaptability home page
▫ http://www.utdallas.edu/~chung/adaptability.html
• Quickest road to understanding the concepts
non-software examples
▫ http://www.agcs.com/supportv2/techpapers/patterns/papers/tutnotes/
index.htm
• The Sun location for J2ee
▫ http://java.sun.com/j2ee/
• Sun’s Java Pet store example used
▫ http://jboss.utdallas.edu:8080/estore

More Related Content

What's hot

Modern Software Architectures: Building Solutions for Web, Cloud, and Mobile
Modern Software Architectures: Building Solutions for Web, Cloud, and MobileModern Software Architectures: Building Solutions for Web, Cloud, and Mobile
Modern Software Architectures: Building Solutions for Web, Cloud, and MobileDan Mohl
 
Greate Introduction to Oracle Fusion Middleware and ADF
Greate Introduction to Oracle Fusion Middleware and ADFGreate Introduction to Oracle Fusion Middleware and ADF
Greate Introduction to Oracle Fusion Middleware and ADFMohamed Shahpoup
 
Dynamic Object-Oriented Requirements System (DOORS)
Dynamic Object-Oriented Requirements System (DOORS)Dynamic Object-Oriented Requirements System (DOORS)
Dynamic Object-Oriented Requirements System (DOORS)David Groff
 
Basic concepts and terminology for the Requirements Management application
Basic concepts and terminology for the Requirements Management applicationBasic concepts and terminology for the Requirements Management application
Basic concepts and terminology for the Requirements Management applicationIBM Rational software
 
C# .NET Developer Portfolio
C# .NET Developer PortfolioC# .NET Developer Portfolio
C# .NET Developer Portfoliocummings49
 
Doors hints and tips schema
Doors hints and tips schemaDoors hints and tips schema
Doors hints and tips schemaHazel Woodcock
 
Establishing and analyzing traceability between artifacts
Establishing and analyzing traceability between artifactsEstablishing and analyzing traceability between artifacts
Establishing and analyzing traceability between artifactsIBM Rational software
 
J2ee web services(overview)
J2ee web services(overview)J2ee web services(overview)
J2ee web services(overview)Prafull Jain
 
Ejb course-in-mumbai
Ejb course-in-mumbaiEjb course-in-mumbai
Ejb course-in-mumbaivibrantuser
 
Modules as requirement specifications
Modules as requirement specificationsModules as requirement specifications
Modules as requirement specificationsIBM Rational software
 
Managing requirements by using baselines
Managing requirements by using baselinesManaging requirements by using baselines
Managing requirements by using baselinesIBM Rational software
 
7) packaging and deployment
7) packaging and deployment7) packaging and deployment
7) packaging and deploymenttechbed
 
Architecture of eSobi club based on J2EE
Architecture of eSobi club based on J2EEArchitecture of eSobi club based on J2EE
Architecture of eSobi club based on J2EEAllan Huang
 
J2 EEE SIDES
J2 EEE  SIDESJ2 EEE  SIDES
J2 EEE SIDESbputhal
 

What's hot (20)

Modern Software Architectures: Building Solutions for Web, Cloud, and Mobile
Modern Software Architectures: Building Solutions for Web, Cloud, and MobileModern Software Architectures: Building Solutions for Web, Cloud, and Mobile
Modern Software Architectures: Building Solutions for Web, Cloud, and Mobile
 
Greate Introduction to Oracle Fusion Middleware and ADF
Greate Introduction to Oracle Fusion Middleware and ADFGreate Introduction to Oracle Fusion Middleware and ADF
Greate Introduction to Oracle Fusion Middleware and ADF
 
Dynamic Object-Oriented Requirements System (DOORS)
Dynamic Object-Oriented Requirements System (DOORS)Dynamic Object-Oriented Requirements System (DOORS)
Dynamic Object-Oriented Requirements System (DOORS)
 
Basic concepts and terminology for the Requirements Management application
Basic concepts and terminology for the Requirements Management applicationBasic concepts and terminology for the Requirements Management application
Basic concepts and terminology for the Requirements Management application
 
C# .NET Developer Portfolio
C# .NET Developer PortfolioC# .NET Developer Portfolio
C# .NET Developer Portfolio
 
Ch4 ejb
Ch4 ejbCh4 ejb
Ch4 ejb
 
Prashant Patel
Prashant PatelPrashant Patel
Prashant Patel
 
An Oracle ADF Introduction
An Oracle ADF IntroductionAn Oracle ADF Introduction
An Oracle ADF Introduction
 
Doors hints and tips schema
Doors hints and tips schemaDoors hints and tips schema
Doors hints and tips schema
 
Establishing and analyzing traceability between artifacts
Establishing and analyzing traceability between artifactsEstablishing and analyzing traceability between artifacts
Establishing and analyzing traceability between artifacts
 
J2ee web services(overview)
J2ee web services(overview)J2ee web services(overview)
J2ee web services(overview)
 
Ejb course-in-mumbai
Ejb course-in-mumbaiEjb course-in-mumbai
Ejb course-in-mumbai
 
Modules as requirement specifications
Modules as requirement specificationsModules as requirement specifications
Modules as requirement specifications
 
Java Introduction
Java IntroductionJava Introduction
Java Introduction
 
Managing requirements by using baselines
Managing requirements by using baselinesManaging requirements by using baselines
Managing requirements by using baselines
 
MVC
MVCMVC
MVC
 
7) packaging and deployment
7) packaging and deployment7) packaging and deployment
7) packaging and deployment
 
Architecture of eSobi club based on J2EE
Architecture of eSobi club based on J2EEArchitecture of eSobi club based on J2EE
Architecture of eSobi club based on J2EE
 
J2 EEE SIDES
J2 EEE  SIDESJ2 EEE  SIDES
J2 EEE SIDES
 
Identifying and managing change
Identifying and managing changeIdentifying and managing change
Identifying and managing change
 

Viewers also liked

Cognitive APIs and Conversational Interfaces
Cognitive APIs and Conversational InterfacesCognitive APIs and Conversational Interfaces
Cognitive APIs and Conversational InterfacesPavel Veller
 
FVCP - Facebook , Twitter and Meetup API / Widgets
FVCP - Facebook , Twitter and Meetup API / WidgetsFVCP - Facebook , Twitter and Meetup API / Widgets
FVCP - Facebook , Twitter and Meetup API / WidgetsPete DuMelle
 
1072個研發替代役的日子
1072個研發替代役的日子1072個研發替代役的日子
1072個研發替代役的日子Mu Chun Wang
 
Social networking api for Android Developers
Social networking api for Android DevelopersSocial networking api for Android Developers
Social networking api for Android DevelopersSatyam Twanabasu
 
đau Nhức Khớp Cổ Chân
đau Nhức Khớp Cổ Chânđau Nhức Khớp Cổ Chân
đau Nhức Khớp Cổ Chânbecki138
 
Presentacion Weblog FEDITIC
Presentacion Weblog FEDITICPresentacion Weblog FEDITIC
Presentacion Weblog FEDITICKatiusca Peña
 
TD_Portfolio_2015-lrz
TD_Portfolio_2015-lrzTD_Portfolio_2015-lrz
TD_Portfolio_2015-lrzSteve Albert
 
√ Website designing company in delhi
√ Website designing company in delhi√ Website designing company in delhi
√ Website designing company in delhiCss Founder
 
Website designing company in gurgaon
Website designing company in gurgaonWebsite designing company in gurgaon
Website designing company in gurgaonCss Founder
 
Website development company in delhi ncr
Website development company in delhi ncrWebsite development company in delhi ncr
Website development company in delhi ncrCss Founder
 
Урок "ЧОРНОБИЛЬСЬКА КАТАСТРОФА"
Урок  "ЧОРНОБИЛЬСЬКА КАТАСТРОФА"Урок  "ЧОРНОБИЛЬСЬКА КАТАСТРОФА"
Урок "ЧОРНОБИЛЬСЬКА КАТАСТРОФА"Школа №7 Миргород
 
Website designing company in faridabad
Website designing company in faridabadWebsite designing company in faridabad
Website designing company in faridabadCss Founder
 
Live streaming
Live streamingLive streaming
Live streamingtrs4
 
URP 486 LandUseProject (Final)
URP 486 LandUseProject (Final)URP 486 LandUseProject (Final)
URP 486 LandUseProject (Final)Alonzo Lopez
 
The Chat Revolution
The Chat RevolutionThe Chat Revolution
The Chat Revolutiontrs4
 
Why you should live stream your next major meeting
Why you should live stream your next major meeting Why you should live stream your next major meeting
Why you should live stream your next major meeting Jim McConnell
 
20161024 R語言資料分析實務 (3)
20161024 R語言資料分析實務 (3)20161024 R語言資料分析實務 (3)
20161024 R語言資料分析實務 (3)羅左欣
 

Viewers also liked (20)

Cognitive APIs and Conversational Interfaces
Cognitive APIs and Conversational InterfacesCognitive APIs and Conversational Interfaces
Cognitive APIs and Conversational Interfaces
 
FVCP - Facebook , Twitter and Meetup API / Widgets
FVCP - Facebook , Twitter and Meetup API / WidgetsFVCP - Facebook , Twitter and Meetup API / Widgets
FVCP - Facebook , Twitter and Meetup API / Widgets
 
1072個研發替代役的日子
1072個研發替代役的日子1072個研發替代役的日子
1072個研發替代役的日子
 
Social networking api for Android Developers
Social networking api for Android DevelopersSocial networking api for Android Developers
Social networking api for Android Developers
 
đau Nhức Khớp Cổ Chân
đau Nhức Khớp Cổ Chânđau Nhức Khớp Cổ Chân
đau Nhức Khớp Cổ Chân
 
Unidad1act2audioeducativo 120227190047-phpapp01
Unidad1act2audioeducativo 120227190047-phpapp01Unidad1act2audioeducativo 120227190047-phpapp01
Unidad1act2audioeducativo 120227190047-phpapp01
 
APM
APMAPM
APM
 
Presentacion Weblog FEDITIC
Presentacion Weblog FEDITICPresentacion Weblog FEDITIC
Presentacion Weblog FEDITIC
 
TD_Portfolio_2015-lrz
TD_Portfolio_2015-lrzTD_Portfolio_2015-lrz
TD_Portfolio_2015-lrz
 
√ Website designing company in delhi
√ Website designing company in delhi√ Website designing company in delhi
√ Website designing company in delhi
 
Website designing company in gurgaon
Website designing company in gurgaonWebsite designing company in gurgaon
Website designing company in gurgaon
 
Website development company in delhi ncr
Website development company in delhi ncrWebsite development company in delhi ncr
Website development company in delhi ncr
 
Урок "ЧОРНОБИЛЬСЬКА КАТАСТРОФА"
Урок  "ЧОРНОБИЛЬСЬКА КАТАСТРОФА"Урок  "ЧОРНОБИЛЬСЬКА КАТАСТРОФА"
Урок "ЧОРНОБИЛЬСЬКА КАТАСТРОФА"
 
Website designing company in faridabad
Website designing company in faridabadWebsite designing company in faridabad
Website designing company in faridabad
 
Бібліотека та технології веб-2.0
Бібліотека та технології веб-2.0Бібліотека та технології веб-2.0
Бібліотека та технології веб-2.0
 
Live streaming
Live streamingLive streaming
Live streaming
 
URP 486 LandUseProject (Final)
URP 486 LandUseProject (Final)URP 486 LandUseProject (Final)
URP 486 LandUseProject (Final)
 
The Chat Revolution
The Chat RevolutionThe Chat Revolution
The Chat Revolution
 
Why you should live stream your next major meeting
Why you should live stream your next major meeting Why you should live stream your next major meeting
Why you should live stream your next major meeting
 
20161024 R語言資料分析實務 (3)
20161024 R語言資料分析實務 (3)20161024 R語言資料分析實務 (3)
20161024 R語言資料分析實務 (3)
 

Similar to Mcv design patterns

Getting started with MVC 5 and Visual Studio 2013
Getting started with MVC 5 and Visual Studio 2013Getting started with MVC 5 and Visual Studio 2013
Getting started with MVC 5 and Visual Studio 2013Thomas Robbins
 
Enterprise java unit-1_chapter-2
Enterprise java unit-1_chapter-2Enterprise java unit-1_chapter-2
Enterprise java unit-1_chapter-2sandeep54552
 
enterprisejavaunit-1chapter-2-210914075956.pdf
enterprisejavaunit-1chapter-2-210914075956.pdfenterprisejavaunit-1chapter-2-210914075956.pdf
enterprisejavaunit-1chapter-2-210914075956.pdfEidTahir
 
J2EE Patterns
J2EE PatternsJ2EE Patterns
J2EE PatternsEmprovise
 
Architectural Design & Patterns
Architectural Design&PatternsArchitectural Design&Patterns
Architectural Design & PatternsInocentshuja Ahmad
 
Web tier-framework-mvc
Web tier-framework-mvcWeb tier-framework-mvc
Web tier-framework-mvcKashfUlHuda1
 
Introduction to ejb and struts framework
Introduction to ejb and struts frameworkIntroduction to ejb and struts framework
Introduction to ejb and struts frameworks4al_com
 
Mobile App Architectures & Coding guidelines
Mobile App Architectures & Coding guidelinesMobile App Architectures & Coding guidelines
Mobile App Architectures & Coding guidelinesQamar Abbas
 
Over view of software artitecture
Over view of software artitectureOver view of software artitecture
Over view of software artitectureABDEL RAHMAN KARIM
 
Introduction to j2 ee patterns online training class
Introduction to j2 ee patterns online training classIntroduction to j2 ee patterns online training class
Introduction to j2 ee patterns online training classQUONTRASOLUTIONS
 
Spring tutorials
Spring tutorialsSpring tutorials
Spring tutorialsTIB Academy
 
MVC architecture by Mohd.Awais on 18th Aug, 2017
MVC architecture by Mohd.Awais on 18th Aug, 2017MVC architecture by Mohd.Awais on 18th Aug, 2017
MVC architecture by Mohd.Awais on 18th Aug, 2017Innovation Studio
 
Introduction to j2 ee frameworks
Introduction to j2 ee frameworksIntroduction to j2 ee frameworks
Introduction to j2 ee frameworksMukesh Kumar
 
Building Enterprise Application with J2EE
Building Enterprise Application with J2EEBuilding Enterprise Application with J2EE
Building Enterprise Application with J2EECalance
 

Similar to Mcv design patterns (20)

Getting started with MVC 5 and Visual Studio 2013
Getting started with MVC 5 and Visual Studio 2013Getting started with MVC 5 and Visual Studio 2013
Getting started with MVC 5 and Visual Studio 2013
 
MVC Framework
MVC FrameworkMVC Framework
MVC Framework
 
Enterprise java unit-1_chapter-2
Enterprise java unit-1_chapter-2Enterprise java unit-1_chapter-2
Enterprise java unit-1_chapter-2
 
enterprisejavaunit-1chapter-2-210914075956.pdf
enterprisejavaunit-1chapter-2-210914075956.pdfenterprisejavaunit-1chapter-2-210914075956.pdf
enterprisejavaunit-1chapter-2-210914075956.pdf
 
Mvc architecture
Mvc architectureMvc architecture
Mvc architecture
 
J2EE Patterns
J2EE PatternsJ2EE Patterns
J2EE Patterns
 
MVC architecture
MVC architectureMVC architecture
MVC architecture
 
J2 ee archi
J2 ee archiJ2 ee archi
J2 ee archi
 
Architectural Design & Patterns
Architectural Design&PatternsArchitectural Design&Patterns
Architectural Design & Patterns
 
Web tier-framework-mvc
Web tier-framework-mvcWeb tier-framework-mvc
Web tier-framework-mvc
 
Introduction to ejb and struts framework
Introduction to ejb and struts frameworkIntroduction to ejb and struts framework
Introduction to ejb and struts framework
 
Mobile App Architectures & Coding guidelines
Mobile App Architectures & Coding guidelinesMobile App Architectures & Coding guidelines
Mobile App Architectures & Coding guidelines
 
Over view of software artitecture
Over view of software artitectureOver view of software artitecture
Over view of software artitecture
 
Introduction to j2 ee patterns online training class
Introduction to j2 ee patterns online training classIntroduction to j2 ee patterns online training class
Introduction to j2 ee patterns online training class
 
Spring tutorials
Spring tutorialsSpring tutorials
Spring tutorials
 
MVC architecture by Mohd.Awais on 18th Aug, 2017
MVC architecture by Mohd.Awais on 18th Aug, 2017MVC architecture by Mohd.Awais on 18th Aug, 2017
MVC architecture by Mohd.Awais on 18th Aug, 2017
 
Introduction to j2 ee frameworks
Introduction to j2 ee frameworksIntroduction to j2 ee frameworks
Introduction to j2 ee frameworks
 
Persentation
PersentationPersentation
Persentation
 
Asp.net mvc 5 ppt
Asp.net mvc 5 pptAsp.net mvc 5 ppt
Asp.net mvc 5 ppt
 
Building Enterprise Application with J2EE
Building Enterprise Application with J2EEBuilding Enterprise Application with J2EE
Building Enterprise Application with J2EE
 

Recently uploaded

The Essentials of Digital Experience Monitoring_ A Comprehensive Guide.pdf
The Essentials of Digital Experience Monitoring_ A Comprehensive Guide.pdfThe Essentials of Digital Experience Monitoring_ A Comprehensive Guide.pdf
The Essentials of Digital Experience Monitoring_ A Comprehensive Guide.pdfkalichargn70th171
 
KnowAPIs-UnknownPerf-jaxMainz-2024 (1).pptx
KnowAPIs-UnknownPerf-jaxMainz-2024 (1).pptxKnowAPIs-UnknownPerf-jaxMainz-2024 (1).pptx
KnowAPIs-UnknownPerf-jaxMainz-2024 (1).pptxTier1 app
 
Salesforce Certified Field Service Consultant
Salesforce Certified Field Service ConsultantSalesforce Certified Field Service Consultant
Salesforce Certified Field Service ConsultantAxelRicardoTrocheRiq
 
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...kellynguyen01
 
Building a General PDE Solving Framework with Symbolic-Numeric Scientific Mac...
Building a General PDE Solving Framework with Symbolic-Numeric Scientific Mac...Building a General PDE Solving Framework with Symbolic-Numeric Scientific Mac...
Building a General PDE Solving Framework with Symbolic-Numeric Scientific Mac...stazi3110
 
Advancing Engineering with AI through the Next Generation of Strategic Projec...
Advancing Engineering with AI through the Next Generation of Strategic Projec...Advancing Engineering with AI through the Next Generation of Strategic Projec...
Advancing Engineering with AI through the Next Generation of Strategic Projec...OnePlan Solutions
 
Optimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTVOptimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTVshikhaohhpro
 
What is Fashion PLM and Why Do You Need It
What is Fashion PLM and Why Do You Need ItWhat is Fashion PLM and Why Do You Need It
What is Fashion PLM and Why Do You Need ItWave PLM
 
Unit 1.1 Excite Part 1, class 9, cbse...
Unit 1.1 Excite Part 1, class 9, cbse...Unit 1.1 Excite Part 1, class 9, cbse...
Unit 1.1 Excite Part 1, class 9, cbse...aditisharan08
 
DNT_Corporate presentation know about us
DNT_Corporate presentation know about usDNT_Corporate presentation know about us
DNT_Corporate presentation know about usDynamic Netsoft
 
Unveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time ApplicationsUnveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time ApplicationsAlberto González Trastoy
 
(Genuine) Escort Service Lucknow | Starting ₹,5K To @25k with A/C 🧑🏽‍❤️‍🧑🏻 89...
(Genuine) Escort Service Lucknow | Starting ₹,5K To @25k with A/C 🧑🏽‍❤️‍🧑🏻 89...(Genuine) Escort Service Lucknow | Starting ₹,5K To @25k with A/C 🧑🏽‍❤️‍🧑🏻 89...
(Genuine) Escort Service Lucknow | Starting ₹,5K To @25k with A/C 🧑🏽‍❤️‍🧑🏻 89...gurkirankumar98700
 
ODSC - Batch to Stream workshop - integration of Apache Spark, Cassandra, Pos...
ODSC - Batch to Stream workshop - integration of Apache Spark, Cassandra, Pos...ODSC - Batch to Stream workshop - integration of Apache Spark, Cassandra, Pos...
ODSC - Batch to Stream workshop - integration of Apache Spark, Cassandra, Pos...Christina Lin
 
Cloud Management Software Platforms: OpenStack
Cloud Management Software Platforms: OpenStackCloud Management Software Platforms: OpenStack
Cloud Management Software Platforms: OpenStackVICTOR MAESTRE RAMIREZ
 
Alluxio Monthly Webinar | Cloud-Native Model Training on Distributed Data
Alluxio Monthly Webinar | Cloud-Native Model Training on Distributed DataAlluxio Monthly Webinar | Cloud-Native Model Training on Distributed Data
Alluxio Monthly Webinar | Cloud-Native Model Training on Distributed DataAlluxio, Inc.
 
EY_Graph Database Powered Sustainability
EY_Graph Database Powered SustainabilityEY_Graph Database Powered Sustainability
EY_Graph Database Powered SustainabilityNeo4j
 
why an Opensea Clone Script might be your perfect match.pdf
why an Opensea Clone Script might be your perfect match.pdfwhy an Opensea Clone Script might be your perfect match.pdf
why an Opensea Clone Script might be your perfect match.pdfjoe51371421
 
The Evolution of Karaoke From Analog to App.pdf
The Evolution of Karaoke From Analog to App.pdfThe Evolution of Karaoke From Analog to App.pdf
The Evolution of Karaoke From Analog to App.pdfPower Karaoke
 
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...MyIntelliSource, Inc.
 

Recently uploaded (20)

The Essentials of Digital Experience Monitoring_ A Comprehensive Guide.pdf
The Essentials of Digital Experience Monitoring_ A Comprehensive Guide.pdfThe Essentials of Digital Experience Monitoring_ A Comprehensive Guide.pdf
The Essentials of Digital Experience Monitoring_ A Comprehensive Guide.pdf
 
KnowAPIs-UnknownPerf-jaxMainz-2024 (1).pptx
KnowAPIs-UnknownPerf-jaxMainz-2024 (1).pptxKnowAPIs-UnknownPerf-jaxMainz-2024 (1).pptx
KnowAPIs-UnknownPerf-jaxMainz-2024 (1).pptx
 
Salesforce Certified Field Service Consultant
Salesforce Certified Field Service ConsultantSalesforce Certified Field Service Consultant
Salesforce Certified Field Service Consultant
 
Call Girls In Mukherjee Nagar 📱 9999965857 🤩 Delhi 🫦 HOT AND SEXY VVIP 🍎 SE...
Call Girls In Mukherjee Nagar 📱  9999965857  🤩 Delhi 🫦 HOT AND SEXY VVIP 🍎 SE...Call Girls In Mukherjee Nagar 📱  9999965857  🤩 Delhi 🫦 HOT AND SEXY VVIP 🍎 SE...
Call Girls In Mukherjee Nagar 📱 9999965857 🤩 Delhi 🫦 HOT AND SEXY VVIP 🍎 SE...
 
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
 
Building a General PDE Solving Framework with Symbolic-Numeric Scientific Mac...
Building a General PDE Solving Framework with Symbolic-Numeric Scientific Mac...Building a General PDE Solving Framework with Symbolic-Numeric Scientific Mac...
Building a General PDE Solving Framework with Symbolic-Numeric Scientific Mac...
 
Advancing Engineering with AI through the Next Generation of Strategic Projec...
Advancing Engineering with AI through the Next Generation of Strategic Projec...Advancing Engineering with AI through the Next Generation of Strategic Projec...
Advancing Engineering with AI through the Next Generation of Strategic Projec...
 
Optimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTVOptimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTV
 
What is Fashion PLM and Why Do You Need It
What is Fashion PLM and Why Do You Need ItWhat is Fashion PLM and Why Do You Need It
What is Fashion PLM and Why Do You Need It
 
Unit 1.1 Excite Part 1, class 9, cbse...
Unit 1.1 Excite Part 1, class 9, cbse...Unit 1.1 Excite Part 1, class 9, cbse...
Unit 1.1 Excite Part 1, class 9, cbse...
 
DNT_Corporate presentation know about us
DNT_Corporate presentation know about usDNT_Corporate presentation know about us
DNT_Corporate presentation know about us
 
Unveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time ApplicationsUnveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
 
(Genuine) Escort Service Lucknow | Starting ₹,5K To @25k with A/C 🧑🏽‍❤️‍🧑🏻 89...
(Genuine) Escort Service Lucknow | Starting ₹,5K To @25k with A/C 🧑🏽‍❤️‍🧑🏻 89...(Genuine) Escort Service Lucknow | Starting ₹,5K To @25k with A/C 🧑🏽‍❤️‍🧑🏻 89...
(Genuine) Escort Service Lucknow | Starting ₹,5K To @25k with A/C 🧑🏽‍❤️‍🧑🏻 89...
 
ODSC - Batch to Stream workshop - integration of Apache Spark, Cassandra, Pos...
ODSC - Batch to Stream workshop - integration of Apache Spark, Cassandra, Pos...ODSC - Batch to Stream workshop - integration of Apache Spark, Cassandra, Pos...
ODSC - Batch to Stream workshop - integration of Apache Spark, Cassandra, Pos...
 
Cloud Management Software Platforms: OpenStack
Cloud Management Software Platforms: OpenStackCloud Management Software Platforms: OpenStack
Cloud Management Software Platforms: OpenStack
 
Alluxio Monthly Webinar | Cloud-Native Model Training on Distributed Data
Alluxio Monthly Webinar | Cloud-Native Model Training on Distributed DataAlluxio Monthly Webinar | Cloud-Native Model Training on Distributed Data
Alluxio Monthly Webinar | Cloud-Native Model Training on Distributed Data
 
EY_Graph Database Powered Sustainability
EY_Graph Database Powered SustainabilityEY_Graph Database Powered Sustainability
EY_Graph Database Powered Sustainability
 
why an Opensea Clone Script might be your perfect match.pdf
why an Opensea Clone Script might be your perfect match.pdfwhy an Opensea Clone Script might be your perfect match.pdf
why an Opensea Clone Script might be your perfect match.pdf
 
The Evolution of Karaoke From Analog to App.pdf
The Evolution of Karaoke From Analog to App.pdfThe Evolution of Karaoke From Analog to App.pdf
The Evolution of Karaoke From Analog to App.pdf
 
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
 

Mcv design patterns

  • 2. Design Patterns • A pattern is a proven solution to a problem in a context. • Christopher Alexander says each pattern is a three-part rule which expresses a relation between a certain context, a problem, and a solution. • Design patterns represent a solutions to problems that arise when developing software within a particular context. i.e Patterns = problems.solution pairs in a context
  • 3. Background • Started in 1987 by Ward Cunningham and Ken Beck who were working with Smalltalk and designing GUIs. • Popularized by Gamma, Helm, Johnson and Vlissides (The gang of four, Go4) • The three of Go4 were working on frameworks (E++,Unidraw, HotDraw) • Design pattern use a consistent documentation approach • Design pattern are granular and applied at different levels such as frameworks, subsystems and sub-subsystems • Design patterns are often organized as creational, structural or behavioral
  • 4. Categorizing Pattern Patterns, then, represent expert solutions to recurring problems in a context and thus have been captured at many levels of abstraction and in numerous domains. Numerous categories are: • Design • Architectural • Analysis • Creational • Structural • Behavioral
  • 5. Sun’s J2EE Framework • Components Containers and Connectors: Hiding Complexity, Enhancing Portability • Components are the key focus of application developers • Containers intercede between clients and components, providing services transparently to both, including transaction support and resource pooling. • Connectors sit beneath the J2EE platform, defining a portable service API to plug into existing enterprise vendor offerings.
  • 6. J2EE • Components ▫ Enterprise Java Beans (EJB) ▫ Java Server Pages (JSP) ▫ Servlets • Containers (service providers) ▫ Web container ▫ Bean Container • Connectors (connection service providers)
  • 7.
  • 8. J2EE and Design Patterns • J2EE: AN OPERATING SYSTEM FOR THE WEB Enterprise web applications, which live on networks and are accessible through browsers, are redefining Enterprise Web Software. This is the next wave of computing. • The J2EE architecture is built to enable component developers to use a Model View Controller (MVC) Design Pattern.
  • 9. Details of MVC Design Pattern • Name (essence of the pattern) ▫ Model View Controller MVC • Context (where does this problem occur) ▫ MVC is an architectural pattern that is used when developing interactive application such as a shopping cart on the Internet. • Problem (definition of the reoccurring difficulty) ▫ User interfaces change often, especially on the internet where look-and-feel is a competitive issue. Also, the same information is presented in different ways. The core business logic and data is stable.
  • 10. MVC continued • Solution (how do you solve the problem) ▫ Use the software engineering principle of “separation of concerns” to divide the application into three areas:  Model encapsulates the core data and functionality  View encapsulates the presentation of the data there can be many views of the common data  Controller accepts input from the user and makes request from the model for the data to produce a new view.
  • 12. MVC Architecture • The Model represents the structure of the data in the application, as well as application-specific operations on those data. • A View (of which there may be many) presents data in some form to a user, in the context of some application function. • A Controller translates user actions (mouse motions, keystrokes, words spoken, etc.) and user input into application function calls on the model, and selects the appropriate View based on user preferences and Model state.
  • 13. Example of MVC Design Pattern • Let’s investigate this statement by looking at a small application that demonstrates MVC on J2EE
  • 14. Java Pet Store- MVC Design Pattern  The Java Pet Store is a reference application that demonstrates J2EE technologies.  It demonstrates interaction between Java Server Pages (JSP's), custom Tag Libraries, JavaBeans, and Enterprise Java Beans.  It demonstrates a real-world approach to application development, where the presentation of data is separated from the process of obtaining data from objects which interact with the enterprise or database tier.  The Pet Store application implements MVC (Model-View- Controller) design, and demonstrates one way to design an application that should scale well.
  • 15. Multi Tier Architecture  The Java Pet Store design is divided into multiple tiers: A. Client tier B. Web tier C. Enterprise JavaBeans tier D. Enterprise Information System tier.  These tiers are not necessarily arranged hierarchically.  Each tier may communicate directly with other tiers, or indirectly by way of intermediate tiers.
  • 17. A. Details of Client Tier • The Client tier is responsible for presenting data to the user, interacting with the user, and communicating with the other tiers of the application. • The Client tier is the only part the application the user ever sees. • The Client tier communicates with other tiers by way of well-defined interfaces. • A separate Client tier in the design provides flexibility and extensibility.
  • 18. A. Details of Client Tier • In The Java Pet Store Client tier consists mainly of a browser displaying Web pages generated from server-side JSP pages in the Web tier. • Future new clients can be written using technologies or languages that do not yet even exist, since they must conform only to the interface for communicating with other tiers
  • 19. B. Web Tier • The Web tier is responsible for performing all Web-related processing, such as serving HTML, instantiating Web page templates, and formatting JSP pages for display by browsers. • The Web tier in the Java Pet Store does all of these, and takes on the Controller functions for the Web application, caching model data interpreting user inputs, selecting appropriate Views based on application flow, and managing database connections.
  • 20. C. EJB Tier • Enterprise JavaBeans are software business components which extend servers to perform application-specific functionality. • The interface between these components and their containers is defined in the EJBs specification. • Essentially, the EJBs tier provides a component model for access to distributed system services and persistent data.
  • 21. C. EJB Tier • Both stand-alone clients and Web applications in the Web tier can use EJB components hosted by the EJBs tier. • It also simplifies application component development, because details about system issues such as persistence, reentrancy, transactions, remote access, and so on, are all handled by the container.
  • 22. D.Enterprise Information System (EIS) Tier • The EIS tier is the enterprise information infrastructure. • Members of the EIS tier typically include enterprise information planning (ERP) systems, transaction processing monitors, relational database management systems, and legacy enterprise applications. • Access to the EIS tier is usually transactional, to ensure that data are consistent across application boundaries. • The EIS tier also enforces security and offers scalability.
  • 23. MVC supports Modular Design  Has set of modules, each tightly coupled internally, and loosely coupled between modules.  Each module has an interface that defines the module's functional requirements and provides a place where third- party products may be integrated.  The Java Pet Store demo modules are:  User Account  Product Catalog  Order Processing  Messaging  Inventory  Control  The Modular design supports the design goal of reusable software.
  • 24. Java Pet store- MVC • Views ▫ JSP pages, composed with templates and displayed in an HTML browser • Controller ▫ maps user input from the browser to request events, and forwards those events to the Shopping Client Controller in the EJB tier. • Model ▫ EJB Tier
  • 25. MVC Details in Java Pet store • Model represents the structure of the data in the application, as well as application-specific operations on data - CartModel, InventoryModel, CustomerEJB, and others • Views are Java server pages (JSPs) ▫ rendered from the web container to the browser, stand-alone applications that provide View functionality, and interfaces to spreadsheet programs, such as the StarOfficeTM suite. • Controller is server side java program (Servlet) ▫ MainServlet.java, which dispatches browser requests to other controller objects, such as ShoppingClientController.java, AdminClientController.java, and their related support classes.
  • 26. Views:Java Server Page (JSP) • http://java.sun.com/products/jsp/ • Technology for developing dynamic web sites that replaces CGI • Thought of as a server-side scripting tool • Contains HTML and Java code (scripts) • Is compiled into a servlet and executes on the server.
  • 27. Controller Servlet • A java class that runs on the server • Extends http Servlet • Runs in a container class (servlet/JSP engine) • Application servers (Jrun, WebLogic) have the containers • This has the logic for the application
  • 28. EJBs • Enterprise Java Beans Connect Servlets to the back end database • Examples of EJBs in Java Pet store are: AccountHandler, ModelUpdateManager, ShoppingClientControllerHome, CartHandler, ShoppingClientControllerEJB, SigninHandler, OrderHandler
  • 29. Advantages of MVC • Separating Model from View (that is, separating data representation from presentation) - easy to add multiple data presentations for the same data, -facilitates adding new types of data presentation as technology develops. -Model and View components can vary independently enhancing maintainability, extensibility, and testability.
  • 30. Advantages of MVC design Pattern • Separating Controller from View (application behavior from presentation) - permits run-time selection of appropriate Views based on workflow, user preferences, or Model state. • Separating Controller from Model (application behavior from data representation) - allows configurable mapping of user actions on the Controller to application functions on the Model.
  • 31. Consequences or Benefits • We make changes without bringing down the server. • We leave the core code alone • We can have multiple versions of the same data displayed • We can test our changes in the actual environment. • We have achieved “separation of concerns”
  • 32. References • Home of the patterns community http://hillside.net/ • Adaptability home page ▫ http://www.utdallas.edu/~chung/adaptability.html • Quickest road to understanding the concepts non-software examples ▫ http://www.agcs.com/supportv2/techpapers/patterns/papers/tutnotes/ index.htm • The Sun location for J2ee ▫ http://java.sun.com/j2ee/ • Sun’s Java Pet store example used ▫ http://jboss.utdallas.edu:8080/estore