SlideShare uma empresa Scribd logo
1 de 32
1
Web Engineering
A presentation by
Athul
Sai(P3MCA12012)
Sreejith
S(P3MCA12036)
2
Web Applicat ions
 WebApps encompass:
 complete Web sites
 Simple information Web sites
 Complex e-Commerce of other sites with embedded
functionality and data retrieval
 Complex Web sites that are interoperable with other
legacy software and systems
 specialized functionality within Web sites
 information processing applications that reside on
the Internet or on an intranet or ExtraNet.
3
WebApp At t ribut es—I
 Network intensiveness. A WebApp resides on a network
and must serve the needs of a diverse community of
clients.
 Concurrency. A large number of users may access the
WebApp at one time; patterns of usage among end-users
will vary greatly.
 Unpredictable load. The number of users of the WebApp
may vary by orders of magnitude from day to day.
 Performance. If a WebApp user must wait too long (for
access, for server-side processing, for client-side
formatting and display), he or she may decide to go
elsewhere.
4
WebApp At t ribut es—I I
 Availability. Although expectation of 100 percent
availability is unreasonable, users of popular WebApps
often demand access on a “24/7/365” basis.
 Data driven. The primary function of many WebApps is to
use hypermedia to present text, graphics, audio, and video
content to the end-user.
 Content sensitive. The quality and aesthetic nature of
content remains an important determinant of the quality of
a WebApp.
 Continuous evolution. Unlike conventional application
software that evolves over a series of planned,
chronologically-spaced releases, Web applications evolve
continuously.
5
WebApp At t ribut es—I I I
 Immediacy. WebApps often exhibit a time to market that
can be a matter of a few days or weeks.
 With modern tools, sophisticated Web pages can be
produced in only a few hours.
 Security. In order to protect sensitive content and provide
secure modes of data transmission, strong security
measures must be implemented throughout the
infrastructure that supports a WebApp and within the
application itself.
 Aesthetics. When an application has been designed to
market or sell products or ideas, aesthetics may have as
much to do with success as technical design.
6
WebApp Cat egories
 informational—read-only content is provided with simple navigation and links
 download—a user downloads information from the appropriate server
 customizable—the user customizes content to specific needs
 interaction—communication among a community of users occurs via chatroom,
bulletin boards, or instant messaging
 user input—forms-based input is the primary mechanism for communicating
need
 transaction-oriented—the user makes a request (e.g., places an order) that is
fulfilled by the WebApp
 service-oriented—the application provides a service to the user, e.g., assists the
user in determining a mortgage payment
 Portal—the application channels the user to other Web content or services
outside the domain of the portal application
 database access—the user queries a large database and extracts information
 data warehousing—the user queries a collection of large databases and extracts
information
WebE layers
7
8
The WebE Process
 Must accommodate:
 Incremental delivery
 Frequent changes
 Short timeline
 Therefore,
 An incremental process model should be used in
virtually all situations
 An agile process model is appropriate in many
situations
9
The WebE Process
sof t ware increment
Release
refact oring
business analysis
formulat ion
it erat ion plan
analysis model
content
iteration
function
configuration
design model
content
architecture
navigation
interface
coding
component t est
accept ance t est
cust omer use
cust omer evaluat ion
10
The WebE Process
Framework—I
 Customer communication
 Business analysis defines the
business/organizational context for the WebApp.
 Formulation is a requirements gathering activity
involving all stakeholders. The intent is to describe
the problem that the WebApp is to solve
 Planning
 The “plan” consists of a task definition and a
timeline schedule for the time period (usually
measured in weeks) projected for the development
of the WebApp increment.
11
The WebE Process
Framework—I I
 Modeling
 Analysis model—establishes a basis for design
 Content Analysis.
 Interaction Analysis.
 Functional Analysis.
 Configuration Analysis.
 Design model—represents key WebApp elements
 Content design
 Aesthetic design
 Architectural design
 Interface design
 Navigation design
 Component design
12
The WebE Process
Framework—I I I
 Construction
 WebE tools and technology are applied to construct
the WebApp that has been modeled
 Testing of all design elements
 Delivery and Evaluation (Deployment)
 configure for its operational environment
 deliver to end-users, and
 Evaluation feedback is presented to the WebE team
 the increment is modified as required (the beginning
of the next incremental cycle)
13
WebE—Best Pract ices
 Take the time to understand the business needs and product
objectives, even if the details of the WebApp are vague.
 Describe how users will interact with the WebApp using a
scenario-based approach
 Develop a project plan, even it its very brief.
 Spend some time modeling what it is that you’re going to build.
 Review the models for consistency and quality.
 Use tools and technology that enable you to construct the
system with as many reusable components as possible.
 Don’t rely on early users to debug the WebApp—design
comprehensive tests and execute them before releasing the
system.
14
Analysis Modeling f or
WebApps
15
Analysis
 Content Analysis. The full spectrum of content to be provided
by the WebApp is identified, including text, graphics and
images, video, and audio data. Data modeling can be used to
identify and describe each of the data objects.
 Interaction Analysis. The manner in which the user interacts
with the WebApp is described in detail. Use-cases can be
developed to provide detailed descriptions of this interaction.
 Functional Analysis. The usage scenarios (use-cases) created
as part of interaction analysis define the operations that will be
applied to WebApp content and imply other processing
functions. All operations and functions are described in detail.
 Configuration Analysis. The environment and infrastructure in
which the WebApp resides are described in detail.
16
When Do We Perf orm
Analysis?
 In some WebE situations, analysis and design merge.
However, an explicit analysis activity occurs when …
 the WebApp to be built is large and/or complex
 the number of stakeholders is large
 the number of Web engineers and other contributors is
large
 the goals and objectives (determined during formulation)
for the WebApp will effect the business’ bottom line
 the success of the WebApp will have a strong bearing
on the success of the business
17
The User Hierarchy
SafeHomeAssured.com
user
Figure 18.1 User hierarchy for SafeHomeAssured.com
guest regist ered
user
cust omer service
st aff
exist ing cust omernew cust omer
18
Use-Case Diagram
Figure 18.2 Use-case diagram f or new-cust omer
new customer
log-in to
SafeHomeAssured.com
customize
SafeHome
describe
home layout
select
SafeHome
components
save
configuration
purchase
conf iguration
view
shopping cart
provide
purchase data
recall saved
configuration
peruse
descriptive
content
complete
SafeHome order
customization functionality
e-commerce functionality
<<inc lude>>
<<inc lude>>
<<inc lude>>
<<inc lude>>
<<inc lude>>
<<inc lude>>
19
The Cont ent Model
 Content objects are extracted from use-cases
 examine the scenario description for direct and
indirect references to content
 Attributes of each content object are identified
 The relationships among content objects and/or the
hierarchy of content maintained by a WebApp
 Relationships—entity-relationship diagram or UML
 Hierarchy—data tree or UML
20
Dat a Tree
Figure 1 8 .3 Dat a t ree for aSafeHom e com ponent
component
part Number
part Name
part Type
description
price
MarketingDescript ion
Phot ograph
TechDescript ion
Schemat ic
Video
WholesalePrice
Ret ailPrice
21
Analysis Classes
 Analysis classes are derived by
examining each use-case
 A grammatical parse is used to identify
candidate classes
 A UML class diagram is developed for
each analysis class
22
Analysis Class Example
Figure 18.4 Analysis classes for use-case: select SafeHomecomponents
BillOfMat erials
ident ifier
priceTot al
addEnt ry( )
delet eEnt ry( )
edit Ent ry( )
name( )
save( )
comput ePrice( )
Product Component
part Number
part Name
part Type
descript ion
price
creat eNewIt em( )
get Descript ion( )
get TechSpec
BoMIt em
quant it y
price
addt oList( )
delet efromList( )
Sensor Camera Cont rolPanel Soft Feat ure
1
*
1
*
23
The I nt eract ion Model
 Composed of four elements:
 use-cases
 sequence diagrams
 state diagrams
 a user interface prototype
 Each of these is an important UML
notation
24
Sequence Diagram
Figure 18.5 Sequence diagram for use-case:select SafeHomecomponents
new cust omer
:Room :FloorPlan
desc ribes
room *
plac es room
in f loor plan
:Product
Component
selec t s produc t c om ponent *
:Billof
Mat erials
add t o BoM
FloorPlan
Reposit ory
sav e f loor plan c onf igurat ion
sav e bill of m at erials
BoM
Reposit ory
25
St at e Diagram
Figure 1 8 .6 Part ial st at e diagram for ne w c ust ome rinteract ion
n e w cu st o m e r
Validating user
system status=“input ready”
displaymsg = “enteruserid”
displaymsg =“enterpswd”
entry/ log-in requested
do: run user validation
exit/set user access switch
select “log-in”
userid
validated
password validated
Selecting user action
system status=“link ready”
display: navigation choices”
entry/ validated user
do: link as required
exit/user action selected
select other functions
select customization functionality
select e-commerce (purchase) functionality
Customizing
system status=“input ready”
display: basic instructions
entry/validated user
do: process user selection
exit/ customization terminated
select descriptive
content
room being defined
Defining room
system status=“input ready”
display: roomdef. window
entry/ roomdef.selected
do: run room queries
do: store room variables
exit/room completed
select descriptive
content
Building floor plan
system status=“input ready”
display: floor plan window
entry/ floor plan selected
do: insert room in place
do: store floor plan variables
exit/room insertion completed
select descriptive
content
select enter room in floor plan
Saving floor plan
system status=“input ready”
display: storage indicator
entry/ floor plan save selected
do: store floor plan
exit/save completed
select save floor plan
room insertion completed
next selection
customization complete
all rooms
defined
26
The Funct ional Model
 The functional model addresses two
processing elements of the WebApp
 user observable functionality that is
delivered by the WebApp to end-users
 the operations contained within analysis
classes that implement behaviors
associated with the class.
 An activity diagram can be used to
represent processing flow
27
Act ivit y Diagram
Figure 1 8 .7 Act ivit y diagram f or c omput e Pr i c e( ) ope r a t i on
init ialize t ot alCost
invoke
calcShippingCost
get price and
quant it y
components remain onBoMList
invoke
det ermineDiscount
discount < = 0
discount>0
t ot alCost=
t ot alCost - discount
t axTot al=
t ot alCost x t axrat e
no components remain onBoMList
lineCost =
price x quant it y
add lineCost t o
t ot alCost
priceTot al =
t ot alCost + t axTot al
+ shippingCost
ret urns:
shippingCost
ret urns: discount
28
The Conf igurat ion Model
 Server-side
 Server hardware and operating system environment
must be specified
 Interoperability considerations on the server-side must
be considered
 Appropriate interfaces, communication protocols and
related collaborative information must be specified
 Client-side
 Browser configuration issues must be identified
 Testing requirements should be defined
29
Relat ionship-Navigat ion
Analysis
 Relationship-navigation analysis (RNA) identifies relationships
among the elements uncovered as part of the creation of the
analysis model
 Steps:
 Stakeholder analysis—identifies the various user categories and
establishes an appropriate stakeholder hierarchy
 Element analysis—identifies the content objects and functional
elements that are of interest to end users
 Relationship analysis—describes the relationships that exist among
the WebApp elements
 Navigation analysis—examines how users might access individual
elements or groups of elements
 Evaluation analysis—considers pragmatic issues (e.g., cost/benefit)
associated with implementing the relationships defined earlier
30
Navigat ion Analysis-I
 Should certain elements be easier to reach (require fewer
navigation steps) than others? What is the priority for
presentation?
 Should certain elements be emphasized to force users to
navigate in their direction?
 How should navigation errors be handled?
 Should navigation to related groups of elements be given priority
over navigation to a specific element.
 Should navigation be accomplished via links, via search-based
access, or by some other means?
 Should certain elements be presented to users based on the
context of previous navigation actions?
 Should a navigation log be maintained for users?
31
Navigat ion Analysis-I I
 Should a full navigation map or menu (as opposed to a single
“back” link or directed pointer) be available at every point in a
user’s interaction?
 Should navigation design be driven by the most commonly
expected user behaviors or by the perceived importance of the
defined WebApp elements?
 Can a user “store” his previous navigation through the WebApp
to expedite future usage?
 For which user category should optimal navigation be
designed?
 How should links external to the WebApp be handled?
overlaying the existing browser window? as a new browser
window? as a separate frame?
THANKYOU 
32

Mais conteúdo relacionado

Mais procurados

Sequence diagram
Sequence diagramSequence diagram
Sequence diagramRahul Pola
 
Compiler design error handling
Compiler design error handlingCompiler design error handling
Compiler design error handlingRohitK71
 
Introduction to Software Engineering
Introduction to Software EngineeringIntroduction to Software Engineering
Introduction to Software EngineeringSaqib Raza
 
Web Development with HTML5, CSS3 & JavaScript
Web Development with HTML5, CSS3 & JavaScriptWeb Development with HTML5, CSS3 & JavaScript
Web Development with HTML5, CSS3 & JavaScriptEdureka!
 
Front End Development | Introduction
Front End Development | IntroductionFront End Development | Introduction
Front End Development | IntroductionJohnTaieb
 
Introduction to Web Development
Introduction to Web DevelopmentIntroduction to Web Development
Introduction to Web DevelopmentParvez Mahbub
 
Static and Dynamic webpage
Static and Dynamic webpageStatic and Dynamic webpage
Static and Dynamic webpageAishwarya Pallai
 
Software process and project metrics
Software process and project metricsSoftware process and project metrics
Software process and project metricsIndu Sharma Bhardwaj
 
Software architecture design ppt
Software architecture design pptSoftware architecture design ppt
Software architecture design pptfarazimlak
 
Difference between-web-designing-and-web-development
Difference between-web-designing-and-web-developmentDifference between-web-designing-and-web-development
Difference between-web-designing-and-web-developmentGlobal Media Insight
 
Software requirement specification
Software requirement specificationSoftware requirement specification
Software requirement specificationshiprashakya2
 

Mais procurados (20)

Web Engineering
Web EngineeringWeb Engineering
Web Engineering
 
Web Engineering
Web EngineeringWeb Engineering
Web Engineering
 
software engineering
software engineeringsoftware engineering
software engineering
 
Sequence diagram
Sequence diagramSequence diagram
Sequence diagram
 
Software Architecture
Software ArchitectureSoftware Architecture
Software Architecture
 
Web Engineering
Web EngineeringWeb Engineering
Web Engineering
 
Introduction to UML
Introduction to UMLIntroduction to UML
Introduction to UML
 
Compiler design error handling
Compiler design error handlingCompiler design error handling
Compiler design error handling
 
Introduction to Software Engineering
Introduction to Software EngineeringIntroduction to Software Engineering
Introduction to Software Engineering
 
Web Development with HTML5, CSS3 & JavaScript
Web Development with HTML5, CSS3 & JavaScriptWeb Development with HTML5, CSS3 & JavaScript
Web Development with HTML5, CSS3 & JavaScript
 
Front End Development | Introduction
Front End Development | IntroductionFront End Development | Introduction
Front End Development | Introduction
 
Software Evolution
Software EvolutionSoftware Evolution
Software Evolution
 
Introduction to Web Development
Introduction to Web DevelopmentIntroduction to Web Development
Introduction to Web Development
 
Static and Dynamic webpage
Static and Dynamic webpageStatic and Dynamic webpage
Static and Dynamic webpage
 
Software process and project metrics
Software process and project metricsSoftware process and project metrics
Software process and project metrics
 
Software architecture design ppt
Software architecture design pptSoftware architecture design ppt
Software architecture design ppt
 
Difference between-web-designing-and-web-development
Difference between-web-designing-and-web-developmentDifference between-web-designing-and-web-development
Difference between-web-designing-and-web-development
 
Web application architecture
Web application architectureWeb application architecture
Web application architecture
 
Software requirement specification
Software requirement specificationSoftware requirement specification
Software requirement specification
 
software design
software designsoftware design
software design
 

Semelhante a Web engineering

WebE_chapter_16.ppt
WebE_chapter_16.pptWebE_chapter_16.ppt
WebE_chapter_16.pptUsamaPatel9
 
Employee Management System
Employee Management SystemEmployee Management System
Employee Management Systemvivek shah
 
IRJET- Conversational Commerce (ESTILO)
IRJET- Conversational Commerce (ESTILO)IRJET- Conversational Commerce (ESTILO)
IRJET- Conversational Commerce (ESTILO)IRJET Journal
 
IRJET- Design of Closed Loop PI Controller Based Hybrid Z-Source DC-DC Conver...
IRJET- Design of Closed Loop PI Controller Based Hybrid Z-Source DC-DC Conver...IRJET- Design of Closed Loop PI Controller Based Hybrid Z-Source DC-DC Conver...
IRJET- Design of Closed Loop PI Controller Based Hybrid Z-Source DC-DC Conver...IRJET Journal
 
127801976 mobile-shop-management-system-documentation
127801976 mobile-shop-management-system-documentation127801976 mobile-shop-management-system-documentation
127801976 mobile-shop-management-system-documentationNitesh Kumar
 
1.Design Modelling for Web Apps.pdf software engineering
1.Design Modelling for Web Apps.pdf software engineering1.Design Modelling for Web Apps.pdf software engineering
1.Design Modelling for Web Apps.pdf software engineeringSukhmanSingh91
 
SathishKumar Natarajan
SathishKumar NatarajanSathishKumar Natarajan
SathishKumar NatarajanSathish Kumar
 
Web Based Investment Management System
Web Based Investment Management SystemWeb Based Investment Management System
Web Based Investment Management SystemMike Taylor
 
System analysis and design
System analysis and designSystem analysis and design
System analysis and designRobinsonObura
 
Over view of software artitecture
Over view of software artitectureOver view of software artitecture
Over view of software artitectureABDEL RAHMAN KARIM
 
Building Bridges: Merging RPA Processes, UiPath Apps, and Data Service to bu...
Building Bridges:  Merging RPA Processes, UiPath Apps, and Data Service to bu...Building Bridges:  Merging RPA Processes, UiPath Apps, and Data Service to bu...
Building Bridges: Merging RPA Processes, UiPath Apps, and Data Service to bu...DianaGray10
 
Research Inventy : International Journal of Engineering and Science
Research Inventy : International Journal of Engineering and ScienceResearch Inventy : International Journal of Engineering and Science
Research Inventy : International Journal of Engineering and Scienceinventy
 
Super applied in a sitecore migration project
Super applied in a sitecore migration projectSuper applied in a sitecore migration project
Super applied in a sitecore migration projectdodoshelu
 
Case Study For Web Based Application for Rent or Sale
Case Study For Web Based Application for Rent or SaleCase Study For Web Based Application for Rent or Sale
Case Study For Web Based Application for Rent or SaleMike Taylor
 
Rich Internet Applications
Rich Internet ApplicationsRich Internet Applications
Rich Internet ApplicationsYoussef Shaath
 

Semelhante a Web engineering (20)

WebE_chapter_16.ppt
WebE_chapter_16.pptWebE_chapter_16.ppt
WebE_chapter_16.ppt
 
Slides chapter 16
Slides chapter 16Slides chapter 16
Slides chapter 16
 
Employee Management System
Employee Management SystemEmployee Management System
Employee Management System
 
AnikResume
AnikResumeAnikResume
AnikResume
 
IRJET- Conversational Commerce (ESTILO)
IRJET- Conversational Commerce (ESTILO)IRJET- Conversational Commerce (ESTILO)
IRJET- Conversational Commerce (ESTILO)
 
IRJET- Design of Closed Loop PI Controller Based Hybrid Z-Source DC-DC Conver...
IRJET- Design of Closed Loop PI Controller Based Hybrid Z-Source DC-DC Conver...IRJET- Design of Closed Loop PI Controller Based Hybrid Z-Source DC-DC Conver...
IRJET- Design of Closed Loop PI Controller Based Hybrid Z-Source DC-DC Conver...
 
Job portal
Job portalJob portal
Job portal
 
127801976 mobile-shop-management-system-documentation
127801976 mobile-shop-management-system-documentation127801976 mobile-shop-management-system-documentation
127801976 mobile-shop-management-system-documentation
 
1.Design Modelling for Web Apps.pdf software engineering
1.Design Modelling for Web Apps.pdf software engineering1.Design Modelling for Web Apps.pdf software engineering
1.Design Modelling for Web Apps.pdf software engineering
 
SathishKumar Natarajan
SathishKumar NatarajanSathishKumar Natarajan
SathishKumar Natarajan
 
Web Based Investment Management System
Web Based Investment Management SystemWeb Based Investment Management System
Web Based Investment Management System
 
System analysis and design
System analysis and designSystem analysis and design
System analysis and design
 
Over view of software artitecture
Over view of software artitectureOver view of software artitecture
Over view of software artitecture
 
Project report
Project report Project report
Project report
 
icv
icvicv
icv
 
Building Bridges: Merging RPA Processes, UiPath Apps, and Data Service to bu...
Building Bridges:  Merging RPA Processes, UiPath Apps, and Data Service to bu...Building Bridges:  Merging RPA Processes, UiPath Apps, and Data Service to bu...
Building Bridges: Merging RPA Processes, UiPath Apps, and Data Service to bu...
 
Research Inventy : International Journal of Engineering and Science
Research Inventy : International Journal of Engineering and ScienceResearch Inventy : International Journal of Engineering and Science
Research Inventy : International Journal of Engineering and Science
 
Super applied in a sitecore migration project
Super applied in a sitecore migration projectSuper applied in a sitecore migration project
Super applied in a sitecore migration project
 
Case Study For Web Based Application for Rent or Sale
Case Study For Web Based Application for Rent or SaleCase Study For Web Based Application for Rent or Sale
Case Study For Web Based Application for Rent or Sale
 
Rich Internet Applications
Rich Internet ApplicationsRich Internet Applications
Rich Internet Applications
 

Último

SKILL OF INTRODUCING THE LESSON MICRO SKILLS.pptx
SKILL OF INTRODUCING THE LESSON MICRO SKILLS.pptxSKILL OF INTRODUCING THE LESSON MICRO SKILLS.pptx
SKILL OF INTRODUCING THE LESSON MICRO SKILLS.pptxAmanpreet Kaur
 
Graduate Outcomes Presentation Slides - English
Graduate Outcomes Presentation Slides - EnglishGraduate Outcomes Presentation Slides - English
Graduate Outcomes Presentation Slides - Englishneillewis46
 
Accessible Digital Futures project (20/03/2024)
Accessible Digital Futures project (20/03/2024)Accessible Digital Futures project (20/03/2024)
Accessible Digital Futures project (20/03/2024)Jisc
 
Beyond_Borders_Understanding_Anime_and_Manga_Fandom_A_Comprehensive_Audience_...
Beyond_Borders_Understanding_Anime_and_Manga_Fandom_A_Comprehensive_Audience_...Beyond_Borders_Understanding_Anime_and_Manga_Fandom_A_Comprehensive_Audience_...
Beyond_Borders_Understanding_Anime_and_Manga_Fandom_A_Comprehensive_Audience_...Pooja Bhuva
 
This PowerPoint helps students to consider the concept of infinity.
This PowerPoint helps students to consider the concept of infinity.This PowerPoint helps students to consider the concept of infinity.
This PowerPoint helps students to consider the concept of infinity.christianmathematics
 
Unit 3 Emotional Intelligence and Spiritual Intelligence.pdf
Unit 3 Emotional Intelligence and Spiritual Intelligence.pdfUnit 3 Emotional Intelligence and Spiritual Intelligence.pdf
Unit 3 Emotional Intelligence and Spiritual Intelligence.pdfDr Vijay Vishwakarma
 
Sociology 101 Demonstration of Learning Exhibit
Sociology 101 Demonstration of Learning ExhibitSociology 101 Demonstration of Learning Exhibit
Sociology 101 Demonstration of Learning Exhibitjbellavia9
 
Micro-Scholarship, What it is, How can it help me.pdf
Micro-Scholarship, What it is, How can it help me.pdfMicro-Scholarship, What it is, How can it help me.pdf
Micro-Scholarship, What it is, How can it help me.pdfPoh-Sun Goh
 
ICT Role in 21st Century Education & its Challenges.pptx
ICT Role in 21st Century Education & its Challenges.pptxICT Role in 21st Century Education & its Challenges.pptx
ICT Role in 21st Century Education & its Challenges.pptxAreebaZafar22
 
On National Teacher Day, meet the 2024-25 Kenan Fellows
On National Teacher Day, meet the 2024-25 Kenan FellowsOn National Teacher Day, meet the 2024-25 Kenan Fellows
On National Teacher Day, meet the 2024-25 Kenan FellowsMebane Rash
 
Sensory_Experience_and_Emotional_Resonance_in_Gabriel_Okaras_The_Piano_and_Th...
Sensory_Experience_and_Emotional_Resonance_in_Gabriel_Okaras_The_Piano_and_Th...Sensory_Experience_and_Emotional_Resonance_in_Gabriel_Okaras_The_Piano_and_Th...
Sensory_Experience_and_Emotional_Resonance_in_Gabriel_Okaras_The_Piano_and_Th...Pooja Bhuva
 
Food safety_Challenges food safety laboratories_.pdf
Food safety_Challenges food safety laboratories_.pdfFood safety_Challenges food safety laboratories_.pdf
Food safety_Challenges food safety laboratories_.pdfSherif Taha
 
The basics of sentences session 3pptx.pptx
The basics of sentences session 3pptx.pptxThe basics of sentences session 3pptx.pptx
The basics of sentences session 3pptx.pptxheathfieldcps1
 
General Principles of Intellectual Property: Concepts of Intellectual Proper...
General Principles of Intellectual Property: Concepts of Intellectual  Proper...General Principles of Intellectual Property: Concepts of Intellectual  Proper...
General Principles of Intellectual Property: Concepts of Intellectual Proper...Poonam Aher Patil
 
Single or Multiple melodic lines structure
Single or Multiple melodic lines structureSingle or Multiple melodic lines structure
Single or Multiple melodic lines structuredhanjurrannsibayan2
 
Fostering Friendships - Enhancing Social Bonds in the Classroom
Fostering Friendships - Enhancing Social Bonds  in the ClassroomFostering Friendships - Enhancing Social Bonds  in the Classroom
Fostering Friendships - Enhancing Social Bonds in the ClassroomPooky Knightsmith
 
How to Give a Domain for a Field in Odoo 17
How to Give a Domain for a Field in Odoo 17How to Give a Domain for a Field in Odoo 17
How to Give a Domain for a Field in Odoo 17Celine George
 
HMCS Vancouver Pre-Deployment Brief - May 2024 (Web Version).pptx
HMCS Vancouver Pre-Deployment Brief - May 2024 (Web Version).pptxHMCS Vancouver Pre-Deployment Brief - May 2024 (Web Version).pptx
HMCS Vancouver Pre-Deployment Brief - May 2024 (Web Version).pptxmarlenawright1
 

Último (20)

SKILL OF INTRODUCING THE LESSON MICRO SKILLS.pptx
SKILL OF INTRODUCING THE LESSON MICRO SKILLS.pptxSKILL OF INTRODUCING THE LESSON MICRO SKILLS.pptx
SKILL OF INTRODUCING THE LESSON MICRO SKILLS.pptx
 
Graduate Outcomes Presentation Slides - English
Graduate Outcomes Presentation Slides - EnglishGraduate Outcomes Presentation Slides - English
Graduate Outcomes Presentation Slides - English
 
Accessible Digital Futures project (20/03/2024)
Accessible Digital Futures project (20/03/2024)Accessible Digital Futures project (20/03/2024)
Accessible Digital Futures project (20/03/2024)
 
Beyond_Borders_Understanding_Anime_and_Manga_Fandom_A_Comprehensive_Audience_...
Beyond_Borders_Understanding_Anime_and_Manga_Fandom_A_Comprehensive_Audience_...Beyond_Borders_Understanding_Anime_and_Manga_Fandom_A_Comprehensive_Audience_...
Beyond_Borders_Understanding_Anime_and_Manga_Fandom_A_Comprehensive_Audience_...
 
This PowerPoint helps students to consider the concept of infinity.
This PowerPoint helps students to consider the concept of infinity.This PowerPoint helps students to consider the concept of infinity.
This PowerPoint helps students to consider the concept of infinity.
 
Unit 3 Emotional Intelligence and Spiritual Intelligence.pdf
Unit 3 Emotional Intelligence and Spiritual Intelligence.pdfUnit 3 Emotional Intelligence and Spiritual Intelligence.pdf
Unit 3 Emotional Intelligence and Spiritual Intelligence.pdf
 
Sociology 101 Demonstration of Learning Exhibit
Sociology 101 Demonstration of Learning ExhibitSociology 101 Demonstration of Learning Exhibit
Sociology 101 Demonstration of Learning Exhibit
 
Micro-Scholarship, What it is, How can it help me.pdf
Micro-Scholarship, What it is, How can it help me.pdfMicro-Scholarship, What it is, How can it help me.pdf
Micro-Scholarship, What it is, How can it help me.pdf
 
ICT Role in 21st Century Education & its Challenges.pptx
ICT Role in 21st Century Education & its Challenges.pptxICT Role in 21st Century Education & its Challenges.pptx
ICT Role in 21st Century Education & its Challenges.pptx
 
Mehran University Newsletter Vol-X, Issue-I, 2024
Mehran University Newsletter Vol-X, Issue-I, 2024Mehran University Newsletter Vol-X, Issue-I, 2024
Mehran University Newsletter Vol-X, Issue-I, 2024
 
On National Teacher Day, meet the 2024-25 Kenan Fellows
On National Teacher Day, meet the 2024-25 Kenan FellowsOn National Teacher Day, meet the 2024-25 Kenan Fellows
On National Teacher Day, meet the 2024-25 Kenan Fellows
 
Sensory_Experience_and_Emotional_Resonance_in_Gabriel_Okaras_The_Piano_and_Th...
Sensory_Experience_and_Emotional_Resonance_in_Gabriel_Okaras_The_Piano_and_Th...Sensory_Experience_and_Emotional_Resonance_in_Gabriel_Okaras_The_Piano_and_Th...
Sensory_Experience_and_Emotional_Resonance_in_Gabriel_Okaras_The_Piano_and_Th...
 
Food safety_Challenges food safety laboratories_.pdf
Food safety_Challenges food safety laboratories_.pdfFood safety_Challenges food safety laboratories_.pdf
Food safety_Challenges food safety laboratories_.pdf
 
The basics of sentences session 3pptx.pptx
The basics of sentences session 3pptx.pptxThe basics of sentences session 3pptx.pptx
The basics of sentences session 3pptx.pptx
 
General Principles of Intellectual Property: Concepts of Intellectual Proper...
General Principles of Intellectual Property: Concepts of Intellectual  Proper...General Principles of Intellectual Property: Concepts of Intellectual  Proper...
General Principles of Intellectual Property: Concepts of Intellectual Proper...
 
Single or Multiple melodic lines structure
Single or Multiple melodic lines structureSingle or Multiple melodic lines structure
Single or Multiple melodic lines structure
 
Spatium Project Simulation student brief
Spatium Project Simulation student briefSpatium Project Simulation student brief
Spatium Project Simulation student brief
 
Fostering Friendships - Enhancing Social Bonds in the Classroom
Fostering Friendships - Enhancing Social Bonds  in the ClassroomFostering Friendships - Enhancing Social Bonds  in the Classroom
Fostering Friendships - Enhancing Social Bonds in the Classroom
 
How to Give a Domain for a Field in Odoo 17
How to Give a Domain for a Field in Odoo 17How to Give a Domain for a Field in Odoo 17
How to Give a Domain for a Field in Odoo 17
 
HMCS Vancouver Pre-Deployment Brief - May 2024 (Web Version).pptx
HMCS Vancouver Pre-Deployment Brief - May 2024 (Web Version).pptxHMCS Vancouver Pre-Deployment Brief - May 2024 (Web Version).pptx
HMCS Vancouver Pre-Deployment Brief - May 2024 (Web Version).pptx
 

Web engineering

  • 1. 1 Web Engineering A presentation by Athul Sai(P3MCA12012) Sreejith S(P3MCA12036)
  • 2. 2 Web Applicat ions  WebApps encompass:  complete Web sites  Simple information Web sites  Complex e-Commerce of other sites with embedded functionality and data retrieval  Complex Web sites that are interoperable with other legacy software and systems  specialized functionality within Web sites  information processing applications that reside on the Internet or on an intranet or ExtraNet.
  • 3. 3 WebApp At t ribut es—I  Network intensiveness. A WebApp resides on a network and must serve the needs of a diverse community of clients.  Concurrency. A large number of users may access the WebApp at one time; patterns of usage among end-users will vary greatly.  Unpredictable load. The number of users of the WebApp may vary by orders of magnitude from day to day.  Performance. If a WebApp user must wait too long (for access, for server-side processing, for client-side formatting and display), he or she may decide to go elsewhere.
  • 4. 4 WebApp At t ribut es—I I  Availability. Although expectation of 100 percent availability is unreasonable, users of popular WebApps often demand access on a “24/7/365” basis.  Data driven. The primary function of many WebApps is to use hypermedia to present text, graphics, audio, and video content to the end-user.  Content sensitive. The quality and aesthetic nature of content remains an important determinant of the quality of a WebApp.  Continuous evolution. Unlike conventional application software that evolves over a series of planned, chronologically-spaced releases, Web applications evolve continuously.
  • 5. 5 WebApp At t ribut es—I I I  Immediacy. WebApps often exhibit a time to market that can be a matter of a few days or weeks.  With modern tools, sophisticated Web pages can be produced in only a few hours.  Security. In order to protect sensitive content and provide secure modes of data transmission, strong security measures must be implemented throughout the infrastructure that supports a WebApp and within the application itself.  Aesthetics. When an application has been designed to market or sell products or ideas, aesthetics may have as much to do with success as technical design.
  • 6. 6 WebApp Cat egories  informational—read-only content is provided with simple navigation and links  download—a user downloads information from the appropriate server  customizable—the user customizes content to specific needs  interaction—communication among a community of users occurs via chatroom, bulletin boards, or instant messaging  user input—forms-based input is the primary mechanism for communicating need  transaction-oriented—the user makes a request (e.g., places an order) that is fulfilled by the WebApp  service-oriented—the application provides a service to the user, e.g., assists the user in determining a mortgage payment  Portal—the application channels the user to other Web content or services outside the domain of the portal application  database access—the user queries a large database and extracts information  data warehousing—the user queries a collection of large databases and extracts information
  • 8. 8 The WebE Process  Must accommodate:  Incremental delivery  Frequent changes  Short timeline  Therefore,  An incremental process model should be used in virtually all situations  An agile process model is appropriate in many situations
  • 9. 9 The WebE Process sof t ware increment Release refact oring business analysis formulat ion it erat ion plan analysis model content iteration function configuration design model content architecture navigation interface coding component t est accept ance t est cust omer use cust omer evaluat ion
  • 10. 10 The WebE Process Framework—I  Customer communication  Business analysis defines the business/organizational context for the WebApp.  Formulation is a requirements gathering activity involving all stakeholders. The intent is to describe the problem that the WebApp is to solve  Planning  The “plan” consists of a task definition and a timeline schedule for the time period (usually measured in weeks) projected for the development of the WebApp increment.
  • 11. 11 The WebE Process Framework—I I  Modeling  Analysis model—establishes a basis for design  Content Analysis.  Interaction Analysis.  Functional Analysis.  Configuration Analysis.  Design model—represents key WebApp elements  Content design  Aesthetic design  Architectural design  Interface design  Navigation design  Component design
  • 12. 12 The WebE Process Framework—I I I  Construction  WebE tools and technology are applied to construct the WebApp that has been modeled  Testing of all design elements  Delivery and Evaluation (Deployment)  configure for its operational environment  deliver to end-users, and  Evaluation feedback is presented to the WebE team  the increment is modified as required (the beginning of the next incremental cycle)
  • 13. 13 WebE—Best Pract ices  Take the time to understand the business needs and product objectives, even if the details of the WebApp are vague.  Describe how users will interact with the WebApp using a scenario-based approach  Develop a project plan, even it its very brief.  Spend some time modeling what it is that you’re going to build.  Review the models for consistency and quality.  Use tools and technology that enable you to construct the system with as many reusable components as possible.  Don’t rely on early users to debug the WebApp—design comprehensive tests and execute them before releasing the system.
  • 15. 15 Analysis  Content Analysis. The full spectrum of content to be provided by the WebApp is identified, including text, graphics and images, video, and audio data. Data modeling can be used to identify and describe each of the data objects.  Interaction Analysis. The manner in which the user interacts with the WebApp is described in detail. Use-cases can be developed to provide detailed descriptions of this interaction.  Functional Analysis. The usage scenarios (use-cases) created as part of interaction analysis define the operations that will be applied to WebApp content and imply other processing functions. All operations and functions are described in detail.  Configuration Analysis. The environment and infrastructure in which the WebApp resides are described in detail.
  • 16. 16 When Do We Perf orm Analysis?  In some WebE situations, analysis and design merge. However, an explicit analysis activity occurs when …  the WebApp to be built is large and/or complex  the number of stakeholders is large  the number of Web engineers and other contributors is large  the goals and objectives (determined during formulation) for the WebApp will effect the business’ bottom line  the success of the WebApp will have a strong bearing on the success of the business
  • 17. 17 The User Hierarchy SafeHomeAssured.com user Figure 18.1 User hierarchy for SafeHomeAssured.com guest regist ered user cust omer service st aff exist ing cust omernew cust omer
  • 18. 18 Use-Case Diagram Figure 18.2 Use-case diagram f or new-cust omer new customer log-in to SafeHomeAssured.com customize SafeHome describe home layout select SafeHome components save configuration purchase conf iguration view shopping cart provide purchase data recall saved configuration peruse descriptive content complete SafeHome order customization functionality e-commerce functionality <<inc lude>> <<inc lude>> <<inc lude>> <<inc lude>> <<inc lude>> <<inc lude>>
  • 19. 19 The Cont ent Model  Content objects are extracted from use-cases  examine the scenario description for direct and indirect references to content  Attributes of each content object are identified  The relationships among content objects and/or the hierarchy of content maintained by a WebApp  Relationships—entity-relationship diagram or UML  Hierarchy—data tree or UML
  • 20. 20 Dat a Tree Figure 1 8 .3 Dat a t ree for aSafeHom e com ponent component part Number part Name part Type description price MarketingDescript ion Phot ograph TechDescript ion Schemat ic Video WholesalePrice Ret ailPrice
  • 21. 21 Analysis Classes  Analysis classes are derived by examining each use-case  A grammatical parse is used to identify candidate classes  A UML class diagram is developed for each analysis class
  • 22. 22 Analysis Class Example Figure 18.4 Analysis classes for use-case: select SafeHomecomponents BillOfMat erials ident ifier priceTot al addEnt ry( ) delet eEnt ry( ) edit Ent ry( ) name( ) save( ) comput ePrice( ) Product Component part Number part Name part Type descript ion price creat eNewIt em( ) get Descript ion( ) get TechSpec BoMIt em quant it y price addt oList( ) delet efromList( ) Sensor Camera Cont rolPanel Soft Feat ure 1 * 1 *
  • 23. 23 The I nt eract ion Model  Composed of four elements:  use-cases  sequence diagrams  state diagrams  a user interface prototype  Each of these is an important UML notation
  • 24. 24 Sequence Diagram Figure 18.5 Sequence diagram for use-case:select SafeHomecomponents new cust omer :Room :FloorPlan desc ribes room * plac es room in f loor plan :Product Component selec t s produc t c om ponent * :Billof Mat erials add t o BoM FloorPlan Reposit ory sav e f loor plan c onf igurat ion sav e bill of m at erials BoM Reposit ory
  • 25. 25 St at e Diagram Figure 1 8 .6 Part ial st at e diagram for ne w c ust ome rinteract ion n e w cu st o m e r Validating user system status=“input ready” displaymsg = “enteruserid” displaymsg =“enterpswd” entry/ log-in requested do: run user validation exit/set user access switch select “log-in” userid validated password validated Selecting user action system status=“link ready” display: navigation choices” entry/ validated user do: link as required exit/user action selected select other functions select customization functionality select e-commerce (purchase) functionality Customizing system status=“input ready” display: basic instructions entry/validated user do: process user selection exit/ customization terminated select descriptive content room being defined Defining room system status=“input ready” display: roomdef. window entry/ roomdef.selected do: run room queries do: store room variables exit/room completed select descriptive content Building floor plan system status=“input ready” display: floor plan window entry/ floor plan selected do: insert room in place do: store floor plan variables exit/room insertion completed select descriptive content select enter room in floor plan Saving floor plan system status=“input ready” display: storage indicator entry/ floor plan save selected do: store floor plan exit/save completed select save floor plan room insertion completed next selection customization complete all rooms defined
  • 26. 26 The Funct ional Model  The functional model addresses two processing elements of the WebApp  user observable functionality that is delivered by the WebApp to end-users  the operations contained within analysis classes that implement behaviors associated with the class.  An activity diagram can be used to represent processing flow
  • 27. 27 Act ivit y Diagram Figure 1 8 .7 Act ivit y diagram f or c omput e Pr i c e( ) ope r a t i on init ialize t ot alCost invoke calcShippingCost get price and quant it y components remain onBoMList invoke det ermineDiscount discount < = 0 discount>0 t ot alCost= t ot alCost - discount t axTot al= t ot alCost x t axrat e no components remain onBoMList lineCost = price x quant it y add lineCost t o t ot alCost priceTot al = t ot alCost + t axTot al + shippingCost ret urns: shippingCost ret urns: discount
  • 28. 28 The Conf igurat ion Model  Server-side  Server hardware and operating system environment must be specified  Interoperability considerations on the server-side must be considered  Appropriate interfaces, communication protocols and related collaborative information must be specified  Client-side  Browser configuration issues must be identified  Testing requirements should be defined
  • 29. 29 Relat ionship-Navigat ion Analysis  Relationship-navigation analysis (RNA) identifies relationships among the elements uncovered as part of the creation of the analysis model  Steps:  Stakeholder analysis—identifies the various user categories and establishes an appropriate stakeholder hierarchy  Element analysis—identifies the content objects and functional elements that are of interest to end users  Relationship analysis—describes the relationships that exist among the WebApp elements  Navigation analysis—examines how users might access individual elements or groups of elements  Evaluation analysis—considers pragmatic issues (e.g., cost/benefit) associated with implementing the relationships defined earlier
  • 30. 30 Navigat ion Analysis-I  Should certain elements be easier to reach (require fewer navigation steps) than others? What is the priority for presentation?  Should certain elements be emphasized to force users to navigate in their direction?  How should navigation errors be handled?  Should navigation to related groups of elements be given priority over navigation to a specific element.  Should navigation be accomplished via links, via search-based access, or by some other means?  Should certain elements be presented to users based on the context of previous navigation actions?  Should a navigation log be maintained for users?
  • 31. 31 Navigat ion Analysis-I I  Should a full navigation map or menu (as opposed to a single “back” link or directed pointer) be available at every point in a user’s interaction?  Should navigation design be driven by the most commonly expected user behaviors or by the perceived importance of the defined WebApp elements?  Can a user “store” his previous navigation through the WebApp to expedite future usage?  For which user category should optimal navigation be designed?  How should links external to the WebApp be handled? overlaying the existing browser window? as a new browser window? as a separate frame?