Web Technology PDF

Download as pdf or txt
Download as pdf or txt
You are on page 1of 812

SUBJECT CODE : 310252

As per Revised Syllabus of

Savitribai Phule Pune University


Choice Based Credit System (CBCS)
T.E. (Computer Engineering) Semester - VI

Web Technology

Mrs. Anuradha A. Puntambekar


M.E. (Computer)
Formerly Assistant Professor in
P.E.S. Modern College of Engineering,
Pune.

® ®
TECHNICAL
PUBLICATIONS
SINCE 1993 An Up-Thrust for Knowledge

(i)
Web Technology
Subject Code : 310252

T.E. (Computer Engineering) Semester - VI

ã Copyright with Author


All publishing rights (printed and ebook version) reserved with Technical Publications. No part of this book
should be reproduced in any form, Electronic, Mechanical, Photocopy or any information storage and
retrieval system without prior permission in writing, from Technical Publications, Pune.

Published by :
® ® Amit Residency, Office No.1, 412, Shaniwar Peth,
TECHNICAL Pune - 411030, M.S. INDIA Ph.: +91-020-24495496/97
PUBLICATIONS
SINCE 1993 An Up-Thrust for Knowledge Email : [email protected] Website : www.technicalpublications.org

Printer :
Yogiraj Printers & Binders
Sr. No. 10/1A,
Ghule Industrial Estate, Nanded Village Road,
Tal. - Haveli, Dist. - Pune - 411041.

ISBN 978-93-91567-28-6

9 789391 567286 SPPU 19

9789391567286 [1] (ii)


Preface
The importance of Web Technology is well known in various engineering fields.
Overwhelming response to my books on various subjects inspired me to write this book. The
book is structured to cover the key aspects of the subject Web Technology.
The book uses plain, lucid language to explain fundamentals of this subject. The book
provides logical method of explaining various complicated concepts and stepwise methods
to explain the important topics. Each chapter is well supported with necessary illustrations,
practical examples and solved problems. All the chapters in the book are arranged in a
proper sequence that permits each topic to build upon earlier studies. All care has been
taken to make students comfortable in understanding the basic concepts of the subject.
Representative questions have been added at the end of each section to help the
students in picking important points from that section.
The book not only covers the entire scope of the subject but explains the philosophy of
the subject. This makes the understanding of this subject more clear and makes it more
interesting. The book will be very useful not only to the students but also to the subject
teachers. The students have to omit nothing and possibly have to cover nothing more.
I wish to express my profound thanks to all those who helped in making this book a
reality. Much needed moral support and encouragement is provided on numerous
occasions by my whole family. I wish to thank the Publisher and the entire team of
Technical Publications who have taken immense pain to get this book in time with quality
printing.
Any suggestion for the improvement of the book will be acknowledged and well
appreciated.

Author
A. A. Puntambekar

Dedicated to God

(iii)
Syllabus
Web Technology - (310252)
Credit : Examination Scheme :

Mid-Sem (TH) : 30 Marks


03
End-Sem (TH) : 70 Marks

Unit I Web Essentials and Mark-up language - HTML


The Internet, basic internet protocols, the World Wide Web, HTTP Request message, HTTP
response message, web clients, web servers. HTML : Introduction, history and versions.
HTML elements : headings, paragraphs, line break, colors and fonts, links, frames, lists,
tables, images and forms, Difference between HTML and HTML5. CSS : Introduction to
Style Sheet, CSS features, CSS core syntax, Style sheets and HTML, Style rule cascading
and inheritance, text properties. Bootstrap. (Chapter - 1)

Unit II Client Side Technologies : JavaScript and DOM


JavaScript : Introduction to JavaScript, JavaScript in perspective, basic syntax, variables
and data types, statements, operators, literals, functions, objects, arrays, built in objects,
JavaScript debuggers. DOM : Introduction to Document Object Model, DOM history and
levels, intrinsic event handling, modifying element style, the document tree, DOM event
handling, jQuery, Overview of Angular JS. (Chapter - 2)

Unit III Java Servlets and XML


Servlet : Servlet architecture overview, A “Hello World” servlet, Servlets generating
dynamic content, Servlet life cycle, parameter data, sessions, cookies, URL rewriting, other
Servlet capabilities, data storage, Servlets concurrency, databases (MySQL) and Java
Servlets. XML : XML documents and vocabularies, XML declaration, XML Namespaces,
DOM based XML processing, transforming XML documents, DTD : Schema, elements,
attributes. AJAX : Introduction, Working of AJAX. (Chapter - 3)

Unit IV JSP and Web Services


JSP : Introduction to Java Server Pages, JSP and Servlets, running JSP applications, Basic
JSP, JavaBeans classes and JSP, Support for the Model-View-Controller paradigm, JSP
related technologies. Web Services : Web Service concepts, Writing a Java Web Service,
Writing a Java web service client, Describing Web Services : WSDL, Communicating
Object data : SOAP. Struts : Overview, architecture, configuration, actions, interceptors,
result types, validations, localization, exception handling, annotations. (Chapter - 4)

(iv)
Unit V Server Side Scripting Languages
PHP : Introduction to PHP, uses of PHP, general syntactic characteristics, Primitives,
operations and expressions, output, control statements, arrays, functions, pattern matching,
form handling, files, cookies, session tracking, using MySQL with PHP, WAP and WML.
Introduction to ASP.NET : Overview of the .NET Framework, Overview of C#,
Introduction to ASP.NET, ASP.NET Controls, Web Services. Overview of Node JS.
(Chapter - 5)

Unit VI Ruby and Rails


Introduction to Ruby : Origins & uses of Ruby, scalar types and their operations, simple
input and output, control statements, fundamentals of arrays, hashes, methods, classes, code
blocks and iterators, pattern matching. Introduction to Rails : Overview of Rails,
Document Requests, Processing Forms, Rails Applications and Databases, Layouts, Rails
with Ajax. Introduction to EJB. (Chapter - 6)

(v)
Table of Contents
Unit - I
Chapter - 1 Web Essentials and Mark - up Language - HTML
(1 - 1) to (1 - 146)
Part I : Web Essentials
1.1 Basic Concepts ................................................................................................. 1 - 3
1.1.1 What is Web Technology ? ................................................................................ 1 - 3
1.1.2 Concept of Internet ........................................................................................... 1 - 3
1.1.3 Concept of World Wide Web............................................................................. 1 - 3
1.1.4 Internet or WWW ? ........................................................................................... 1 - 4

1.2 Basic Internet Protocol .................................................................................... 1 - 4


1.3 The Web Site Design Issues ............................................................................. 1 - 6
1.3.1 Browser Compatibility Issues ............................................................................ 1 - 8
1.3.2 Bandwidth.......................................................................................................... 1 - 8
1.3.3 Cache ................................................................................................................. 1 - 8

1.4 HTTP Request Message and Response Message ............................................. 1 - 9


1.5 Features of HTTP Protocol ............................................................................. 1 - 14
1.6 Web Clients .................................................................................................... 1 - 14
1.6.1 Functions Defined by Web Browser ................................................................ 1 - 15
1.6.2 URL................................................................................................................... 1 - 16

1.7 Web Servers ................................................................................................... 1 - 17


1.7.1 Apache ............................................................................................................. 1 - 18
1.7.2 IIS ..................................................................................................................... 1 - 18

1.8 Client Sever Communication ......................................................................... 1 - 20


Part II : HTML
1.9 Introduction ................................................................................................... 1 - 22

(vi)
1.10 History and Versions .................................................................................... 1 - 23
1.11 Structure of HTML ....................................................................................... 1 - 24
1.12 HTML Elements ............................................................................................ 1 - 25
1.12.1 Heading .......................................................................................................... 1 - 25
1.12.2 Paragraphs ..................................................................................................... 1 - 26
1.12.3 Line Break ...................................................................................................... 1 - 27
1.12.4 Setting Font Style ........................................................................................... 1 - 28
1.12.5 Text Alignment .............................................................................................. 1 - 29
1.12.6 Setting the Font and Color............................................................................. 1 - 30
1.12.7 Special Character ........................................................................................... 1 - 34

1.13 Links ............................................................................................................. 1 - 36


1.13.1 Playing an Audio File...................................................................................... 1 - 39
1.13.2 Uses of Links .................................................................................................. 1 - 40

1.14 Frames ......................................................................................................... 1 - 41


1.14.1 Frames with Scrollbars .................................................................................. 1 - 44

1.15 Lists .............................................................................................................. 1 - 49


1.15.1 Unordered List ............................................................................................... 1 - 50
1.15.2 Ordered List ................................................................................................... 1 - 51

1.16 Tables ........................................................................................................... 1 - 54


1.16.1 Basic Table Structure ..................................................................................... 1 - 55
1.16.2 RowSpan and ColSpan ................................................................................... 1 - 58
1.16.3 Additional Table Elements ............................................................................. 1 - 68

1.17 Images .......................................................................................................... 1 - 72


1.18 Forms ........................................................................................................... 1 - 73
1.18.1 Text ................................................................................................................ 1 - 74
1.18.2 Text Area........................................................................................................ 1 - 76
1.18.3 Checkbox ....................................................................................................... 1 - 77
1.18.4 Radio Button .................................................................................................. 1 - 78
1.18.5 Button ............................................................................................................ 1 - 79

(vii)
1.18.6 Menus ............................................................................................................ 1 - 81

1.19 HTML5 .......................................................................................................... 1 - 86


1.19.1 Features of HTML 5.0 .................................................................................... 1 - 86
1.19.2 Difference between HTML and HTML5 ......................................................... 1 - 87

Part III : CSS

1.20 Introduction to Style Sheet .......................................................................... 1 - 88


1.21 CSS Features ................................................................................................ 1 - 88
1.22 CSS Core Syntax ........................................................................................... 1 - 88
1.23 Selector ........................................................................................................ 1 - 91
1.23.1 Simple Selector Form..................................................................................... 1 - 91
1.23.2 Class Selectors ............................................................................................... 1 - 92
1.23.3 Generic Selectors ........................................................................................... 1 - 94
1.23.4 Id Selectors .................................................................................................... 1 - 96
1.23.5 Universal Selectors ........................................................................................ 1 - 97
1.23.6 Attribute Selector .......................................................................................... 1 - 98
1.23.7 Pseudo Classes............................................................................................... 1 - 99
1.23.8 Contextual Selector ..................................................................................... 1 - 101

1.24 Style Sheets and HTML .............................................................................. 1 - 102


1.24.1 Inline Style Sheet ......................................................................................... 1 - 102
1.24.2 Document Level Style Sheet ........................................................................ 1 - 104
1.24.3 External Stylesheet ...................................................................................... 1 - 106

1.25 Style Rule Cascading and Inheritance ........................................................ 1 - 108


1.25.1 Style Rule Cascading .................................................................................... 1 - 108
1.25.2 Inheritance................................................................................................... 1 - 110

1.26 Text Properties........................................................................................... 1 - 113


1.26.1 Font Families................................................................................................ 1 - 113
1.26.2 Font Sizes ..................................................................................................... 1 - 115
1.26.3 Font Variants ............................................................................................... 1 - 116
1.26.4 Font Styles ................................................................................................... 1 - 116

(viii)
1.26.5 Font Weights ............................................................................................... 1 - 117
1.26.6 Font Shorthands .......................................................................................... 1 - 118
1.26.7 Text Decoration ........................................................................................... 1 - 119
1.26.8 Alignment of Text ........................................................................................ 1 - 120

1.27 Bootstrap ................................................................................................... 1 - 123


1.27.1 Grid System.................................................................................................. 1 - 126
1.27.2 Typography .................................................................................................. 1 - 128
1.27.3 Tables........................................................................................................... 1 - 134
1.27.4 Images.......................................................................................................... 1 - 135
1.27.5 Button .......................................................................................................... 1 - 136
1.27.6 Form............................................................................................................. 1 - 138

1.28 Multiple Choice Questions with Answers .................................................. 1 - 143


Unit - II
Chapter - 2 Client Side Technologies : JavaScript and DOM
(2 - 1) to (2 - 174)
Part I : JavaScript
2.1 Introduction to JavaScript................................................................................ 2 - 3
2.1.1 Difference between Java and JavaScript ........................................................... 2 - 3

2.2 JavaScript in Perspective ................................................................................. 2 - 3


2.3 Basic Syntax ..................................................................................................... 2 - 4
2.4 Identifiers, Keywords and Comments ............................................................. 2 - 7
2.5 Data Types ....................................................................................................... 2 - 7
2.6 Literals.............................................................................................................. 2 - 8
2.7 Other Primitive Types ...................................................................................... 2 - 9
2.8 Variables .......................................................................................................... 2 - 9
2.9 Operators ....................................................................................................... 2 - 10
2.10 Input and Output ......................................................................................... 2 - 12
2.10.1 The document.write ..................................................................................... 2 - 12

(ix)
2.11 Statements ................................................................................................... 2 - 12
2.11.1 If Statement ................................................................................................... 2 - 12
2.11.2 Switch Statement .......................................................................................... 2 - 15
2.11.3 Loop Statement ............................................................................................. 2 - 17
2.11.3.1 while Loop .................................................................................................. 2 - 17
2.11.3.2 do..while Loop ............................................................................................ 2 - 18
2.11.3.3 for Loop ...................................................................................................... 2 - 19
2.11.3.4 break Statement ......................................................................................... 2 - 20
2.11.3.5 The continue Statement ............................................................................. 2 - 21

2.12 Querying and Handling Properties .............................................................. 2 - 22


2.13 Functions...................................................................................................... 2 - 28
2.13.1 Defining a Function ........................................................................................ 2 - 29
2.13.2 Writing a Function ......................................................................................... 2 - 29
2.13.3 Adding an Arguments .................................................................................... 2 - 30
2.13.4 Scope of Variable and Argument ................................................................... 2 - 30
2.13.5 Calling a Function from with Argument......................................................... 2 - 33
2.13.6 Calling a Function without an Argument ....................................................... 2 - 34
2.13.7 Calling a Function from HTML ....................................................................... 2 - 35
2.13.8 Function Calling another Function................................................................. 2 - 36
2.13.9 Returning a Value from Function................................................................... 2 - 37

2.14 Built in Objects ............................................................................................. 2 - 38


2.14.1 Math Objects ................................................................................................. 2 - 38
2.14.2 Number Objects............................................................................................. 2 - 40
2.14.3 Date Objects .................................................................................................. 2 - 41
2.14.4 Boolean Objects............................................................................................. 2 - 43
2.14.5 String Objects................................................................................................. 2 - 44

2.15 Creation of Object........................................................................................ 2 - 46


2.16 Arrays ........................................................................................................... 2 - 48
2.16.1 Declaring an Array ......................................................................................... 2 - 48

(x)
2.16.2 Initializing an Array ........................................................................................ 2 - 49
2.16.3 Defining an Array Elements ........................................................................... 2 - 49
2.16.4 Looping an Array............................................................................................ 2 - 52
2.16.5 Adding an Array Element ............................................................................... 2 - 53
2.16.6 Sorting an Array Element ............................................................................... 2 - 54
2.16.7 Combining Array Elements into String........................................................... 2 - 56
2.16.8 Changing Elements of an Array ..................................................................... 2 - 57

2.17 Strings .......................................................................................................... 2 - 62


2.17.1 Manipulating a String .................................................................................... 2 - 62
2.17.2 Joining a String............................................................................................... 2 - 63
2.17.3 Receiving a Character from Given Position ................................................... 2 - 63
2.17.4 Retrieving a Position of Character in a String ................................................ 2 - 64
2.17.5 Dividing Text .................................................................................................. 2 - 65
2.17.6 Copying a Substring ....................................................................................... 2 - 66
2.17.7 Converting String to Number and Number to String ..................................... 2 - 68
2.17.8 Changing Case of String ................................................................................. 2 - 70
2.17.9 Finding Unicode of a Character ..................................................................... 2 - 71

2.18 JavaScript Debuggers ................................................................................... 2 - 73


Part II : DOM
2.19 Introduction to Document Object Model (DOM) ........................................ 2 - 74
2.20 DOM History and Levels .............................................................................. 2 - 75
2.21 The Document Tree ..................................................................................... 2 - 75
2.22 Modifying Element Style .............................................................................. 2 - 77
2.22.1 Accessing Elements using DOM ..................................................................... 2 - 77
2.22.2 Modifying Elements using DOM .................................................................... 2 - 79

2.23 DOM Event Handling ................................................................................... 2 - 84


2.23.1 Handling Events from the Body Elements ..................................................... 2 - 88

2.24 Form Validation in JavaScript ...................................................................... 2 - 91

(xi)
Part III : jQuery
2.25 jQuery ........................................................................................................ 2 - 103
2.25.1 Introduction to jQuery ................................................................................. 2 - 103
2.25.2 Basic Syntax ................................................................................................. 2 - 104
2.25.3 Loading jQuery............................................................................................. 2 - 104
2.25.4 Selecting Elements....................................................................................... 2 - 106
2.25.5 Changing Styles ............................................................................................ 2 - 113
2.25.6 Creating Elements........................................................................................ 2 - 114
2.25.7 Appending Elements.................................................................................... 2 - 116
2.25.8 Removing Elements ..................................................................................... 2 - 117
Part IV : Angular JS
2.26 Overview of Angular JS .............................................................................. 2 - 120
2.26.1 MVC with Angular JS.................................................................................... 2 - 121
2.26.2 Directives ..................................................................................................... 2 - 122
2.26.3 Expression .................................................................................................... 2 - 127
2.26.4 Controllers ................................................................................................... 2 - 129
2.26.5 Filters ........................................................................................................... 2 - 133
2.26.6 Tables........................................................................................................... 2 - 140
2.26.7 Modules ....................................................................................................... 2 - 143
2.26.8 Forms ........................................................................................................... 2 - 146
2.26.9 Includes........................................................................................................ 2 - 152
2.26.10 Views ......................................................................................................... 2 - 154
2.26.11 Scopes ........................................................................................................ 2 - 156
2.26.12 Services ...................................................................................................... 2 - 158
2.26.13 Dependency Injection ................................................................................ 2 - 164
2.26.14 Custom Directives ...................................................................................... 2 - 167
2.26.15 Internationalization ................................................................................... 2 - 169

2.27 Multiple Choice Questions with Answers .................................................. 2 - 172

(xii)
Unit - III
Chapter - 3 Java Servlets and XML (3 - 1) to (3 - 130)
Part I : Servlet
3.1 Introduction to Server Side Programming ....................................................... 3 - 3
3.2 Servlet Architecture Overview......................................................................... 3 - 3
3.2.1 Need and Advantages........................................................................................ 3 - 5

3.3 A "Hello World" Servlet ................................................................................... 3 - 5


3.4 Servlets Generating Dynamic Content .......................................................... 3 - 10
3.5 Servlet Life Cycle ............................................................................................ 3 - 12
3.6 Servlet API ...................................................................................................... 3 - 14
3.6.1 The javax.servlet Package ................................................................................ 3 - 14
3.6.1.1 Interfaces...................................................................................................... 3 - 14
3.6.1.2 Classes .......................................................................................................... 3 - 17
3.6.2 The javax.servlet.http Package ........................................................................ 3 - 18
3.6.2.1 Interface ....................................................................................................... 3 - 18
3.6.2.2 Classes .......................................................................................................... 3 - 19

3.7 Parameter Data.............................................................................................. 3 - 20


3.8 Sessions .......................................................................................................... 3 - 28
3.8.1 Session Management using Session ID ............................................................. 3 -29

3.9 Cookies ........................................................................................................... 3 - 33


3.9.1 Servlet Support for Cookies ............................................................................. 3 - 33
3.9.2 Examples .......................................................................................................... 3 - 34

3.10 URL Rewriting .............................................................................................. 3 - 40


3.11 Other Servlet Capabilities ............................................................................ 3 - 43
3.11.1 Additional HttpServletRequest Method ........................................................ 3 - 44
3.11.2 Additional HttpServletResponse Method...................................................... 3 - 44

3.12 Data Storage ................................................................................................ 3 - 47


3.13 Servlets and Concurrency ............................................................................ 3 - 48

(xiii)
3.14 Databases (MySQL) and Java Servlets ......................................................... 3 - 52
3.14.1 Structured Query Language using MySQL ..................................................... 3 - 52
3.14.2 JDBC Perspectives .......................................................................................... 3 - 57
3.14.2.1 How JDBC Works ? ..................................................................................... 3 - 58
3.14.2.2 Difference between JDBC and ODBC.......................................................... 3 - 58
3.14.2.3 Uses of JDBC ............................................................................................... 3 - 58
3.14.3 Steps for Connectivity between Servlet and Database ................................. 3 - 59
3.14.4 Implementation ............................................................................................. 3 - 60
Part II : XML
3.15 XML Documents and Vocabularies .............................................................. 3 - 81
3.16 XML Declaration .......................................................................................... 3 - 83
3.16.1 Declaring Elements ........................................................................................ 3 - 84
3.16.2 Declaring Attributes....................................................................................... 3 - 85
3.16.3 Declaring Entities ........................................................................................... 3 - 87

3.17 Rules............................................................................................................. 3 - 88
3.18 XML Namespaces ......................................................................................... 3 - 89
3.19 Document Type Definition (DTD) ................................................................ 3 - 89
3.20 Schema......................................................................................................... 3 - 94
3.20.1 Data Types ..................................................................................................... 3 - 96
3.20.2 Advantages and Disadvantages of Schema ................................................... 3 - 98

3.21 DOM based XML Processing ........................................................................ 3 - 99


3.22 Transforming XML Documents .................................................................. 3 - 106
3.22.1 Transforming XML into XSLT........................................................................ 3 - 106
3.22.2 XSL Elements................................................................................................ 3 - 107
3.22.3 Difference between XML and XSLT.............................................................. 3 - 115
Part III : AJAX
3.23 Introduction ............................................................................................... 3 - 115
3.24 Working of AJAX ........................................................................................ 3 - 115
3.25 XMLHttpRequest Object ............................................................................ 3 - 118

(xiv)
3.26 Coding AJAX Script ..................................................................................... 3 - 121
3.27 Multiple Choice Questions with Answers .................................................. 3 - 127
Unit - IV
Chapter - 4 JSP and Web Services (4 - 1) to (4 - 100)
Part I : JSP

4.1 Introduction to Java Server Pages ................................................................... 4 - 3


4.2 JSP and Servlets ............................................................................................... 4 - 3
4.3 Basics of JSP ..................................................................................................... 4 - 4
4.3.1 JSP Document Structure .................................................................................... 4 - 4
4.3.2 JSP Processing .................................................................................................... 4 - 5
4.3.3 Running JSP Applications ................................................................................... 4 - 6
4.3.4 Directives ........................................................................................................... 4 - 8
4.3.5 Comments ......................................................................................................... 4 - 9
4.3.6 Scripting Elements ............................................................................................. 4 - 9
4.3.7 Actions and Templates .................................................................................... 4 - 14

4.4 Implicit Objects .............................................................................................. 4 - 19


4.5 JavaBeans Classes and JSP ............................................................................. 4 - 20
4.6 Support for the Model-View-Controller Paradigm ........................................ 4 - 25
Part II : Web Services
4.7 Web Services Concepts .................................................................................. 4 - 26
4.7.1 Components of Web Services.......................................................................... 4 - 27

4.8 Writing a Java Web Service............................................................................ 4 - 28


4.9 Describing Web Services : WSDL ................................................................... 4 - 46
4.10 Communicating Object Data : SOAP ............................................................ 4 - 49
4.10.1 Structure of SOAP .......................................................................................... 4 - 49
4.10.2 SOAP and HTTP .............................................................................................. 4 - 50
4.10.3 SOAP Encoding............................................................................................... 4 - 51
4.10.4 RPC Representation ....................................................................................... 4 - 52

(xv)
Part III : Struts
4.11 Overview ...................................................................................................... 4 - 53
4.12 Architecture ................................................................................................. 4 - 54
4.13 Execution of First Struts Applications .......................................................... 4 - 55
4.14 Configuration ............................................................................................... 4 - 62
4.15 Actions ......................................................................................................... 4 - 63
4.16 Interceptors ................................................................................................. 4 - 71
4.17 Result Types ................................................................................................. 4 - 77
4.18 Validations ................................................................................................... 4 - 80
4.19 Localization .................................................................................................. 4 - 84
4.20 Exception Handling ...................................................................................... 4 - 90
4.21 Annotations ................................................................................................. 4 - 95
4.22 Multiple Choice Questions with Answers .................................................... 4 - 98
Unit - V
Chapter - 5 Server Side Scripting Languages (5 - 1) to (5 - 138)
Part I : PHP
5.1 Introduction to PHP ......................................................................................... 5 - 3
5.1.1 Origins and Uses of PHP .................................................................................... 5 - 3
5.1.2 Overview ............................................................................................................ 5 - 3
5.1.3 Installation of PHP ............................................................................................. 5 - 3

5.2 General Syntactic Characteristics .................................................................... 5 - 4


5.2.1 Variables ............................................................................................................ 5 - 5

5.3 Primitives ......................................................................................................... 5 - 6


5.3.1 Integer Type....................................................................................................... 5 - 6
5.3.2 Double Type ....................................................................................................... 5 - 6
5.3.3 String Type ......................................................................................................... 5 - 6
5.3.4 Boolean Type ..................................................................................................... 5 - 7

(xvi)
5.4 Type Conversion .............................................................................................. 5 - 7
5.5 Operations and Expressions ............................................................................ 5 - 8
5.5.1 Arithmetic Operators......................................................................................... 5 - 8
5.5.2 Relational Operators.......................................................................................... 5 - 9
5.5.3 Boolean Operators............................................................................................. 5 - 9
5.5.4 String Operators ................................................................................................ 5 - 9

5.6 Output ............................................................................................................ 5 - 10


5.7 Statements Control ........................................................................................ 5 - 11
5.7.1 The Selection Statement ................................................................................. 5 - 11
5.7.2 Looping Structure ............................................................................................ 5 - 13

5.8 Arrays ............................................................................................................. 5 - 17


5.8.1 Creating and Manipulating Arrays ................................................................... 5 - 17
5.8.2 Types of Arrays ................................................................................................ 5 - 20
5.8.3 Extracting Data from Arrays, Implode, Explode and Flip Functions ................ 5 - 23
5.8.4 Traversing Arrays ............................................................................................. 5 - 26

5.9 Functions........................................................................................................ 5 - 29
5.9.1 General Characteristics of Functions ............................................................... 5 - 29
5.9.2 Parameters ...................................................................................................... 5 - 30

5.10 Built in Functions ......................................................................................... 5 - 31


5.10.1 Functions based on Basic Operations ............................................................ 5 - 31
5.10.2 String Handling Functions .............................................................................. 5 - 32
5.10.3 Data Type Conversion Functions ................................................................... 5 - 34
5.10.4 Array Handling Functions .............................................................................. 5 - 34

5.11 Form Handling ............................................................................................. 5 - 35


5.12 Pattern Matching ......................................................................................... 5 - 42
5.13 Files .............................................................................................................. 5 - 45
5.13.1 Opening and Closing Files ............................................................................. 5 - 45
5.13.2 Reading from File .......................................................................................... 5 - 46
5.13.3 Writing to a File ............................................................................................ 5 - 46

(xvii)
5.14 Cookies......................................................................................................... 5 - 50
5.14.1 Introduction to Cookies ................................................................................. 5 - 50
5.14.2 PHP Support for Cookies................................................................................ 5 - 50
5.15 Session Tracking........................................................................................... 5 - 51
5.16 Using MySQL with PHP ................................................................................ 5 - 53
5.16.1 Connecting to Database ................................................................................ 5 - 53
5.16.2 Creating Database ......................................................................................... 5 - 54
5.16.3 Selecting Database ........................................................................................ 5 - 55
5.16.4 Listing Database............................................................................................. 5 - 55
5.16.5 Listing Table Names ....................................................................................... 5 - 56
5.16.6 Creating a Table ............................................................................................. 5 - 56
5.16.7 Inserting Data ................................................................................................ 5 - 57
5.16.8 Altering Table ................................................................................................ 5 - 58
5.16.9 Deleting Database ......................................................................................... 5 - 59
5.17 WAP ............................................................................................................. 5 - 67
5.18 WML............................................................................................................. 5 - 68
5.18.1 Cards and Decks............................................................................................. 5 - 69
5.18.2 Sample Program ............................................................................................ 5 - 69
5.18.3 Comments ..................................................................................................... 5 - 71
5.18.4 Paragraph ...................................................................................................... 5 - 71
5.18.5 Line Break ...................................................................................................... 5 - 72
5.18.6 Table .............................................................................................................. 5 - 73
5.18.7 Image ............................................................................................................. 5 - 74
5.18.8 Hyperlinks ...................................................................................................... 5 - 75
5.18.9 Inputs ............................................................................................................. 5 - 77
5.18.10 Select ........................................................................................................... 5 - 78
5.18.11 Event ............................................................................................................ 5 - 79
Part II : ASP.NET
5.19 Introduction to ASP.NET .............................................................................. 5 - 86
5.19.1 How does ASP.NET Works ? .......................................................................... 5 - 86
5.19.2 Features of ASP.NET ...................................................................................... 5 - 86

(xviii)
5.20 Overview of the .NET Framework................................................................ 5 - 87
5.21 Overview of C#............................................................................................. 5 - 88
5.21.1 Parts of C# Program ....................................................................................... 5 - 89
5.21.2 Creating First C# Program.............................................................................. 5 - 89
5.21.3 Variables ........................................................................................................ 5 - 93
5.21.4 Data Types ..................................................................................................... 5 - 93
5.21.5 Input and Output ........................................................................................... 5 - 93
5.21.6 Operators....................................................................................................... 5 - 94
5.21.7 Control Structure ........................................................................................... 5 - 99
5.21.8 The Break and Continue Statements ........................................................... 5 - 103
5.21.9 Class and Object .......................................................................................... 5 - 105

5.22 Introduction to ASP.NET ............................................................................ 5 - 107


5.22.1 ASP.NET Component Model ........................................................................ 5 - 107
5.22.2 Life Cycle of ASP.NET Application ................................................................ 5 - 107

5.23 ASP.NET Web Form Model ........................................................................ 5 - 110


5.24 ASP.NET Controls ....................................................................................... 5 - 110
5.24.1 How to Create Web Form Application ? ...................................................... 5 - 110

5.25 Web Services.............................................................................................. 5 - 122


5.25.1 Writing Web Service .................................................................................... 5 - 122
5.25.2 Writing Web service Client .......................................................................... 5 - 127
Part III : Node.js
5.26 Overview of Node JS .................................................................................. 5 - 133
5.26.1 Features of Node JS ..................................................................................... 5 - 136

5.27 Multiple Choice Questions with Answers .................................................. 5 - 136


Unit - VI
Chapter - 6 Ruby and Rails (6 - 1) to (6 - 72)
Part I : Introduction to Ruby
6.1 Origins & Uses of Ruby .................................................................................... 6 - 2
6.2 Scalar Types and their Operations ................................................................... 6 - 2
(xix)
6.2.1 Numeric and String Literals ............................................................................... 6 - 3
6.2.2 Variable and Assignment Statements................................................................ 6 - 4
6.2.3 Numeric Operators ............................................................................................ 6 - 4
6.2.4 String Methods .................................................................................................. 6 - 5

6.3 Simple Input and Output ................................................................................. 6 - 8


6.3.1 Screen Output.................................................................................................... 6 - 8
6.3.2 Keyboard Input .................................................................................................. 6 - 8

6.4 Control Statements .......................................................................................... 6 - 9


6.4.1 Control Expressions ........................................................................................... 6 - 9
6.4.2 Selection and Looping Statements .................................................................. 6 - 11

6.5 Fundamentals of Arrays ................................................................................. 6 - 14


6.5.1 The for-in Statement ....................................................................................... 6 - 15
6.5.2 Built in Methods for Arrays and Lists............................................................... 6 - 15
6.5.3 Examples .......................................................................................................... 6 - 16

6.6 Hashes ............................................................................................................ 6 - 18


6.7 Methods ......................................................................................................... 6 - 19
6.7.1 Fundamentals .................................................................................................. 6 - 19
6.7.2 Local Variables ................................................................................................. 6 - 20
6.7.3 Parameters ...................................................................................................... 6 - 20

6.8 Classes ............................................................................................................ 6 - 21


6.8.1 Basics of Classes............................................................................................... 6 - 21
6.8.2 Access Control ................................................................................................. 6 - 23
6.8.3 Inheritance....................................................................................................... 6 - 24

6.9 Code Blocks and Iterators .............................................................................. 6 - 25


6.10 Pattern Matching ......................................................................................... 6 - 26
6.10.1 Basics of Pattern Matching ............................................................................ 6 - 26
6.10.2 Remembering Matches ................................................................................. 6 - 27
6.10.3 Substitutions .................................................................................................. 6 - 27

(xx)
Part II : Introduction to Rails
6.11 Overview of Rails ......................................................................................... 6 - 28
6.12 Document Requests..................................................................................... 6 - 29
6.12.1 Static Documents - Creation of First Application in Rails .............................. 6 - 30
6.12.2 Dynamic Documents...................................................................................... 6 - 35

6.13 Processing Forms ......................................................................................... 6 - 36


6.14 Rails Applications and Databases ................................................................ 6 - 42
6.15 Layouts ......................................................................................................... 6 - 47
6.16 Rails with Ajax .............................................................................................. 6 - 48
Part III : EJB
6.17 Introduction to EJB ...................................................................................... 6 - 48
6.17.1 Types of EJB ................................................................................................... 6 - 49
6.17.2 Benefits of EJB ............................................................................................... 6 - 51
6.17.3 Architecture ................................................................................................... 6 - 52
6.17.4 EJB Technology .............................................................................................. 6 - 53
6.17.5 EJB Container and its Services ....................................................................... 6 - 67
6.17.6 EJB Interfaces................................................................................................. 6 - 68
6.17.7 EJB Clients ...................................................................................................... 6 - 70

6.18 Multiple Choice Questions with Answers .................................................... 6 - 70

Web Technology Laboratory (L - 1) to (L - 26)

Solved Model Question Papers (M - 1) to (M - 4)

(xxi)
Notes

(xxii)
UNIT- I

1 Web Essentials and Mark - up


Language - HTML
Syllabus
The Internet, basic internet protocols, the World Wide Web, HTTP Request message, HTTP response
message, web clients, web servers. HTML : Introduction, history and versions.
HTML elements : headings, paragraphs, line break, colors and fonts, links, frames, lists, tables,
images and forms, Difference between HTML and HTML5. CSS : Introduction to Style Sheet, CSS
features, CSS core syntax, Style sheets and HTML, Style rule cascading and inheritance, text
properties. Bootstrap.

Contents
1.1 Basic Concepts
1.2 Basic Internet Protocol
1.3 The Web Site Design Issues ....................................... Dec.-18, May-19, .................. Marks 5

1.4 HTTP Request Message and Response Message ..... May-18, March-19, ............... Marks 5

1.5 Features of HTTP Protocol


1.6 Web Clients
1.7 Web Servers ............................................... April-18, Dec.-18, ................. Marks 5

1.8 Client Sever Communication


1.9 Introduction

1.10 History and Version


1.11 Structure of HTML
1.12 HTML Elements ............................................... April-18, May-18, .................. Marks 5

1.13 Links
1.14 Frames

1.15 Lists

1.16 Tables

(1 - 1)
Web Technology 1-2 Web Essentials and Mark - up Language - HTML

1.17 Images

1.18 Forms
1.19 HTML5 ............................................... May-19, Dec.-19, .................. Marks 5

1.20 Introduction to Style Sheet


1.21 CSS Features

1.22 CSS Core Syntax


1.23 Selector

1.24 Style Sheets and HTML

1.25 Style Rule Cascading and Inheritance


1.26 Text Properties ............................................... March-20,.............................. Marks 5
1.27 Bootstrap ............................................... May-18, Dec.-19, .................. Marks 9

1.28 Multiple Choice Questions

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1-3 Web Essentials and Mark - up Language - HTML

Part I : Web Essentials

1.1 Basic Concepts

1.1.1 What is Web Technology ?


 Web technology is a technology that acts as an interface between web client and
web server. It includes markup languages, programming interfaces, online
presentation tools, Java applets, video editing tools and so on.
 The commonly used client side scripting languages are HTML, JavaScript, CSS,
XML and so on.
 The commonly used server side technologies are ASP, JSP, Java Servlets, PHP and
so on.

1.1.2 Concept of Internet

Definition : Internet is global system in which millions of computers are connected together. It is
basically a network of networks.

 Using internet many people can share resources and can communicate with each
other. To have internet service one must go to the service providers. That means
your computer must be connected to the Internet Service Providers (ISP) through
phone-line modem or DSL.
 There are some privately owned internet service providers from which we can hire
the internet services.

1.1.3 Concept of World Wide Web

Definition : World Wide Web (WWW) is collections of software and corresponding protocols used to
access the resources over the network.

 The world wide web is a information system in which various documents


containing information are interlinked together. User can access this information or
write the information via computers. This information is typically stored on the web
pages and through web browsers we can access these web pages.
 The web pages may contain the information in the form of text, audio, video,
images and graphics. We can navigate between the web pages using hyperlinks.
 The concept of WWW was introduced by Sir Tim Berners-Lee the contractor at the
European Organization for Nuclear Research (CERN), Switzerland in 1980. He
built a personal database of people and software models and used hypertext so that
each new page of information was linked to an existing page.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1-4 Web Essentials and Mark - up Language - HTML

1.1.4 Internet or WWW ?


 The term internet and WWW is often used interchangeably, but these are two
different terms.
 The internet is collection of computers and other devices (such as printers, scanners
etc.) connected together whereas World Wide Web (WWW) is collection of software
and corresponding protocols used to access the resources over the network.
 The world wide web contains huge amount of documents, images and other
resources which can be accessed using the hyperlinks.
 Thus people use internet through the Web.

1.2 Basic Internet Protocols


Various protocols used in internetworking are -

1) File Transfer Protocol (FTP)


 The file transfer protocol sets the rules for transferring files between computers.
 When user wants to download a file from the server FTP is used.
 FTP uses two connections between client and server. One connection is used for
actual data transfer and other is used for control information (used for commands).
This separation of data and commands makes the FTP more efficient.

Fig. 1.2.1 Two connections used in FTP processing

 When client makes a request for particular file download then using the data
transfer connection actual data gets transmitted from server to the client.
 At the same time server keeps track of how much data is sent so far and how much
is remaining. This tracking can be done using the control transfer connection.
 Hence during the file downloading/uploading we can see a message about how
many bytes are getting transferred and how much time is remaining.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1-5 Web Essentials and Mark - up Language - HTML

2) HTTP
 The Hyper Text Transfer Protocol (HTTP) is a request/response protocol.
 It is a communication protocol used to transfer the information on local area
network and World Wide Web (WWW).
 It is the network protocol used to deliver virtually all files and other data
(collectively called resources) on the World Wide Web, whether they're HTML files,
image files, query results, or anything else. Usually, HTTP takes place through
TCP/IP sockets.
 It is also called as a stateless protocol because this protocol is not able to maintain
the previous conversation/information.

3) SNMP
 Simple Network Management Protocol (SNMP) is a protocol which enables
network administrators to manage network devices and to diagnose network
problems.
 The network management system is based on two main elements : a supervisor and
agents.
o The supervisor is the terminal at which the network administrator requests for
network management.
o The agents are found at the level of each interface connecting the managed
devices to the network. With the help of these agents information on the
different objects (such as switch, hub, routers) can be collected.

4) SMTP
 Simple Mail Transfer Protocol (SMTP) is a simple protocol which is extensively
used for transfer of e-mails to remote servers.
 It is an asynchronous protocol, because it allows delayed delivery of message.
 With the help of mail transfer agent and user agent the SMTP sends and receives
the emails.

5) POP3
 Post Office Protocol version 3 (POP3) is used by local email clients (such as
Microsoft Outlook Express).
 The POP3 protocol works only at the receivers end and has no work at the sender’s
end.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1-6 Web Essentials and Mark - up Language - HTML

 The POP protocol has two parts, a client POP i.e. receiver’s POP and a server POP
i.e. receiver’s email server. The client i.e. the receiver opens TCP connection with
receiver’s POP server. This client must be authenticated first by using the user name
and password. Then the client can receive the emails from the mailbox.
6) TCP
 The transmission control protocol is used for,
1. Safe delivery of data
2. Error detection
3. Assurance of the correct sequencing of data being received.
 This protocol is called connection oriented protocol because before sending the
data this protocol requires that two computers have established connections.
 The TCP allows the transmission of arbitrary amount of data by breaking it into
stream of separate IP packets.
 These IP packets are numbered so that it could be reassembled properly at arrivals.
Along with the data an acknowledgement is also sent/received in order to know
whether the reliable connection has occurred or not.

7) UDP
 The user datagram protocol is a connectionless protocol without any error
detection facility.
 This protocol is used for simply transmission of data.
 The UDP is known as an unreliable protocol however this is much faster than TCP.

8) IP
 Internet Protocol (IP) is a network layer protocol which consists of addressing
information.
 Using this information the communication between uniquely addressed computers
is possible.

1.3 The Web Site Design Issues SPPU : Dec.-18, May-19, Marks 5

 Following design goals are for the web design -


1. Simplicity :

 It is a general tendency of web designers to provide lot of animations, huge


amount of information, extreme visuals and so on. This makes the web design
enormous and it should be avoided. The web application must be moderate and
simple.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1-7 Web Essentials and Mark - up Language - HTML

2. Identity :

 Web design must be based on the nature of the web application. It is driven by the
objective of the web application, category of user using it. A web engineer must
work to establish an identity for the web application through the design.
3. Consistency :

 The contents of the web application should be constructed consistently. For


example : Text formatting, font style should be the same over all the text document
of the web application. Similarly, the graphics design, color scheme and style must
be identical over all the web pages of the web application. Architectural design
should produce the templates using which the consistent hypermedia structure
can be formed. Interface design should define the consistent modes of interaction,
navigation and content display. Navigation mechanism must be used consistently
across web application elements.
4. Robustness :

 The users always expect robust contents and functions of the web application.
That means any required functionality should not be missing at all, If any function
or content is missing or insufficient then that web application will fail.
5. Navigability :

 The navigation should be simple and consistent. The design of navigations should
intuitive and predictable in nature. That means any novice user should be in a
position to make use of navigation links without any help.
6. Visual appeal :

 The web applications are most visual and most dynamic and aesthetic in nature.
There are various factors that contribute to visual appeal. These factors are -
 Look and feel of the content, interface layout, color co-ordination, the balance of
text, graphics and other media, navigation mechanism and so on.
7. Compatibility :

 The web application can be used in variety of environment and configurations


such as different browsers, internet connection types, operating systems and
various browsers.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1-8 Web Essentials and Mark - up Language - HTML

1.3.1 Browser Compatibility Issues


 One of the greatest challenge faced by the authors of web document is designing the
web pages which can be displayed properly by multiple browsers.
 Basically, every browser contains a program called rendering engine. This program
interprets the markup tags of your web document and display the result in the
browser. This logic of interpreting the tags varies from browser to browser. As a
result, conflicting results are displayed on different browsers.
 The responsibility of a web designer is to test the web page of as many browsers as
possible to ensure that the work appears correctly as per the design.
 To settle the browser compatibility issues following guideline must be adopted –
o Follow W3C standards : Make use of scripting languages such as HTML, CSS,
JavaScript correctly.
o Validate the code : Test the syntax of the code. Make the web document free
from any kind of coding errors.
o Know your audience : The web design must be accessible, readable and
unambiguous for the target audience.
o Test your work on multiple browsers and devices : Repeatedly test and try to
execute the web document on multiple browsers and devices for ensuring its
correctness.

1.3.2 Bandwidth
 The term bandwidth means amount of data that can be carried from one point to
another in a given period of time. The bandwidth is generally used to define user’s
internet connection speed. It is expressed in terms of bits per seconds (bps).
 The web pages get slowly displayed on the browser as they contain large and
detailed graphics and flash animations. Normally user never prefer to view the web
pages that are displayed slowly on the browser window.
 The web designer must test the execution of web pages at variety of connection
speed.
 The iphones, or other cellular handsets that display the web pages have lower
bandwidth than the home or business computers.

1.3.3 Cache
 The term cache means the temporary storage area.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1-9 Web Essentials and Mark - up Language - HTML

 The computer on which all the web pages are stored is called web server. When we
type URL address in the browser, it connects to appropriate web server and
requests the file specified by the user. The server sends the file to the user and the
user’s browser can download it.
 The first time when user visit the web site, entire contents, including images,
stylesheets and so on get downloaded on user’s hard disk. The next time when user
visits the web site, the user’s browser downloads and parses the web page from the
site. The browser checks if any specified image is already present on the computer’s
hard drive in the cache.
 Cache is the browser’s temporary storage area for web pages and images.
 Thus the browser always try to load images from the cache instead of downloading
it from the web server.
 The browser cache is useful for displaying the frequently visited web pages more
efficiently.
 The cookie is a small text file that server embeds in clients web browser. Each time
when user makes a request for the web page, it sends the cookies as well. The
browser retrieves the values from cookies.
Review Question

1. List and discuss the different design issues in web development.


SPPU : Dec.-18, May-19, Marks 5

1.4 HTTP Request Message and Response Message


SPPU : May-18, March-19, Marks 5

 The basic feature of HTTP protocol is that it follows the request response model.
 The client makes a request for desired web page by giving the URL in the address
bar. This request is submitted to the web server and then web server gives the
response to the web browser by returning the required web page.
1. HTTP Request Message Structure
The basic structure of request message is given by following general form -
<Start line>

<Header fields>

<Blank Line>

<Message Body>

<start Line>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 10 Web Essentials and Mark - up Language - HTML

The start line consists of three parts which are separated by a single space. These parts
are -
i) Request method ii) Request-URI iii) HTTP version
i) Request method : Various methods used for making the request are enlisted in
the following table.
HTTP method Description

GET The GET method is used to retrieve information from a specified URI and is
assumed to be a safe, repeatable operation by browsers.

POST The POST method is used to request the server for desired web page and the
request made is accepted as a new subordinate of the resource identified.
The POST method is used for operations that have side effects and cannot be
safely repeated. For example, transferring money from one bank account to
another has side effects and should not be repeated without explicit approval
by the user.

HEAD The HEAD method is identical to GET. The only difference is that the server
should not return a message-body in the response. The meta-information
contained in the HTTP headers in response to a HEAD request should be
similar to the information sent in response to a GET request.

OPTION This method supports for the specified URL. It can be used to check the
functionality of a web server by requesting '*' instead of a specific resource.

PUT This method uploads a representation of the specified resource.

DELETE This method is useful in deleting the specified resource.

TRACE When request is made using TRACE method the server echoes back the
received request so that a client can see what intermediate servers are adding
or changing in the request.

(ii) Request-URI :
 The Uniform Resource Identifier (URI) is a string used to identify the names or
resources on the Internet.
 The URI is a combination of URL and URN.
 The URL stands for Uniform Resource Locator and URN stands for Uniform
Resource Name.
 The web address denotes the URL and specific name of the place or a person or
item denotes the URN. For example

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 11 Web Essentials and Mark - up Language - HTML

urn : ISBN 978-81-8431-123-2


specifies the address of some book.
 If the URI is written in the form of http : then it is both an URI and URL but there
are some other URI which can also be used as URL. For example
URL Intended server

ftp://ftp.mywebsite.com/index.txt File can be located on FTP server

telnet://mywebsite.org Telnet server

mailto:[email protected] Mail box

http://www.mywebsite.com Web server

(iii) HTTP Version : The first HTTP version was HTTP/0.9 but the official version of
HTTP was HTTP/1.1
<Header Field> and <Message Body>
 The host header filed is associated with the http request.
 The header fields are in the form of field name and field value.
 Thus typical structure of http request is given be following example -

Fig. 1.4.1 HTTP request message structure

2. HTTP Response Message Structure


The basic structure of response message is given by following general form -

<Status line>

<Header fields>

<Blank Line>

<Message Body>

<Status Line>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 12 Web Essentials and Mark - up Language - HTML

Status line is similar to the start line in the request message. It consists of three fields.
HTTP version Status code reason phrase

The HTTP version denotes the HTTP version such as HTTP/1.1. The status code is a
numeric code indicating the type of response. The reason phrase is in the text string form
and presents the information about the status code.
For example -

Following table explains some commonly used status codes.


Status code Reason phrase Description

200 OK This is a standard response for successful request.

201 Created It shows that the request is fulfilled and a new resource is
being created.

202 Accepted When the request is accepted for processing but is not
processed yet is denoted by this status code.

301 Moved The URI for requested resource is moved at some another
permanently location.

401 Unauthorized The requested resource is protected by some password and


the user has not provided any password.

403 Forbidden The requested resource is present on the server but the server
is not able to respond it.

404 Not Found The requested resource is not present currently but may be
available in future.

500 Internal Server It is a generic error message that appears due to software
Error internal failure.

<Header Fields>
The header field in response message is similar to that of request message.
<Message Body>
The message body consists of response message.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 13 Web Essentials and Mark - up Language - HTML

For example
HTTP/1.1 200 OK
Date: Sat, 30 Mar 2019 07:59:01 GMT
Server: Apache/2.0.50 (Unix) mod_perl/1.99_10 Perl/v5.8.4
mod_ssl/2.0.50 OpenSSL/0.9.7d DAV/2 PHP/4.3.8
Last-Modified: Mon, 23 Feb 2009 08:32:41 GMT
Accept-Ranges: bytes
Content-Length: 2010
Content-Type: text/html
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>...</html>
The response header fields are enlisted in following table.

Header field Description

Date It represents the date and time at which the response is generated.

Server The name of the server which is responding

Last-Modified The date and time at which the response is last modified.

Accept-ranges It specifies the unit which is used by the client to accept the range request. For
example if there is a large document and only a single web page is currently
needed then this specifies the Accept-range.

Example 1.4.1 List and discuss any three HTTP commands.


SPPU : May-18, Marks 5

Solution : HTTP protocol defines a set of request methods. A client can use one of these
request methods to send a request message to an HTTP server.

Method Purpose

GET Client can use the GET request to get a web resource from the server.

HEAD Client can use HEAD request to get the header that a GET request would have
obtained.

POST It is used to post data to the web server.

PUT It asks the user to store data.

DELETE It asks the server to delete the data.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 14 Web Essentials and Mark - up Language - HTML

Example 1.4.2 Describe the steps involved when a web browser requests for and obtains a web
page from a web server.
SPPU : March-19, Marks 5

Solution : The steps in web browser and web server communication are :
Step 1 : The user submits the request for web page via web browser.
Step 2 : The web server software routes the request to the server.
Step 3 : The web server decodes the request and then processes it.
Step 4 : The web server then encodes the response as HTML web page. Then the
server submits back the response to web browser.
Step 5 : The web browser updates the display for displaying the requested web page.

1.5 Features of HTTP Protocol


1. It is a communication protocol used between web browser and web server.
2. This protocol is based on request-response messaging. That means client makes
the request of desired web page and then the server responds it by sending the
requested resource.
3. It is a stateless protocol. That means HTTP protocol can not remember the
previous user’s information nor it remembers the number of times the user has
visited particular website.
4. The request-response message consists of plain text in fairly readable form.
5. The HTTP protocol has a cache control. This is an advanced feature of HTTP.
Most of the web browsers automatically store (Cache) the recently visited web
pages. This is very useful feature because if the user requests the same web page
that has been visited already then it can be displayed from the cache memory
instead of requesting the web server and bringing it from there.

1.6 Web Clients


 Web client is a kind of software that runs on the clients machine.
 This software sends the HTTP request to the server and then processes the HTTP
response.
 Various forms of web client software are -
1) Web browsers
2) Browsers running on mobile phones.
3) Software robots which crawl on the web for retrieving the information.
4) User agents which assists the user in browsing the web.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 15 Web Essentials and Mark - up Language - HTML

 Web browser is a kind of software which is basically used to use resources on the
web.
 Over the networks, two computers communicate with each other. In this
communication, when request is made by one computer then that computer is
called a client and when the request gets served by another computer then that
computer is called server. Thus exchange of information takes place via
Client-Server communication.
 When user wants some web document then he makes the request for it using the
web browser.
 The browsers are the programs that are running on the clients’ machines. The
request then gets served by the server and the requested page is then returned to
the client. It is getting displayed to the client on the web browser.
 The commonly used web browsers are (i) Internet explorer (ii) Mozilla Firefox
(iii) Netscape Navigator (iv) Opera (v) Google Chrome (vi) Safari.
 Web browser supports variety of protocols but the most commonly used protocol
on the web browser is Hyper Text Transfer Protocol (HTTP). This protocol is
typically used when browser communicates with the server.

1.6.1 Functions Defined by Web Browser


Various functions of web browser are -
1. Reformats the URL and send a valid HTTP request.
2. When user gives the address of particular web site it is in the form of domain
name. The web browser coverts the DNS to corresponding IP address.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 16 Web Essentials and Mark - up Language - HTML

3. The web browser establishes a TCP connection with the Web browser while
processing the user’s request.
4. The web browsers send the HTTP request to the web server.
5. The web server processes the HTTP request sent by the web browser and returns
the desired web page to the client machine. The web browser on the client’s
machine displays this web page in appropriate format.

1.6.2 URL
 The Uniform Resource Locator (URL) is unique address for the file that has to be
accessed over the internet.
 When we want to access some website we enter it’s URL in the address bar of the
web browser.
 For example if we want to access www.google.com then we must specify its URL in
the address bar as shown.

 However any other file such as some text file or image file or some HTML file can
also be specified. The URL contains name of the protocol such as http://
 The URL may contain the name of the protocol as such as ftp. For example
ftp://ftp.funet.fi/pub/standards/RFC/rfc2166.txt
 The protocol identifier and the resource name are separated by a colon and two
forward slashes. The syntax of writing URL is as given below,
protocol://username@hostname/path/filename
 Sometimes instead of domain name servers IP addresses can also be use. For
example,
http://192.168.0.1
 But use of IP address as URL is not preferred because human can not remember
numbers very easily but they can remember names easily.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 17 Web Essentials and Mark - up Language - HTML

Absolute and Relative URL


 The absolute URL is a URL which directly point to a file. It exactly specifies exact
location of a file or directory on the internet. Each absolute URL is unique. For
example -
http://www.vtubooks.com/home.aspx
 The relative URL points to the file or a directory in relation to the present directory.
For example
 Consider the absolute address which refers an image mother.jpg
http://www.mywebsite.com/myphotos/mother.jpg
 For the above given absolute address the relative address will be -
../myphotos/mother.jpg
 That means from the current URL the directory myphotos will be searched for the
image mother.jpg. The two periods.. instruct the server to move up one directory
which is the root directory, then enter myphotos directory (/myphotos) and finally
point at mother.jpg. Thus using relative URL writing of long path name can be
avoided.

1.7 Web Servers SPPU : April-18, Dec.-18, Marks 5

 Web server is a special type of server to which the web browser submits the request
of web page which is desired by the client.
 There are some popularly used web servers such as Apache and IIS from Microsoft.

Functions of web server


Various functions of web server are -
1. The web servers accepts the requests from the web browsers.
2. The user request is processed by the web server.
3. The web servers respond to the users by providing the services which they
demand for over the web browsers.
4. The web servers serve the web based applications.
5. The DNS translate the domain names into the IP addresses.
6. The servers verify given address exists, find necessary files ,run appropriate
scripts exchange cookies if necessary and returns back to the browser.
7. Some servers actively participate in session handling techniques.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 18 Web Essentials and Mark - up Language - HTML

Working Principle of Web Server


 When user submits a request for a web page, he/she is actually demanding for a
page present on the web server.
 When web browser submits the request for a web page, the web server responds
this request by sending back the requested page to the web browser of the client’s
machine.

Fig. 1.7.1

Step 1 : Web client requests for the desired web page by providing the IP address of
the website.
Step 2 : The web server locates the desired web page on the website and responds by
sending back the requested page. If the page doesn’t exist, it will send back
the appropriate error page.
Step 3 : The web browser receives the page and renders it as required.

1.7.1 Apache
 It is an excellent server because of its two important features : Reliability and
Efficiency.
 Secondly it is more popular because it is an open source software. That means it is
freely available to anybody. Apache web server is best suitable for UNIX systems
but it can also be used on Windows box.
 The apache web server can be configured as per the requirements using the file
httpd.conf. This file is present in the Apache software package.

1.7.2 IIS

 The Internet Information Services or Internet Information Server is a kind of web


server provided by Microsoft.
 This server is most popular on Windows platform.
 Following are some differences between Apache and IIS servers.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 19 Web Essentials and Mark - up Language - HTML

Sr. Apache web server IIS web server


No.
1. Apache web server is useful on IIS web server is used on Windows
both Unix based systems and on platform.
Windows platform.
2. It is an open source product. It is a vendor specific product and can
be used on windows products only.
3. The Apache web server can be For IIS server, the behaviour is
controlled by editing the controlled by modifying the window
configuration file httpd.conf based management programs called IIS
snap in. We can access IIS snap-in
through the
Control-Panel->Administrative Tools.

Example 1.7.1 Define the terms :


i) Webside ii) Web page iii) Web server iv) URL and v) Home page.
SPPU : April-18, Marks 5

Solution :
i) Website : It is a set of related web pages located under a single domain name.
ii) Web page : It is hypertext document connected to world wide web.
iii) Web server : Web server is a server software that delivers content or services to end
users over internet.
iv) URL : The Uniform Resource Locator (URL) is unique address for the file that has to
be accessed over the internet. When we want to access some website we enter it’s
URL in the address bar of the web browser.
v) Home page : It is the introductory web page of web site that acts as a start-up page.

Example 1.7.2 What are the technologies used in traditional web programing ? Also identify
location of each technology used in this model.
SPPU : April-18, Marks 5

Solution : The server side technologies and client side technologies are used in traditional
web programming. The server side technologies work at the server level and client side
technologies are used at the client level. Following table illustrates the comparative
description of these technologies.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 20 Web Essentials and Mark - up Language - HTML

Sr. No. Server side scripting Client side scripting

1. The server side scripting is used to The client side scripting is used to create the

create the web pages that provide some web pages as a request or response to
services. server. These pages are displayed to the
user on web browser.

2. These scripts generally run on web These scripts generally run on web browser.

servers.

3. A user's request is fulfilled by running a The processing of these scripts takes place

script directly on the web server to on the end users computer. The source code

generate dynamic HTML pages. This is transferred from the web server to the
HTML is then sent to the client browser. users computer over the internet and run
directly in the browser.

4. Uses : Processing of user request, Uses : Making interactive web pages, for

accessing to databases. interacting with temporary storages such as

cookies or local storage, sending request to

server and getting the response and


displaying that response in web browser.

5. Example : PHP, ASP.NET, nearly all the Example : HTML, CSS, JavaScript

programming languages including C++, (primarily)

Java and C#

Review Question

1. Write the difference between client side scripting and server side scripting.
SPPU : Dec.-18, Marks 4

1.8 Client Sever Communication


 In this architecture, there are three components.
1) Client PC or Web client
2) An application server or web server
3) A database server.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 21 Web Essentials and Mark - up Language - HTML

Working

Step 1 : The client PC or web client submits the request for desired web page to the web
server.
Step 2 : The work of server is distributed among application server and database
servers. Application server possesses the required communication functions.
Step 3 : The data required by this business logic is present on database server. The
required data is returned to application servers
Step 4 : The web server or application server prepares the response page and sends
it to the web client.

Fig. 1.8.1 Client server communication

Advantages :
1. High performance and persistent objects take part in communication.
2. This architecture is scalable. That means it can support increased number of
users and resources.
3. High degree of flexibility in deployment platform and configurations.
4. Code/data reusability can be achieved.
5. Improved data integrity
6. Improved security as clients can not directly access the database.
7. The maintenance and modifications can be done effectively without disturbing
other modules in the architecture.

Disadvantages :
1. The complexity gets increased.
2. Cost for network maintenance and deployment is increased.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 22 Web Essentials and Mark - up Language - HTML

Part II : HTML

1.9 Introduction
 HTML stands for HyperText Markup Language. Hypertext is simply a piece of text
that works as a link.
 Markup Language is language of writing layout information within documents.
 Basically an HTML document is a plain text file.
 It contains rich text. The rich text means text with tags.
 HTML is not a case sensitive language.
 Any HTML program can be written in simple Notepad or WordPad text editors.
The extension to this program should be either html or htm.
 This program then can be opened in some web browser and the corresponding web
page can be viewed. Let us create our first web page using HTML.

HTML Document
<html>
<head>
<title>My webpage</title>
</head>
<body>
This is my first Web Page!!!
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 23 Web Essentials and Mark - up Language - HTML

Script Explanation

1) Note that the program consists of some strings enclosed within angular brackets.
Such strings are called tags.
2) The HTML program should be written within <html> and </html>. The <html>
indicates the start of html program and </html> denotes end of html program.
Use of slash (/) in the angular bracket indicates end of that particular tag.
3) Any HTML program has two prominent parts : head and body. The head part
acts as a header of a file and contains some information like setting the title of
web page.

Comments in HTML

 The comment in HTML can be denoted as follows -


<!--It is a comment statement -->

 There should not be a space between angular bracket and exclamation mark. This
comment is beginning with <!-- and ending with -->. Also note one thing that there
should not be any -- inside the comment.

1.10 History and Versions


 HTML stands for HyperText Marks up Language. It is a markup language.
 In 1991 Tim Berners Lee invented HTML.
 In 1991 there is a recommendation for HTML 4.01. Thus From 1991 to 1999, HTML
developed from version 1 to version 4.
 In year 2000, the World Wide Web Consortium (W3C) recommended XHTML 1.0.
The XHTML syntax was strict, and the developers were forced to write valid and
"well-formed" code.
 In 2004, WHATWG (Web Hypertext Application Technology Working Group) was
formed. The WHATWG wanted to develop HTML, consistent with how the web
was used, while being backward compatible with older versions of HTML.
 In 2004 - 2006, the WHATWG gained support by the major browser vendors.
 In 2008, the first HTML5 public draft was released.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 24 Web Essentials and Mark - up Language - HTML

1.11 Structure of HTML


 The structure of HTML document can be illustrated by following sample HTML
document.

1. Doctype : The Doctype stands for Document type which tells the browser what
type of document (HTML) it is about to process.
2. HTML : The <html> element is sometimes called the root element as it contains
all the other HTML elements in the document.
3. Head : HTML pages are divided into two sections : The head and the body,
which correspond to the <head> and <body> elements. The head contains
descriptive elements about the document, such as its title, any style sheets or
JavaScript files it uses.
4. Body : The body contains content (both HTML elements and regular text) that
will be displayed by the browser.
5. Character encoding : The <meta> element specifies that the character encoding
for the document is UTF-8. Character encoding refers to which character set
standard is being used to encode the characters in the document. UTF-8 is a more
complete variable-width encoding system that can encode all 110,000 characters
in the unicode character set.
6. External style sheet : The external stylesheet such as css can be used with HTML
document. We can specify the name of the CSS stylesheet.
7. External scripts : Sometimes external JavaScript files can be associated with
HTML document.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 25 Web Essentials and Mark - up Language - HTML

1.12 HTML Elements SPPU : April-18, May-18, Marks 5

 In all HTML/XHTML documents the root element is <html> which has two
children : head and body.
 Any text contained within the head element does not appear directly in the client
area of web browser. The head element is used for providing certain information to
web browser. The <title> element is used to give title to the web page. Note that this
title does not appear in client area. Rather
it appears at the top of web browser.
 The <body> element contains the
information which is to be displayed in the
client area of web browser.
 The body element can contain several
fundamental elements such as <p>, <h1>,
<div>, <a>, <hr>, <br> and so on. The
elements within the body part is for
Fig. 1.12.1 Element tree
deciding the layout of your web page.

1.12.1 Heading
 There are header tags which help to display the text as some header.
 The header tag is denoted by h1, h2 and so on upto h6.
 Following HTML document along with its output is itself self explanatory.

HTML Document [headerDemo.html]

<!DOCTYPE html>
<html>
<head>
</head>
<body>
<h1> This is a first header </h1>
<h2> This is a second header </h2>
<h3> This is a third header </h3>
<h4> This is a forth header </h4>
<h5> This is a fifth header </h5>
<h6> This is a sixth header </h6>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 26 Web Essentials and Mark - up Language - HTML

Output

1.12.2 Paragraphs
Following are the tags that are used for creating paragraphs.
Tag Meaning

<p> This tag should be put at the end of every paragraph.

<pre> This tag is used to preserve the white spaces and lines in the text.

<div> This tag is used to make division of sections in the XHTML document.

For example

HTML Document[TextFormat.html]
<!DOCTYPE html>
<html >
<head>
</head>
<body>
<p>
Once upon a time, there was a king who kept a monkey as a pet.
The monkey served the king by all the possible ways.
</p>
<div>
It was very hot in those days. So one day, when the king was sleeping, monkey was
fanning the king. Suddenly monkey noticed a fly on the chest of the king. The monkey tried to
swish it away. But fly would go away for one moment and come back again.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 27 Web Essentials and Mark - up Language - HTML

</div>
<div> So monkey decided to teach a lesson to the fly.</div>
<pre>
The monkey then looked for something to hit a fly.
It then found a stick.
It picked up the stick and tried to beat the fly using stick.
Hmmm at last it found a fly and
with all the force it hit the fly as a result of which the king died.

Lesson from the story:Never keep a fool servant !!!


</pre>
</body>
</html>
Output

1.12.3 Line Break


For the line break the <br/> tag is used. This is a single line break tag. Generally this
tag is kept at the end of every line.

For example
<!DOCTYPE html>
<html>
<head>
<title>Line Break Demo</title>
</head>
<body>
<p>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 28 Web Essentials and Mark - up Language - HTML

Here the line breaks <br/> and new line starts.


Again line breaks<br/> Bye.
</p>
</body>
</html>
Output

1.12.4 Setting Font Style


The font style can be of various types such as boldface, italics, and strikethrough.
Tag Purpose
<b> </b> Displays the text in bold
<i> </i> Displays the text in italics
<strong </strong> Displays the text in bold
<strike> </strike> Displays the text with strike

Following HTML document illustrates this -


HTML Document [FontStyle.html]
<!DOCTYPE html>
<html>
<head>
<title>Font Style Demo</title>
</head>
<body>
<b> This is a bold text </b> <br/>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 29 Web Essentials and Mark - up Language - HTML

<i> This is in italics</i> <br/>


<strong> This is strongly emphasized text</strong> <br/>
<strike> This is striked text </strike>
<center> This will appear at the center</center> <br/>
</body>
</html>
Output

1.12.5 Text Alignment

We can align the text at left, right or at the center using a <div> tag. Here is a HTML
program which shows the text aligned left, right and centre.

HTML Document[TextAlign.html]
<!DOCTYPE html >
<html>
<head>
<title>Font Style Demo</title>
</head>
<body>
<div align="center">This line is aligned at center</div>
<div align="left">This line is aligned at left</div>
<div align="right">This line is aligned at right</div>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 30 Web Essentials and Mark - up Language - HTML

Output

1.12.6 Setting the Font and Color


We can set the font, size and color of the text in the web page. The tag <basefont> is
used for this purpose. The optional attributes used with <basefont> tag are as given
below :
Attribute Value Purpose
color Color value such as “red”, It displays the text with specified color.
“yellow” and so on.
face Font-family such as “arial”, It displays the text with specific font family.
“verdana”,”sans-serif” and so on.
size Number The text of specified size will be displayed using
this attribute value.

For example -
HTML Document[SetFont.html]
<!DOCTYPE html>
<html >
<head>
<title>Setting the Text </title>
</head>
<body>
<basefont face="arial" size="10">
Varsha is sweet and <br/>
Jayashree is very naughty!!<br/>
But Sachin is a serious guy<br/>
And Rashmi is a new-comer in this group
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 31 Web Essentials and Mark - up Language - HTML

Output

The <basefont> tag is supported in Internet Explorer 9 and not by FireFox, Chrome,
Opera and so on.
Most of the web designers prefer to have their web pages white in color. HTML allows
the web developer to use color attribute for coloring the text or for setting the background
color.
First of all we will learn how to display a text colourful on the webpage.

HTML Document[ColorFont.html]
<!DOCTYPE html>
<html>
<head>
<title>coloring the text</title>
</head>
<body>
<basefont face="arial" size="5" color="blue">
Great people are simple and <br>
<font face="Times new roman" color="red" size="8">
Simple people are great!!!<br>
<font face="GoudyHandtooled BT" color="green" size="14">
Great people rule the world.
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 32 Web Essentials and Mark - up Language - HTML

Output

Script Explanation :
1) In the above HTML document, we have used font face tag to set the font.
2) Using the attributes color and size we can specify values color and size in double
quotes.
We can set the background color of the web page using the attribute bgcolor.
Following program sets the background color of the web page to red.

HTML Document[BgColor.html]
<!DOCTYPE html>
<html>
<head>
<title>Coloring the background</title>
</head>
<body bgcolor="#FFFF00">
<h3>This is document has colored background</h3>
</body>
</html>

Script Explanation :
1) In above document we have specified background color using the bgcolor
attribute.
2) The color can be specified by either using the color name in double quotes or
using the hex.code as given in above document.
3) The first two digits of hex code represents the red value, then next two digits
specify the green value and final two digits specify the blue value. Hence the
corresponding output will be as follows -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 33 Web Essentials and Mark - up Language - HTML

Output

Note that the background color is specified by the hexadecimal value. Following table
shows the hex and corresponding decimal values -
Decimal value Hexadecimal value
1 1
2 2
3 3
4 4
5 5
6 6
7 7
8 8
9 9
10 A
11 B
12 C
13 D
14 E
15 F

In HTML, the colors are specified by beginning with # and the FF denotes 255. In this
color code first two digits specify the amount of red color then next two digits specify the
green color and the last two digits specify blue color.
# FF 00 00
red colour

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 34 Web Essentials and Mark - up Language - HTML

Hence is used to set the background color red. Each pair of digits specifies 0 to 255
color values. Thus hexadecimal color coding helps us to specify.
256 * 256 * 256 = 16777216 colors.
The color can also be specified by its name as follows -
<html>
<body bgcolor=yellow>
</html>
Following is a list of colors that can be specified for setting the background colors.

Aqua Navy

Black Olive

Blue Purple

Fuchsia Red

Gray Silver

Green Teal

Lime White

Maroon Yellow

1.12.7 Special Character


 In HTML certain symbols are treated as special. For example - < i.e. less than
symbol is considered as special symbol because it is used as the beginning of the
tag.
 Hence we cannot directly use certain symbols such as <, >, “,© and so on.
 To print these symbols we use the units which are called as reference. This
reference always begins with ampersand (&) sign. Such reference is called as entity
reference.
 Following table enlists some characters and entity references -
Character Meaning Entity Reference

< less than &lt;

> greater than &gt;

& ampersand &amp;

“ double quote &quot;

’ apostrophes &apos;

© copyright &copy;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 35 Web Essentials and Mark - up Language - HTML

 Another type of entity reference that is used frequently is &nbsp; that is non
breaking space character.
 This entity reference is useful for defining the space between two string and
informing browser for not performing the word wrapper between the strings.
 Following is a sample script that makes use of &nbsp.
HTML Document[SpaceDemo.html]
<!DOCTYPE html>
<html>
<head>
<title>Space Demo</title>
</head>
<body>
<h3>
Method 1:
</h3>
<p>
Jony&nbsp;Jony&nbsp;Yes&nbsp;Papa&nbsp&nbsp;&nbsp;&nbsp;&nbsp;Eating
&nbsp;sugar&nbsp;no&nbsp;Papa&nbsp;&nbsp;&nbsp;Open&nbsp;Your&nbsp;
mouth&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Ha!Ha!Ha
</p>
<h3>
Method 2:
</h3>
<p>
Jony Jony Yes Papa Eating sugar no Papa Open Your mouth Ha!Ha!Ha
</p>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 36 Web Essentials and Mark - up Language - HTML

Example 1.12.1 How divide and pound symbol can be put on HTML document ?
SPPU : May-18, Marks 5

Solution : With the help of entity references denoted using & these two symbols can be
put in HTML document. The code can be
<html>
Output
<head>
</head>
<body>
<p>This &divide symbol</p>
<p>This &pound symbol</p>
</body>
</html>

Review Question

1. List and describe any five HTML tags.


SPPU : April-18, Marks 5

1.13 Links
 There is a common practice to specify the web link in the web page. The link acts as
a pointer to some web page or some resource.
 Use of hyperlink in the web page allows that page to link logically with other page.
 We can use hyperlinks by using a tag <a> and by specifying the URL for href.
 The value assigned to href specifies the target of the link.
 The <a> means beginning of the web link and </a> means end of the web link.
 The most important attribute of the <a> element is the href attribute, which indicates
the link's destination.
 By default, links will appear as follows in all browsers :
1) An unvisited link is underlined and blue.
2) A visited link is underlined and purple.
3) An active link is underlined and red.
 Following are the steps to be followed to specify web link in the web page.
Step 1 : The beginning of web link can be specified by the tag <a href = “ “.
Inside the double quotes mention the URL of desired link.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 37 Web Essentials and Mark - up Language - HTML

Step 2 : Write some text that should act as a hyperlink.


Step 3 : End the web link </a>
Here is a sample program which implements the above given idea -
HTML Document [HyperlnkDemo.html]
<!DOCTYPE html>
<html>
<head>
<title> Use of Hyperlink on the web Page </title>
</head>
<body>
click here to get a
<a href="http://www.vtubooks.com">book</a> on engineering
</body>
</html>
Output

If you click on the hyperlink book then you will get the following output.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 38 Web Essentials and Mark - up Language - HTML

The target attribute


 If we want to get that link opened in another window we can mention _target
property. Various targets can be -
 _self loads the page into the current window.
 _blank loads the page into a new separate browser window.
Example 1.13.1 Develop a HTML page to use image as a link to another page.

Solution :
Step 1 : Write the HTML document containing an hyperlink to an image. When we click
on the image the html page referred by the <a href> tag must get opened.
XHTML Document[ImgLink.html]
<!DOCTYPE html>
<html>
<head>
<title> Image Demo </title>
</head>
<body>
<h1> Indian Heritage </h1>
</p>
<a href="TajMahal.html" target ="_blank">
<img src= "TajMahal.jpg" alt= "Taj Mahal!!" />
</a>
<br/>History of Taj Mahal
<br/>
</body>
</html>
Step 2 : Write the HTML document(TajMahal.html) mentioned by the <a href> tag in
Step 1 as follows.
HTML Document[TajMahal.html]
<!DOCTYPE html>
<html>
<head>
<title> Information on TajMahal </title>
</head>
<body>
<h1> Indian Heritage </h1>
<p>
Taj Mahal is one of the wonders of the World. It is located in Agra,India.
<br/>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 39 Web Essentials and Mark - up Language - HTML

Taj Mahal is built by <strong>Shah Jahan</strong> in memory of his wife


<strong>Mumtaz Mahal</strong>
<br/>
It is considered to be the excellent example of Mughal Architecture
</p>
<br/>
</body>
</html>
Step 3 : Open some web browser and specify the file name ImgLink.html in the address
bar and you will get following output.
Output

1.13.1 Playing an Audio File


Using HTML script we can play the audio files. The simplest way to play audio file is
the use of hyperlinks. Following script shows how simple it is to a play a sound file using
HTML
<html>
<body>
<h2>Playing The Audio</h2>
<form>
<a href="chimes.wav">Click here to Play the sound</a>
</form>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 40 Web Essentials and Mark - up Language - HTML

The above script executes in almost all the web browsers such as Internet explorer,
Mozilla Firefox, Opera and so on. But the above HTML document launches the Media
player software and then the audio file is played within it. For playing the audio files
using hyperlinks it is necessary to get the audio file downloaded first.

1.13.2 Uses of Links


 Following are the uses of the hyperlinks for a web document -
1. One can link logically related documents together using the links in the web
page.
2. Use of link enhances the readability of the web document.
3. User can click on the link and can learn more about a subtopic and then can
return to the main topic. This navigation within the web pages is possible due to
the links.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 41 Web Essentials and Mark - up Language - HTML

1.14 Frames
 HTML frames allow us to present documents in
multiple views.
 Using multiple views we can keep certain information
visible and at the same time other views are scrolled
or replaced.
 For example, within the same window, one frame can
display a company information, a second frame can be
Fig. 1.14.1 Frames
a navigation menu and a third frame may display
selected document that can be scrolled through or replaced by navigating in the
second frame.
 Various frames can be set in one browser window.
 To set the frames in the browser window we use frame set.
 For example -
<frameset cols="150,*">

will allow us to divide the window into two columns (i.e. in two vertical frames). One
frame occupying the size of 150 pixels and the other occupies the remaining portion of the
window. Here * means any number of pixels.
 Similarly
<frameset rows="*,120">

will divide the window into two rows (i.e. in two horizontal frames). The second part
of horizontal frame will be of 120 pixels and upper horizontal frame will occupy
remaining portion of the window.
 Similarly we can also specify the frameset in percentage form. For example
<frameset rows="30%,70%">
Using frameset we can divide the rows and columns in any number of frames. For
example
<frameset rows = “20%,30%,50%” cols = “30%,*”>

This will create a frames in the browser’s window as follows -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 42 Web Essentials and Mark - up Language - HTML

Fig. 1.14.2 Frames


 In every layout frame we can load the desired html page by using frame src. For
example
<frame src="D:\\html_examples\\bulleted1.html" name="Left_Vertical">
By this statement we are loading the web page bulleted1.html in the specific frame
and the frame is named as Left_Vertical.

Attributes in frameset tag

Attribute Value Purpose

cols pixels It specifies the number and size


of columns in a frameset
%
*
rows pixels It specifies the number and size
of rows in a frameset.
%
*

Attributes of frame tag


The <frame> tag has no end tag. The <frame> tag defines one frame within a
<frameset> tag. Various attributes of frame tag are,
Attribute Value Purpose

frameborder 0 or 1 Value 1 specifies that the frame is displayed with border and 0
indicates that there is no border.

name Some name It specifies name of the frame

Nosize Due to this attribute we cannot resize the particular frame.

scolling yes, no or It specifies whether or not to display the scrollbar along with the
auto frame.

src URL It specifies the name of the Document to be displayed within the
frame.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 43 Web Essentials and Mark - up Language - HTML

Example of browser containing frame


Step 1 : Create a main HTML document which will display three HTML documents in
three vertical frames.

FrameSet.html
<!DOCTYPE html>
<html>
<frameset cols="25%,*,50%">
<frame src="frame1.html">
<frame src="frame2.html">
<frame src="frame3.html">
</frameset>
</html>

Step 2 : Create frame1.html, frame2.html and frame3.html files as follows –

Frame1.html
<!DOCTYPE html>
<html>
<body>
<h1> Frame 1 </h1>
</body>
</html>

Frame2.html
<!DOCTYPE html>
<html>
<body>
<h1> Frame 2 </h1>
</body>
</html>

Frame3.html
<!DOCTYPE html>
<html>
<body>
<h1> Frame 3 </h1>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 44 Web Essentials and Mark - up Language - HTML

Output

Script explanation : The above HTML document, the <frameset> tag is used to define
frameset. The col attribute is used to create the three column frames.

1.14.1 Frames with Scrollbars


<!DOCTYPE html>
<html>
<frameset cols="25%,*,50%">
<frame src="frame1.html" scrolling=no>
<frame src="frame2.html" scrolling=auto>
<frame src="frame3.html">
</frameset>
</html>
Output

To set the scroll bar we should assign the value auto to the scrolling parameter and if
we do not want the scroll bar accompanying the frame then we must assign the value no
to the scrolling parameter.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 45 Web Essentials and Mark - up Language - HTML

Example 1.14.1 Create XHTML document that has two frames. The left frame displays the
contents.html and the right frame displays the cars.html where second frame is the target of
link from the first frame. [Note : Contents.html is a list of links for the cars description].
Solution :
Step 1 : We will create the basic html file that contains the left and right frames. The
HTML document is as follows :
CarDemo.html
<!DOCTYPE html >
<html>
<head>
<title>My Frames Page</title>
</head>
<frameset cols="50%,50%">
<frame src="contents.html" name="Left_Vertical" noresize />
<frame src="Description.html" name="Right_Vertical" scrolling=no/>
</frameset>
</html>
Step 2 : Following is a HTML document that displays the contents that are loaded at
first. The left frame HTML document is as follows –

contents.html
<!DOCTYPE html >
<html >
<head>
<title>My Frames Page</title>
</head>
<body>
<h3>
<a href="Innova.html" target="Right_Vertical">Toyota Innova</a>
<h3/>
<h3>
<a href="Scorpio.html" target="Right_Vertical">Mahindra Scorpio</a>
<h3/>
<h3>
<a href="Etios.html" target="Right_Vertical">Toyota Etios Liva</a>
<h3/>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 46 Web Essentials and Mark - up Language - HTML

The right frame HTML document is as follows -

Description.html
<!DOCTYPE html >
<html >
<head>
<title>My Frames Page</title>
</head>
<body>
<center>
<h3> WELCOME <h3/>
This page displays the details of a car you have chosen.
</center>
</body>
</html>
Step 3 : Following are the three html documents each containing the description of each
car.

Innova.html
<!DOCTYPE html >
<html>
<head>
<title>My Frames Page</title>
</head>
<body>
<h2> TOYOTA INNOVA</h2>
<ul type="disc">
<li>Price: Rs.9,35,731-Rs.14,82,852</li>
<li><td>Mileage: </td><td>10Kmpl(City) and 13 Kmpl(hwy)</li>
</ul>
</body>
</html>

Scorpio.html
<!DOCTYPE html>
<html >
<head>
<title>My Frames Page</title>
</head>
<body>
<h2> MAHINDRA SCORPIO</h2>
<ul type="disc">
<li>Price: </td><td>Rs.7,49,583-Rs.12,85,479</li>
<li>Mileage: </td><td>12Kmpl(City) and 16 Kmpl(hwy)</li>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 47 Web Essentials and Mark - up Language - HTML

</ul>
</body>
</html>

Etios.html
<!DOCTYPE html>
<html >
<head>
<title>My Frames Page</title>
</head>
<body>
<h2> TOYOTA ETIOS LIVA</h2>
<ul type="disc">
<li> Price: </td><td>Rs.4,46,276-Rs.6,86,426</li>
<li> Mileage: </td><td>17Kmpl(City) and 19 Kmpl(hwy)</li>
</ul>
</body>
</html>
Step 4 : Open the suitable web browser and invoke the CarDemo.html(created in Step 1),
the output will be as follows -

Example 1.14.2 Create a HTML document for a company home page and explain.

Solution : For creation of this web page the frames are used.
Step 1 : The main page is created as follows -

Main.html
<?xml version = "1.0" encoding ="utf-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Frameset//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<frameset rows="20%,80%">
<frame src="logo.html">
<frameset cols="30%,70%">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 48 Web Essentials and Mark - up Language - HTML

<frame src="menu.html">
<frame src="contents.html">
</frameset>
</frameset>
</html>
Step 2 : In the main page a layout of the company home page is created. Various html
files that are called in this HTML document are as given below -
Menu.html
<html>
<head><title>LOGO</title></head>
<body bgcolor="aqua">
<h3><a href="about.html"> About us<a/></h3>
<h3><a href="download1.html"> Free Downloads<a/></h3>
<h3><a href="download2.html"> Download Catalogue<a/></h3>
<h3><a href="download3.html">Download Orderform<a/></h3>
<h3><a href="catalogues.html">Catalogues<a/></h3>
<h3><a href="distributors.html">Distributors<a/></h3>
<h3><a href="Contacts.html">Contact Us<a/></h3>
<h3><a href="feedback.html">Feedback<a/></h3>
</body>
</html>

Logo.html
<html>
<head><title>LOGO</title></head>
<body bgcolor="magenta">
<h1><img src="books.jpg"/> Technical Publications</h1>
</body>
</html>

Contents.html
<html>
<head><title>LOGO</title></head>
<body bgcolor="khaki">
<center>
<h2>BOOKS</h2>
</center>
<p>TECHNICAL PUBLICATIONS is known for commitment to quality and innovation. We are
Leaders in our chosen scholarly and educational markets, serving the book Industry & Academic
Institutions.
</p>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 49 Web Essentials and Mark - up Language - HTML

<p>We have been in the industry for the last 18 years and are known for the quality and scholarly
publications in Engineering books. We publish more than 1000 titles of text books, for various
Universities across the India.
</p>
<p>We are specialized in Engineering text books and have been publishing titles for various
Engineering branches such as Electrical, Electronics, Computer Science, Information
Technology,Mechanical etc. and other management
books.
</p>
</body>
</html>
Step 3 : Open the suitable web browser and type the address for main.html. The output
will be as follows -

1.15 Lists
 List is nothing but the collections of items or elements. There are two types of lists -
unordered lists and ordered lists.
 The unordered list is useful for simply listing the items but if we want the items in
some specific sequence then the ordered lists are used. Let us discuss how to use
these types lists in the HTML document.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 50 Web Essentials and Mark - up Language - HTML

1.15.1 Unordered List


Following HTML document makes use of unordered list.
HTML Document [UnordLstDemo.html]
<!DOCTYPE html>
<html>
<head>
<title> Use of Unordered List </title>
</head>
<body>
<h2>All About Computer ...</h2>
Following are some popular operating systems used in computer
<ul type="disc">
<li>DOS</li>
<li>Windows 98</li>
<li>Windows XP</li>
<li>Windows Professional</li>
<li>Windows Vista</li>
<li>Unix</li>
</ul>
Following are some core subjects on computer science
<ul type="circle">
<li>Operating system</li>
<li>Computer Network</li>
<li>Database management Systems</li>
<li>Web Programming</li>
<li>Software Engineering</li>
</ul>
Following are some popular Web browsers
<ul type="square">
<li>Intenet Explorer</li>
<li>Mozilla Firefox</li>
<li>Netscape Navigator</li>
</ul>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 51 Web Essentials and Mark - up Language - HTML

Output

Script explanation :
In above script we have used the tag <ul> for specifying the unordered list. The list
items can be mentioned using the tag <li> Due to which the list items can appear in
bulleted form. The style of the bullet can be as given below -

tags meaning

<ul> and </ul> Beginning and end of the bulleted list

<li> and </li> Displays the bulleted text on separate line.

<ul type=”circle”> Displays the circular bullets.

<ul type=”disc”> Displays the solid round bullets.

<ul type=”square”> Displays the squared bullets.

1.15.2 Ordered List


The ordered list is a list of items which must follows some specific sequence. We can
number the text using <ol> tag. Following table shows various styles by which the list can
be numbered.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 52 Web Essentials and Mark - up Language - HTML

Tags Meaning

<ol> and </ol> Beginning and end of the numbered list

<li> and </li> Displays the numbered text on separate line.

<ol type=“A”> Displays the list in following manner

A.

B.

C.

<ol type=“i”> Displays the list in following manner

i.

ii.

iii.

<ol type=“I”> Displays the list in following manner

I.

II.

III.

<ol type=“1”> Displays the list in following manner

1.

2.

3.

Here is one illustrative program -

HTML Document [OrdLstDemo.html]


<!DOCTYPE html>
<html>
<head>
<title> Ordered List Demo </title>
</head>
<body>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 53 Web Essentials and Mark - up Language - HTML

<h4>This is a typical List</h4>


<ol type="A">
<li>First</li>
<li>Second</li>
<li>Third</li>
<li>Forth</li>
<li> and so on</li>
</ol>
<h4>The list is starting from 5</h4>
<ol start="5">
<li>Ice cream</li>
<li>Mango</li>
<li>Juice</li>
<li>Pop Corn</li>
<li> and so on</li>
</ol>
</body>
</html>
We can have the nested ordered list. Here is an example of it.
Output

HTML Document [OrdLstDemo1.html]


<!DOCTYPE html>
<html>
<head>
<title> Ordered List Demo </title>
</head>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 54 Web Essentials and Mark - up Language - HTML

<body>
<h4>Information of Nations</h4>
<ol type="1">
<li>India
<ol type="i">
<li>National Bird: Peacock</li>
<li>National animal:Tiger</li>
<li>National game:Hockey</li>
</ol>
</li>
<li>Australia
<ol type="i">
<li>National Bird: Emu</li>
<li>National animal:Kangaroo</li>
<li>National game:Cricket</li>
</ol>
</li>
</ol>
</body>
</html>
Output

1.16 Tables
 For systematic arrangement of information we often require tabular structure.
HTML allows us to create tables on the web pages.
 Many web designers are using invisible tables on the web pages.
 The biggest advantage of using tables on the web pages is that the information gets
arranged systematically.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 55 Web Essentials and Mark - up Language - HTML

 The table is a matrix of rows and columns and the area formed due to intersection
of a row and a column is called cell.

1.16.1 Basic Table Structure


 To create a table on the web page the table beginning tag is <table> and </table> tag
is used for ending the table.
 Within <table> … </table> tag we can create rows and columns.
 The rows are created using <tr> </tr> and columns are created using <td> </td>
 For example -
<table>
<tr> One Two Three
<td> <td> <td>
<tr> Four Five Six
<td> <td> <td>
<tr> Seven Eight Nine
<td> <td> <td>

HTML Document[TabDemo.html]

<!DOCTYPE html>
<html>
<head>
<title> Table Demo </title>
</head>
<body>
<br/><br/>
<center>
<table border="5">
<caption align="bottom">
<b> Table Demo </b>
</caption>
<tr>
<td>This is Left cell-row 1</td>
<td>This is Right cell -row 1</td>
</tr>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 56 Web Essentials and Mark - up Language - HTML

<tr>
<td>This is Left cell-row 2</td>
<td>This is Right cell-row 2</td>
</tr>
</table>
</center>
</body>
</html>

Output

Script Explanation

1) In above program, the parameter border = “5” is set in order to set the table border.
You can give any value to set the desired border.

2) The caption to the table is given by the parameter caption, we can set this caption
either at the top or at the bottom by using the parameter align.

3) Then using the tag <tr> the table row can be set. The <td> tag is used to create
columns from left to right.

4) Thus in the above program we are filling up the table values from top to bottom
and from left to right. Just refer the output provided along with the program for
clear understanding of look and feel of the table.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 57 Web Essentials and Mark - up Language - HTML

Example 1.16.1 Write HTML document to create a table with header to each column.
Solution : We can set the header to each column of the table by <th> tag. Here is a simple
HTML program that simply adds the header to each column.
HTML Document [TabDemo1.html]
<!DOCTYPE html >
<html >
<head>
<title> Table Demo </title> Output
</head>
<body>
<br/><br/>
<center>
<table border="3">
<caption align="bottom">
<b> Students Record </b>
</caption>
<th>Name</th>
<th>Marks</th>
<tr align=center>
<td>Lekhana</td>
<td>89</td>
</tr>
<tr align=center>
<td>Savita</td>
<td>92</td></tr>
</tr>
</table>
</center>
</html>
The data in each row can be aligned centrally by using <tr align=center> Other types of
alignment can be left or right by <tr align=left> or <tr align=right> respectively.

Example 1.16.2 Discuss the process of dividing the table into columns with an example. How
would you give headers to the table columns ?

Solution : The process of dividing the table into column is as follows :


1. Create a table using the tag <table>.
2. Set the border to the table using attribute border=”some value”.
3. Create rows using the tag <tr> and for each row create the columns using <td>
</td> tags.
4. The header for the table column can be given using the tag <th> </th>.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 58 Web Essentials and Mark - up Language - HTML

Example 1.16.3 Following HTML document divides the table in columns and gives the header
to the column.

Solution :
<!DOCTYPE html>
<html>
Output
<head>
<title>Table Demo</title>
</head>
<body>
<table border ="1">
<th>Name</th>
<th>Marks</th>
<tr>
<td>AAA</td>
<td>50</td>
</tr>
<tr>
<td>BBB</td>
<td>90</td>
</tr>
</table>
</body>
</html>

1.16.2 RowSpan and ColSpan


 Sometimes we may require adding sub-columns or sub-rows to categorize the
information properly. In such a situation colspan and rowspan can be used.
 The rowspan is used to extend the row vertically and colspan is used to extend the
column horizontally.
For example -
When rowspan = 2 then the row can be extended vertically by two cells.
rowspan First Second <td rowspan=2>First
Third <td>Second</td><td>Third</td>
When colspan=2 then the column can be extended horizontally by two cells.
First Second <td>First <td>Second
Third <td colspan=2>Third

colspan

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 59 Web Essentials and Mark - up Language - HTML

Example 1.16.4 Explain the structure of HTML. Write code to display following table.

College Name
Sr. No. Section A Section B
X Y X Y
1
2
3

Solution : ImageDemo.html
<html>
<head>
<title>My Table</title>

</head>
<body>
<table border=1>
<tr>
<td rowspan="3">
<p align=center>Sr.No.</p>
<p>&nbsp</td>
</td>

<td colspan="4">
<p align="center">College Name</p>
</td>
</tr>
<tr>
<td width="40%" colspan="2" align="center">Section A</td>
<td width="40%" colspan="2" align="center">Section B</td>
</tr>
<tr>
<td align="center">X</td>
<td align="center">Y</td>
<td align="center">X</td>
<td align="center">Y</td>
</tr>
<tr>
<td align="center">1</td>
<td align="center">&nbsp</td>
<td align="center">&nbsp</td>
<td align="center">&nbsp</td>
<td align="center">&nbsp</td>
</tr>
<tr>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 60 Web Essentials and Mark - up Language - HTML

<td align="center">2</td>
<td align="center">&nbsp</td>
<td align="center">&nbsp</td>
<td align="center">&nbsp</td>
<td align="center">&nbsp</td>
</tr>
<tr>
<td align="center">3</td>
<td align="center">&nbsp</td>
<td align="center">&nbsp</td>
<td align="center">&nbsp</td>
<td align="center">&nbsp</td>
</tr>
</table>
</body>
</html>
Output

Example 1.16.5 Write HTML code to draw table given below :

Image (20%) Company Name (80%)

Schedule

1
Type 1
2

3
Type 2
4

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 61 Web Essentials and Mark - up Language - HTML

Solution : ImageDemo.html
<html>
<head>
<title>My Table</title>
</head>
<body>
<table border=1>
<tr>
<td width="20%" align=center><img src="logo.jpg"/></td>
<th width="80%" align=center>TopTech Solutions</th>
</tr>
<tr>
<td>&nbsp</td>
<td align=center>Schedule</td>
</tr>
<tr>
<td align=center>1</td>
<td rowspan="2" align=center>Type 1</td>
</tr>
<tr>
<td align=center>2</td>
</tr>
<tr>
<td align=center>3</td>
<td rowspan="2" align=center>Type 2</td>
</tr>
<tr>
<td align=center>4</td>
</tr>
</table>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 62 Web Essentials and Mark - up Language - HTML

Example 1.16.6 Write HTML code to draw table given below.

Items Price

Shirt Trouser `. 1000/-

`. 400/- `. 600/-

Solution :
<html> Output
<head>
<title>Item-Price List</title>
</head>
<body>
<table border=1>
<tr>
<th colspan="2"><center>Items</center></th>
<th>Price</th>
</tr>
<tr>
<th><center>Shirt</center></th>
<th><center>Trouser</center></th>
<td rowspan="2"><center>Rs.<br/>1000/-</center></td>
<tr>
<td><center>Rs.400/-</td>
<td><center>Rs.600/-</td>
</tr>
</table>
</body>
</html>

Example 1.16.7 Write HTML code which includes table, Hyperlink, character formatting
ordered and unordered list to display your resume.

Solution : resume.html
<html>
<head>
<title>RESUME APPLICATION</title>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 63 Web Essentials and Mark - up Language - HTML

</head>
<body>
<center><h2>RESUME</h2></center>
<a href="my_photo.jpg">PHOTO</a>
<br/><br/>
<strong>Name: </strong> Mr.Sachin Patil<br/>
<strong>Address: </strong> D10,SunEmpire,SunCityRd,Pune<br/>
<strong>Sex: </strong>Male<br/>
<strong>Phone: </strong>9229229221<br/>
<strong>Email: </strong>[email protected]
<br/><br/>
<strong>Educational Qualification:</strong>
<table border=2>
<tr>
<th>Examination</th>
<th>Year Of Passing</th>
<th>Board/University</th>
<th>Marks obtained</th>
</tr>
<tr>
<td>S.S.C</td><td>1991</td><td>Pune</td><td>93%</td>
</tr>
<tr>
<td>H.S.C</td><td>1993</td><td>Pune</td><td>90%</td>
</tr>
<tr>
<td>B.E.(Computer)</td><td>1997</td><td>Pune</td><td>72%</td>
</tr>
<tr>
<td>M.Tech(Computer)</td><td>2001</td><td>IIT(Kanpur)</td><td>A grade</td>
</tr>
</table>
<strong>
<br/><br/>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 64 Web Essentials and Mark - up Language - HTML

Programming Languages known : Output


</strong>
<ul>
<li>Cobol
<li>C
<li>C++
<li>Visual C++

<li>Visual Basic
<li>Java
</ul>
<br/><br/>
<div align=left>Date:</div>
<div align=right>Place:</div>
<br/>
<div align=left>Signature</div>
</body>
</html>

Example 1.16.8 Create the following table using HTML tags.

Name of Train Place Destination Time Arrival Departure Fare

Rajdhani Mumbai Delhi 07.30 08.45 Rs. 989.00

Madras Mail Mumbai Madras 09.00 10.15 Rs. 450.00

Konkan Exp. Mumbai Manglore 13.30 14.45 Rs. 756.00

Deccan Exp. Mumbai Pune 16.00 17.30 Rs. 345.00

Solution :
<html>
<head>
<title> Train Time Table </title>
</head>
<body>
<table border="1">
<tr>
<th rowspan=2>Name of Train</th>
<th rowspan=2>Place</th>
<th rowspan=2>Destination</th>
<th colspan=2>Time</th>
<th rowspan=2>Fare</th>
</tr>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 65 Web Essentials and Mark - up Language - HTML

<tr><th>Arrival</th><th>Departure</th></tr>
<tr>
<td>Rajdhani</td><td>Mumbai</td><td>Delhi</td>
<td>7.30</td><td>08.45</td>
<td>Rs.989.00</td>
</tr>
<tr>
<td>Madras Mail</td><td>Mumbai</td><td>Madras</td>
<td>09.00</td><td>10.15</td>
<td>Rs.450.00</td>
</tr>
<tr>
<td>Konkan Exp.</td><td>Mumbai</td><td>Manglore</td>
<td>13.30</td><td>14.45</td>
<td>Rs.756.00</td>
</tr>
<tr>
<td>Deccan Exp.</td><td>Mumbai</td><td>Pune</td>
<td>16.00</td><td>17.30</td>
<td>Rs.345.00</td>
</tr>

</table>
</body>
</html>
Output

Example 1.16.9 Differentiate between <table width=”400” height=”200”> and <table


width=”100%” and height=”50%”>.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 66 Web Essentials and Mark - up Language - HTML

Solution : i) <table width=”400” height=”200”> denotes that the table width is 400 pixels
and height is 200 pixels. It denotes the absolute value.
For example
<html>
<head>
</head>
<body>
<table border="1" width="100" height="50">
<tr>
<th>Name</th>
<th>City</th>
<th>Age</th>
</tr>
<tr>
<td>AAA</td><td>Mumbai</td><td>10 yrs.</td>
</tr>
<tr>
<td>BBB</td><td>Pune</td><td>20 yrs.</td>
</tr>
<tr>
<td>CCC</td><td>Chennai</td><td>50 yrs.</td>
</tr>
</table>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 67 Web Essentials and Mark - up Language - HTML

ii) On the other hand <table width=”100%” and height=”50%”> denotes the width of
the table is 100% of the screen and height is 50% of the browser screen. It denotes
the relative value.

For example
<html>
<head>
</head>
<body>
<table border="1" width="100%" height="50%">
<tr>
<th>Name</th>
<th>City</th>
<th>Age</th>
</tr>
<tr>
<td>AAA</td><td>Mumbai</td><td>10 yrs.</td>
</tr>
<tr>
<td>BBB</td><td>Pune</td><td>20 yrs.</td>
</tr>
<tr>
<td>CCC</td><td>Chennai</td><td>50 yrs.</td>
</tr>
</table>
</body>
</html>

Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 68 Web Essentials and Mark - up Language - HTML

1.16.3 Additional Table Elements


There are some additional tables that can add additional meaning and accessibility to
the table. For example -
1. The <caption> element :
 The <caption> tag defines a table caption.
 The <caption> tag must be inserted immediately after the <table> tag.
 For example –
<!DOCTYPE html>
<html>
<head>
<style>
table,th,td{
border:1px solid black;
}
</style>
</head>
<body>
<table>
<caption>Student Information</caption>
<tr> Output
<th>RollNo</th>
<th>Name</th>
</tr>
<tr>
<td>1</td>
<td>AAA</td>
</tr>
Table
<tr>
Caption
<td>2</td>
<td>BBB</td>
</tr>
<tr>
<td>3</td>
<td>CCC</td>
</tr>
</table>
</body>
</html>

2. The <col> and <colgroup> element :


 The <col> tag specifies column properties for each column within a <colgroup>
element.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 69 Web Essentials and Mark - up Language - HTML

 The <col> tag is useful for applying styles to entire columns, instead of repeating
the styles for each cell, for each row.
 For example –
<!DOCTYPE html>
<html>
<head>
<style>
table, th, td {
border: 1px solid black;
}
</style>
</head>
<body>

<table>
<colgroup>
<col span="2" style="background-color:pink">
<col span="2" style="background-color:aqua">
</colgroup>
<tr>
<th>RollNo</th>
Output
<th>Name</th>
<th>City</th>
<th>Marks</th>
</tr>
<tr>
<td>1</td>
<td>AAA</td>
<td>Pune</td>
<td>78</td>
</tr>
<tr>
<td>2</td>
<td>BBB</td>
<td>Mumbai</td>
<td>88</td>
</tr>
<tr>
<td>3</td>
<td>CCC</td>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 70 Web Essentials and Mark - up Language - HTML

<td>Bangalore</td>
<td>97</td>
</tr>
<tr>
<td>4</td>
<td>DDD</td>
<td>Hyderabad</td>
<td>84</td>
</tr>
</table>
</body>
</html>

3. The <tbody>,<thead> and <tfoot>elements

 The <tbody> tag is used to group the body content in an HTML table.
 The <tbody> element is used in conjunction with the <thead> and <tfoot> elements
to specify each part of a table such as body, header, and footer.
 For example –
<!DOCTYPE html>
<html>
<head>
<style>
table, th, td {
border: 1px solid black;
}
thead {color:red;}
tbody {color:green;}
tfoot {color:blue;}
</style>
</head>
<body>

<table>
<thead>
<tr>
<th>RollNo</th>
<th>Name</th>
<th>City</th>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 71 Web Essentials and Mark - up Language - HTML

<th>Marks</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>AAA</td>
<td>Pune</td>
<td>78</td>
Output
</tr>
<tr>
<td>2</td>
<td>BBB</td>
<td>Mumbai</td>
<td>88</td>
</tr>
<tr>
<td>3</td>
<td>CCC</td>
<td>Bangalore</td>
<td>97</td>
</tr>
<tr>
</tbody>
<tfoot>
<td>4</td>
<td>DDD</td>
<td>Hyderabad</td>
<td>84</td>
</tr>
</tfoot>
</table>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 72 Web Essentials and Mark - up Language - HTML

1.17 Images
 We can display images as a link. We have to use the <img src =“ ” > tag for this
purpose.
 Within the double quotes image file should be mentioned. Normally .gif or .jpg files
are used to display the images on the web browser.
 Example
 Following HTML Script shows how to insert an image in the web page.
HTML Document [imagedemo.html]
<!DOCTYPE html>
<html>
<head>
<title> Image Demo </title>
</head>
<body>
<h1> Indian Heritage </h1>
<p>
In India, People celebrate the festival of light <br/>
Which is called as <strong>Diwali</strong>
</p>
<img src= "lamp1.jpg" alt= "Light!!" />
<br/>
Diwali suggests us to enlighten our life with hope,health and wealth
<br/>
</body>
</html>
Output

Script explanation : In above script we have used <img /> tag in order to display an image.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 73 Web Essentials and Mark - up Language - HTML

The image tag has two attributes -


 The src suggests us to give the image file name. If the desired image is not present
in the current directory of web page then the complete path where the image is
located must be given.
 The alt attribute displays the text when it is not possible to display the image. For
instance - in above given imagedemo.html script if, the lamp1.jpg is not present
then we will get following output.

Types of Images
 There are two types of images that are more commonly used -
1. Graphic Interchange Format (GIF) : It uses 8-bit color representation for pixels.
Hence a single pixel can have 256 different colors. This file have the extension
.gif.
2. Joint Photographic Expert Group (JPEG) : This format uses 24-bit color
representation for pixel. Hence a JPEG can have 16 million different colors. The
file have the extension .jpg or .jpeg.

The JPEG image have more color information than a GIF image. Secondly JPEG can be
smaller than GIF image. Hence normally JPEG image is preferred. But the drawback of
JPEG is that it does not support transparency.

1.18 Forms
 Form is a typical layout on the web page by which a user can interact with the web
page.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 74 Web Essentials and Mark - up Language - HTML

 Typical component of forms are text, text area, checkboxes, radio buttons and push
buttons.
 HTML allows us to place these form components on the web page and send the
desired information to the destination server.
 All these form contents appear in the <form> tag. The form has an attribute action
which gets executed when user clicks a button on the form.
 Various attributes of form are –

Attribute Description

action It specifies the url where the form should be submitted.

method It specifies the HTTP methods such as GET, POST

name This attribute denotes the name of the form.

target It specifies the target of the address in the action attribute.

Let us learn various form components with the help of simple HTML documents.

1.18.1 Text
 Text is typically required to place one line text. For example if you want to enter
some name then it is always preferred to have Text field on the form.
 The text field can be set using
<input type="text" size=”30” name =”username” value=" ">
The input type is text and the value of this text field is “ ” That means the blank text
field is displayed initially and we can enter the text of our choice into it. There is size
parameter which allows us to enter some size of the text field.
 Some other parameters or attributes can be
o maxlength that allows us to enter the text of some maximum length.
o name indicates name of the text field.
o align denotes the alignment of the text in the text field. The alignment can
be left, right, bottom and top.

Example code

HTML Document [TextDemo.html]


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 75 Web Essentials and Mark - up Language - HTML

<title>My Page</title>
</head>
<body>
<form>
<b>Input String:</b><br/><input type="text" size="25" value="">
</form>
</body>
</html>

Output

Script explanation : In above document


1) We have the label “Input String” just before the <input> tag. We can also specify
the label by using the <label> tag as follows -
<label>Input String: <br/><input type="text" size="25" value=""></label>
2) Thus the label gets bound to the text box. This aspect is always beneficial for a
web programmer because using label control we can focus on the corresponding
text box contents.
3) Initially the text box field is blank. We can type some text inside this text box.

Example 1.18.1 How will you create password field in a HTML form ?

Solution : The password field is typically created on the form. Hence following code can
be written to create it -
<form name=”form1”>
Password:<input type=”password”/>
</form>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 76 Web Essentials and Mark - up Language - HTML

1.18.2 Text Area


Text field is a form component which allows us to enter single line text, what if we
want to have multiple line text? Then you must use textarea component.

HTML Document [TextareaDemo.html]


<!DOCTYPE html>
<html>
<head>
<title>My Page</title>
</head>
<body>
<form>
Enter the Desired text here
<textarea cols="40" rows="5" name="myname">
</textarea>
</form>
</body>
</html>
Output

Various parameters that can be set for the text area can be,

 row denotes total number of rows in the text area.


 col specifies total number of columns in the text area.
 name denotes the name of the text area which can be utilised for handling
that component for some specific purpose.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 77 Web Essentials and Mark - up Language - HTML

 wrap can be virtual or physical. If the wrap is virtual then the line breaks
get disappeared when the text is actually submitted to the server. But if the
wrap is assigned to the physical then the line breaks (if any) appear as it is
in the text.

1.18.3 Checkbox
 It is the simplest component which is used particularly when we want to make
some selection from several options.
 For having the checkbox we have to specify the input type as checkbox. For
example
<input type="checkbox" name="option1" value="mango"
checked="checked">Mango<br/>
 If we want to get the checkbox displayed as checked then set checked="checked"

Example Code

HTML Document[ChkBoxDemo.html]
<!DOCTYPE html>
<html>
<head>
<title>My Form with Check box</title>
</head>
<body>
<form name ="checkboxForm">
<div align="center"><br>
Select the fruit(s) of your choice<br/>
<input type="checkbox" name="option1" value="mango"
checked="checked">Mango<br/>
<input type="checkbox" name="option2" value="apple">Apple<br/>
<input type="checkbox" name="option3" value="guava">Guava<br/>
</div>
</form>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 78 Web Essentials and Mark - up Language - HTML

Output

Script explanation
1) In the above program to set some checkbox in checked state we can
mention the attribute checked as checked.
2) We can set the value attribute as “ “ but this then the checkbox will not
get associated with any value. The Mango, Apple and Guava are the
labels of the checkboxes.

1.18.4 Radio Button


 This form component is also use to indicate the selection from several choices.
 Using input type=“radio” we can place radio button on the web page.
 This component allows us to make only one selection at a time.
 We can create a group of some radio button component.
 Following HTML document displays the radio buttons for two different groups.
HTML Document[RadioButDemo.html]
<!DOCTYPE html>
<html >
<head>
<title>My Form with radio buttons Page</title>
</head>
<body>
<form name="myform">
<div align="left"><br>
<b>Select Fruit which you like the most</b><br/>
<input type="radio" name="group1" value="Mango">Mango<br/>
<input type="radio" name="group1" value="Apple" checked> Apple<br/>
<input type="radio" name="group1" value="Grapes"> Grapes

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 79 Web Essentials and Mark - up Language - HTML

<br/><br/><br/>
<b>Select Flower which you like the most</b><br/>
<input type="radio" name="group2" value="Rose"> Rose<br/>
<input type="radio" name="group2" value="Lotus">Lotus<br/>
<input type="radio" name="group2" value="Jasmine" checked>Jasmine<br/>
</div>
</form>
</body>
</html>
Output

Example 1.18.2 What is the difference between group of checkbox buttons and group of radio
buttons ?
Solution :
 The checkbox and radio buttons are used for making the selection from a
group of choices.
 When a user selects (checks) a checkbox, its value gets assigned as the
current value of the checkbox group's control name.
 A checkbox group's control name may get paired with several current
values if the user selects more than one checkbox.
 Radio buttons work just like checkboxes except they are typically set up to
be mutually exclusive of one another, i.e. when one is selected, all the
others are automatically deselected.

1.18.5 Button
 We can create the button using <input type =”button”> tag.
 There are two types of buttons that can be created in HTML. One is called
submit button and the another one is reset button.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 80 Web Essentials and Mark - up Language - HTML

 Various parameters of submit button are :


1) name denotes the name of the submit button.
2) value is for writing some text on the text on the button.
3) align specifies alignment of the button.

Example code

HTML Document[Button.html]
<!DOCTYPE html>
<html >
<head>
<title> My Page </title>
</head>
<body>
<form name="myform" action="http://www.localhost.com/cgi-bin/hello.cgi" method="POST">
<div align="center">
<br/><br/>
<input type="text" size="35" value=" ">
<br><input type="submit" value="Send">
<input type="reset" value="Reset"><br>
</div>
</form>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 81 Web Essentials and Mark - up Language - HTML

Script explanation
1) In above HTML document, we have used the form whose name is “myform”.
2) There are two attributes associated with the form tag and those are action and
method. The action parameter indicates the address and the cgi script where the
contents should go and method parameter is for the methods for submitting the
data. The method can be get or post. Thus by specifying the action and method
for a form we can send the desired data at desired location.

1.18.6 Menus
 HTML allows us to have pop down menu on the web page so that the
desired selection can be made.
 The parameter select is for the menu component and option parameter is
for setting the values to the options of drop down menu.
 We can make some specific option selected by selected value = .
 In the following HTML document we have created one drop down menu
in which various fruits are enlisted. By default “Banana” is set as selected.

HTML Document [Menu.html]


<!DOCTYPE html>
<html >
<head>
<title> My Page </title>
</head>
<body>
<form name="myform">
<div align="center">
<select name="My_Menu">
<option value="Mango">Mango</option>
<option value="Strawberry">Strawberry</option>
<option selected value="Banana">Banana </option>
<option value="Apple">Apple</option>
</select>
</div>
</form>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 82 Web Essentials and Mark - up Language - HTML

Output

Example 1.18.3 Create a HTML document that has the form with the following controls

a) A text box to collect the customer name.


b) Four checkboxes, one for the following items :
i. Four HTML textbooks for ` 1000 ii. Eight XML textbooks for ` 2000
iii. Four Javabeans books for ` 2500 iv. Eight UML textbooks for ` 1500
c) A collection of radio buttons that are labelled as follows –
i. Cash ii. Cheque/DD iii. Credit card.

Solution :
<!DOCTYPE html>
<html >
<body>
<center><h2>REGISTRATION FORM</h2></center>
<hr/>
<form>
<table>
<tr>
<td>Name:</td>
<td><input type="text" size="25"value=""></td>
</tr>
<tr>
<td>Select the desired Items:</td>
<td>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 83 Web Essentials and Mark - up Language - HTML

<select name="f">
<option value="4 HTML Books(Rs. 1000)">4 HTML Books(Rs. 1000)</option>
<option value="8 XML Books(Rs. 2000)">8 XML Books(Rs. 2000)</option>
<option value="4 JavaBeans Books(Rs.2500)">4 JavaBeans Books(Rs.2500)</option>
<option value="8 UML Books(Rs.1500)">8 UML Books(Rs.1500)</option>
</select>
</td>
</tr>
<tr>
<td>
Mode of Payment:
</td>
</tr>
<tr>
<td><input type="radio" name="group1" value="Cash">Cash</td>
</tr>
<tr>
<td><input type="radio" name="group1" value="Cheque/DD">Cheque/DD</td>
</tr>
<tr>
<td><input type="radio" name="group1" value="Credit Card">Credit Card</td>
</tr>
<tr></tr><tr></tr><tr></tr>
<td><input type="submit" value="Submit"></td>
<td><input type="reset" value="Reset"></td>
</tr>
</table>
</form>
</body>

Example 1.18.4 Write a form to collect details of a user such as name, address, radio button to
choose subject of book he wants to buy, dropdown to choose favorite author, comments for the
last book he read.
Solution :
<!DOCTYPE html >
<html >
<head>
<title>My Page</title>
</head>
<body>
<form>
<b>Name:</b><input type="text" size="20" value=""><br/>
<b>Address:</b><input type="text" size="35" value=""><br/>
<b>Subjects:</b><br/>
<input type="radio" name="authors" value="Web Programming">Web Programming<br/>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 84 Web Essentials and Mark - up Language - HTML

<input type="radio" name="authors" value="Computer Network">Computer


Network<br/>
<input type="radio" name="authors" value="Software Engineering">Software
Engineering<br/>
<input type="radio" name="authors" value="Data Structures">Data Structures<br/>
<b>Select favorite Author:</b>
<select name="MyMenu">
<option value="AAA">AAA</option>
<option value="BBB">BBB</option>
<option value="CCC">CCC</option>
<option value="DDD">DDD</option>
</select>
</br>
<b>Comments:</b></br>
<textarea cols="30" rows="10" name="comments">
</textarea>
<br/><br/>
<input type="submit" value="Submit"/>
<input type="reset" value="Clear"/>
</form>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 85 Web Essentials and Mark - up Language - HTML

Example 1.18.5 Design a simple HTML form for registration of a student.

Solution : HTML Form for Student Registration


<!DOCTYPE html>
<html >
<head>
<title>My Page</title>
</head>
<body>
<form>
<b>Student Name:</b><input type="text" size="20" value=""><br/><br/>
<b>Address:</b><input type="text" size="35" value=""><br/><br/>
<b>Email:</b><input type="text" size="20" value=""><br/><br/>
<b>Password:</b><input type="password" size="10" value=""><br/><br/>
<b>Select Course:</b><br/><br/>
<input type="radio" name="courses" value="Computer Engineering">Computer
Engineering<br/><br/>
<input type="radio" name="courses" value="E&TC Engineering">E&TC
Engineering<br/><br/>
<input type="radio" name="courses" value="Mechanical Engineering">Mechanical
Engineering<br/><br/>
<input type="radio" name="courses" value="Civil Engineering">Civil
Engineering<br/><br/>
<b>Select Payment Mode:</b>
<select name="MyMenu">
<option value="Cheque">Cheque</option>
<option value="Cash">Cash</option>
<option value="Card">Card</option>
</select>
<br/><br/><br/>
<input type="submit" value="Submit"/>
<input type="reset" value="Clear"/>
</form>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 86 Web Essentials and Mark - up Language - HTML

Output

1.19 HTML5 SPPU : May-19, Dec.-19, Marks 5

 The HTML 5.0 is the fifth revision of HTML standard of World Wide Consortium
(W3C) which is finalized in October 2014.
 The earlier version was HTML 4.0 which was released in 1997.
 The objective of this markup language version was - i) To provide support for latest
multimedia and ii) To make the script readable and consistently understood by the
developer.
 The HTML5 adds many new syntactic features. It includes the elements such as
<video>, <audio> and <canvas> elements. It also has integration of Scalable Vector
Graphics (SVG) contents and MathML for mathematical Formula.

1.19.1 Features of HTML 5.0


1. The XHTML doctype is just impossible to memorize (!DOCTYPE html
PUBLIC "…). Hence a new HTML doctype is <!DOCTYPE html>.
2. There are new graphic elements such as <canvas> and <svg> in HTML5.0.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 87 Web Essentials and Mark - up Language - HTML

3. The support for multimedia elements such as <audio> and <video>


4. It has support for <header>, <footer>, <article>, and <section>
5. It has support for new form controls such as number, date, time, calendar, and
range.
6. It has a rich set of Application Programming Interface (API) for geolocations,
HTML Drag and Drop, Local Storage, Application cache and so on.

1.19.2 Difference between HTML and HTML5


Sr. HTML HTML5
No.

1. The DOCTYPE declaration is much longer such as The DOCTYPE declaration is simple
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML <!DOCTYPE html>
1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd">

2. <audio> and <video> tags are not supported. <audio> and <video> tags are
supported for playing audio and video
files.

3. Finding out geographic location is impossible using The HTML5 supports the API for
HTML identifying the geographic location.

4. It supports the tag such as <applet>, <big>, <center>, The tags that are removed from
<font>, <frame>, <strike> HTML5 are
<applet>, <big>, <center>, <font>,
<frame>, <strike>

5. Does not allow JavaScript to run in browser. It allows JavaScript to run in


JavaScript runs in same thread as browser interface. background.

6. There is no support for <canvas> The <canvas> tag is for 2D drawing.

7. It needs external plugins such as flash. The need for external plugin is
reduced.

Review Questions

1. Write at least any five differences between HTML and HTML5.


SPPU : May-19, Marks 5
2. Describe the following web technology : HTML 5.
SPPU : Dec.-19, Marks 3

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 88 Web Essentials and Mark - up Language - HTML

Part III : CSS

1.20 Introduction to Style Sheet


 The CSS stands for Cascading Style Sheet.
 The Cascading Style Sheet is a markup language used in the web document for
presentation purpose.
 The primary intension of CSS was to separate out the web content from the web
presentation.
 Various elements such as text, font and color are used in CSS for presentation
purpose. Thus CSS specification can be applied to bring the styles in the web
document.

1.21 CSS Features

 By combining CSS with the html document, considerable amount of flexibility into
the content submission can be achieved.
 Similarly, separating out the style from actual contents help in managing large-scale
complex sites. Thus CSS facilitates publication of content in multiple presentation
formats.
 If CSS is used, effectively then global style sheet can be applied to a web document.
This helps in maintaining the consistency in the web document.
 If a small change needs to be done in the style of web content, then CSS makes it
more convenient.
 All above mentioned advantages of CSS show the need for it in web development.

1.22 CSS Core Syntax


 The style specification is specified differently for each different level. For instance :
 For inline cascading style sheets the style appears in side the tag for defining the
value.
<p style="font-size: 30pt ;font-family:Script">

 For the document cascading style sheet the style specification appear as the content
of a style element within the header of a document.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 89 Web Essentials and Mark - up Language - HTML

The type attribute tells the browser that what it is reading is text which is affected by
the Cascading Style Sheet. The type specification is necessary because there is one more
specification used in JavaScript.
 The external style sheet makes use of style specification in the same manner as in
document cascading style sheet.
 The most commonly used CSS properties are enlisted in the following table -

Property Type Property

Fonts font

font-family

font-size

font-style

font-weight

@font-face

Text letter-spacing

line-height

text-align

text-decoration

text-indent

Color and background background

background-color

background-image

background-position

background-repeat

color

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 90 Web Essentials and Mark - up Language - HTML

Borders border

border-color

border-width

border-style

border-top

border-top-color

border-top-width

Spacing padding

padding-bottom, padding-left, padding-right,

padding-top

margin

margin-bottom, margin-left, margin-right,

margin-top

Sizing height

max-height

max-width

min-height

min-width

width

Layout bottom, left, right, top

clear

display

float

overflow

position

visibility

z-index

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 91 Web Essentials and Mark - up Language - HTML

Lists list-style

list-style-image

list-style-type

1.23 Selector
1.23.1 Simple Selector Form
 The simple selector form is a single element to which the property and value is
applied.
 We can also apply property and value to group of elements.
 Following is an illustration for simple selector form.

HTML Document[SimpleSel.html]
<!DOCTYPE html>
<html >
<head>
<title>Simple Selector Form</title>
<style type="text/css">
h1
{
font-family:Arial;
color:green;
} We can apply style to
h2,h3 more than one selector
{
font-family:Monotype Corsiva;
color:red;
font-size: 28pt;
}
</style>
` </head>
<body>
<h1>India is My Country</h1>
<h2>All the Indians are my brothers and sisters</h3>
<h3>I love my country</h3>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 92 Web Essentials and Mark - up Language - HTML

Output

Similarly the style can also be applied to the elements at specific positions.
For example :
body b p {font-size:18pt;}
Note that there are more than one element to which the style is applied and these
elements are separated by the white spaces.
1.23.2 Class Selectors
 Using class selector we can assign different styles to the same element.
 These different styles appear on different occurrences of that element.
For example
HTML Document[ClassSel.html]
<!DOCTYPE html>
<html>
<head>
<title>Class Selector Form</title>
<style type="text/css">
h1.RedText
{
font-family:Monotype Corsiva;
color:red;
font-size: 14pt;
}
h1.BlueText
{
font-family:Arial;
color:blue;
font-size: 10pt;
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 93 Web Essentials and Mark - up Language - HTML

</style>
</head>
<body>
<h1 class ="RedText">India is My Country</h1>
<h1 class="BlueText">All the Indians are my brothers and sisters</h1>
<h3>I love my country</h3>
</body>
</html>
Output

Script explanation :
Note that in above given script we have used two different classes for the element h1.
One class selector is for displaying the string in red color and another is for displaying the
string in blue color. This definition is given in the head section. In the body section these
class names appear in double quotes inside the h1 tag.
Example 1.23.1 Create a HTML document that displays a table of basketball scores at national
games in which the team names have their respective team colors. The score of the
leading/wining team should appear larger and in different font than the losing team. Use
CSS.

Solution : Football.html
<!DOCTYPE html>
<html >
<head>
<style type="text/css">
tr.one
{
background-color:pink;
color:blue;
}
tr.two
{

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 94 Web Essentials and Mark - up Language - HTML

font-family:cursive;
background-color:black;
color:yellow;
font-size:50px;

} Output
tr.three
{
background-color:green;
color:white;
}
</style>
</head>
<body>
<table border="3">
<th>Team</th>
<th>Score</th>
<tr class="one"><td>ABC</td><td>7</td>
</tr>
<tr class="two"><td>XYZ</td><td>10</td>
</tr>
<tr class="three"><td>PQR</td><td>5</td>
</tr>

</body>
</html>

1.23.3 Generic Selectors


 We define the class in generalised form.
 In the sense, that particular class can be applied to any tag.
 Here is the HTML document which makes use of such generic selector.

HTML Document [ClassSel1.html]


<!DOCTYPE html>
<html>
<head>
<title>Generic Class Selector Form</title>
<style type="text/css">
.RedText
{
font-family:Monotype Corsiva;
color:red;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 95 Web Essentials and Mark - up Language - HTML

}
</style>

</head>
<body>
<center>
<h1> Tongue Twister</h1>
</center>
<h2 class="RedText">
She sells sea shells on the sea shore.
</h2>
<h3 class="RedText">
The shells she sells are sea shells, I'm sure.
</h3>
<h4 class="RedText">
And if she sells sea shells on the sea shore,
</h4>
<p class="RedText">
Then l'm sure she sells seashore shells.
</p>
</body>
</html>
Output

Note that the class selector must be preceded by a dot operator.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 96 Web Essentials and Mark - up Language - HTML

1.23.4 Id Selectors
 The id selector is similar to the class selector but the only difference between the
two is that class selector can be applied to more than one elements where as using
the id selector the style can be applied to the one specific element.
 The syntax of using id selector is as follows -
#name_of_id {property:value list;}
 Following HTML document makes use of id selector.

HTML Document[IdSel.html]
<!DOCTYPE html>
<html>
<head>
<title>id Selector</title>
<style type="text/css">
#top
{
font-family:Monotype Corsiva;
color:blue;
font-size:16pt;
}
</style>
</head>
<body>
<div id="top">
It is the mark of an educated mind to be able to
entertain a thought without accepting it.
</div>
<p>
-Aristotle
</p>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 97 Web Essentials and Mark - up Language - HTML

Output

1.23.5 Universal Selectors


This selector is denoted by * (asterisk). This selector can be applied to all the elements
in the document.

HTML Document[UniverSel.html]
<!DOCTYPE html>
<html >
<head>
<title>Universal Selector</title>
<style type="text/css">
*{
color:green;
}
</style>
</head>
<body>
<h2> Famous Proverbs</h2>
<hr/>
<ul type="disc">
<li>A friend in need is a friend indeed</li>
<li>Cleanliness is next to Godliness</li>
<li>All is fair in love and war</li>
<li>An apple a day keeps the doctor away</li>
<li>God helps them who help themselves</li>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 98 Web Essentials and Mark - up Language - HTML

<br/><br/>
<em>
-From My Collection.
</em>
</body>
</html>
Output

As we have defined the universal selector that sets the green color. Hence the text that
is appearing on the above web page is in green color.

1.23.6 Attribute Selector


 CSS allows authors to specify rules that match elements which have certain
attributes defined in the source document.
 The syntax is
[att] - Match when the element sets the "att" attribute, whatever the value of the attribute.
[att=val] - Match when the element's "att" attribute value is exactly "val".
 Example : In the following example all the <a> elements get selected with a target
attribute.
<!DOCTYPE html>
<html>
<head>
<style>
a[target] {
background-color: red;
}
</style>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 99 Web Essentials and Mark - up Language - HTML

</head>
<body>
<p>The links with a target attribute gets a RED background:</p>
<h1><a href="https://www.google.com">Google</a> </h1>
<h2><a href="http://www.facebook.com" target="_blank">Facebook</a></h2>
</body>
</html>
Output

1.23.7 Pseudo Classes


Using pseudo classes we can give special effects on the selectors. There some pseudo
classes which are more commonly used and those are -
 Focus
 Hover
 Hyperlink
In the following XHTML documents we have used these pseudo classes.

HTML Document[PsedoCls.htmll]
<!DOCTYPE html>
<html>
<head>
<title>Pseudo classes</title>
<style type="text/css">
input:focus

{
background-color:skyblue;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 100 Web Essentials and Mark - up Language - HTML

color:white;
}
</style>
</head>

<body>
<form>
Enter some string:<input type="text" name="my_txt"/>
<br/>
<input type="submit" value="Enter"/>
</form>
</body>
</html>
Output

Let us now see one more illustration in which the pseudo class is used.
HTML Document[PsedoCls1.html]
<!DOCTYPE html>
<html>
<head>
<title>Pseudo classes for hyperlinks</title>
<style type="text/css">
a.ColoredTxt:link {color: red}
a.ColoredTxt:visited {color: blue} We have defined two
a.ColoredTxt:hover {color: green} pseudo classes named
ColoredTxt and BigTxt
a.BigTxt:link {color: red}
a.BigTxt:visited {color: blue}

a.BigTxt:hover {font-size: 200%}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 101 Web Essentials and Mark - up Language - HTML

</style>
</head>
<body>
<h3>Move Mouse over following text</h3>
<p>
<em>
<a class="ColoredTxt" href="mypage.html" target="_blank">The text
changes color
</a>
</em>
</p>
<p>
<em>
<a class="BigTxt" href="mypage.html" target="_blank">The text is getting
Big in size
</a>
</em>
</p>
</body>
Output

1.23.8 Contextual Selector


 "Contextual selectors" in CSS allow you to specify different styles for different parts
of your document.
 You can assign styles directly to specific HTML tags, or you can create independent
classes and assign them to tags in the HTML.

For example -
<!DOCTYPE html>
<html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 102 Web Essentials and Mark - up Language - HTML

<head>
<style>
pb{
font-family: Times, serif; /* Font family */
font-weight: bold; /* heavy faced type*/
color: blue; /* blue colour of the text */
}
</style>
</head>
<body>
<div><b>This line is in bold face font</b></div>
<p><b>This line is in bold face with the color of the text - blue </b></p>
<p> Good Bye</p>
</body>
</html>
Output

1.24 Style Sheets and HTML


There are three levels of cascading style sheets -
 Inline style sheet
 Document level style sheet
 External level style sheet

1.24.1 Inline Style Sheet


The inline cascading style sheet is a kind of style sheet in which the styles can be
applied to HTML tags. This tag can be applied using following rule -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 103 Web Essentials and Mark - up Language - HTML

Tag
{
property: value
}

For example :
<p style="font-family: Arial;color:red" >
Here for the tag p two properties are used such as font-family and color and those are
associated with the values such as arial and red respectively.
Note that if we want to use more than one property then we have to use separator
such as semicolon. In the following HTML document we have used cascading style sheet-
HTML Document [InlineStyle.html]
<!DOCTYPE html >
<html>
<head>
<title>Inline Cascading Style Sheet</title>
</head>
<body>
<p>This is simple text</p>
<p style="font-size: 30pt ;font-family:Script">This text is different </p>
<p style="font-size: 40pt ;color:#ff0000">This text is colored.</p>
</body>
</html>

Script explanation
1) In this document, in the body section the style sheets are created.
2) In this section first of all we have displayed a simple sentence This is simple text.
There is no style for this sentence.
3) In the next line, we have applied style in which font-size is set to the size of 30
point and font-family is set by the font name "Script".
4) Then colored text will be displayed by color:#ff0000". The first two digits ff
denote the red color, there is no green and blue color as the values next to ff are
00. Hence the text will be displayed in red.
This can be very well illustrated in output.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 104 Web Essentials and Mark - up Language - HTML

Output

1.24.2 Document Level Style Sheet


 This type style sheet appears only in the head section and in the body section newly
defined Selector tags are used with the actual contents.
 For example : In the following HTML script we have defined h1, h2, h3 and p
selectors. For each of these selectors different property and values are set. Such
setting will help us to represent our web page in some decorative form.
 The most important thing while writing document level style sheet is that we
should mention the
style type="text/css" in the head section. By this the browser will come to know
that the program is making use of cascading style sheet.

HTML Document [DocLevelCSS.html]


<!DOCTYPE html>
<html >
<head>
<title>Document Level style sheet</title>
<style type="text/css">
h1
{
font-family:Arial;
color:green
}
h2
{
font-family:Arial;
color:red;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 105 Web Essentials and Mark - up Language - HTML

left:20px
}
h3
{
font-family:arial;
color:blue;
}
p
{
font-size:14pt;
font-family:verdana
}
</style>
</head>
<body>
<h1>
<center>
This page is created using Document Level Style Sheet
</center>
</h1>
<h2>
This line is aligned left and red colored.
</h2>
<p>
The embedded style sheet is the most commonly used style sheet.
This paragraph is written in Verdana font with font size of 14.
</p>
<h3>
This is a blue <a href="colorname.html">colored</a> line.
</h3>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 106 Web Essentials and Mark - up Language - HTML

Script explanation
1) In above program, we have defined all the selectors in the head sections only.
And these HTML elements are then used along with the web page contents.
2) The setting defined in the selectors will affect the web page contents. For
example we have defined the selector h2 as,
h2
Selector

{
font-family:Arial;

Property color:red; Value


left:20px
}
and then in the body section we have written -
<h2> This line is aligned left and red colored.</h2>
3) Now as h2 defines font to be "Arial" with color as "red" having left alignment of
20 pixels, the sentence "This line is aligned left and red colored." will be
displayed in Arial font, which is red colored and aligned from left by 20 pixels.
Surely we can see this effect on our web browser.

1.24.3 External Stylesheet


 Sometimes we need to apply particular style to more than one web documents in
such cases external style sheets can be used.
 The central idea in this type of style sheet is that the desired style is stored in one
.css file. And the name of that file has to be mentioned in our web pages.
 Then the styles defined in .css file will be applied to all these web pages.
 Here is a sample program in which external style sheet is used.
Step 1 : Create an HTML document

HTML Document [ExtCSS.html]


<!DOCTYPE html>
<html >
<head>
<link rel="stylesheet" type="text/css" href="ex1.css" />
</head>
<body>
<h1 class="special"> <center> This page is created using External Style
Sheet</center> </h1>
<h2>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 107 Web Essentials and Mark - up Language - HTML

This line is aligned left and red colored.


</h2>
<p>
The External style sheet is the compact representation of Cascading Style Sheets.
This paragraph is written in Monotype Corsiva font with font size of 14.
</p>
<h3>
This is a blue <a href="colorname.html">colored</a> line.
</h3>
</body>
</html>
Step 2 : Create a css file which contains the styles that can be applied to different
HTML elements present in the above HTML document.
The cascading style sheet ex1.css can be
<!- - The file name ex1.css and can be opened in notepad.-->
h1
{
font-family:Arial
}
h2
{
font-family:times new roman;
color:red;
left:20px
}
h3
{
font-family:arial;
color:blue;
}
p
{
font-size:14pt;
font-family:Monotype Corsiva
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 108 Web Essentials and Mark - up Language - HTML

Script explanation
When we want to link the external style sheet then we have to use <link> tag which is
to be written in the head section.
 link tells the browser some file must be linked to the page.
 rel=stylesheet tells the browser that this hyperlink is a style sheet.
 href=" " denotes the path name of style sheet file.
 type="text/css" tells the browser that what it is reading is text which is affected by
the cascading style sheet.

1.25 Style Rule Cascading and Inheritance

1.25.1 Style Rule Cascading


 When there are two or more values for the same property then conflict occurs.
There are various levels of style sheets such as embedded CSS and external CSS.
Out of which embedded CSS have more precedence over the external CSS.
 There are some sorting order rules that are used to decide the precedence. These are
based on two things, importance (important or normal) of the property and origin
(author origin, user origin and user agent origin). Let us first understand the terms
important and origins.
 The keyword !important can be applied to specify that particular property is
important.
For example :
p.myclass {font-family:Arial !important ;font-style:bold;}
specifies that the font being Arial is one property but font-style being bold is a
important property.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 109 Web Essentials and Mark - up Language - HTML

 When the specification is marked by !important then it actually specifies the weight.
The weight can be either important or normal.
 The origin can be author origin, user origin and user agent origin. These terms can
be defined as follows -
o Author is a person who writes the XHTML document and associated style
sheets.
o User is a person who interacts with user agent and use the web document
along with the associated style sheets.
o User agent is a program that interprets the web document written in scripting
language and applies the style sheet according to the specification. For
example, HTML is an user agent.
 The sorting order can be determined by applying following rules with highest
precedence to lowest -
1. Important declaration having user origin.
2. Important declaration having author origin.
3. Normal declaration having author origin.
4. Normal declaration having user origin.
5. Any declaration (either important or normal) with user agent (i.e. browser)
origin.
 Following rules are also be used to decide the sorting order of the elements from
highest precedence to lowest -
1. id selectors have the highest precedence.
2. class and pseudo class selectors
3. Contextual selectors
4. Universal selectors
 If the conflict still occurs then it can be resolved writing the properties in the
specification. The rules that are defined later in the document tree have the highest
precedence than those defined earlier.
 Style rule cascading can be defined as the process which is used to resolve the
conflicts in the style specification. Fig. 1.25.1 shows the steps in CSS cascade.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 110 Web Essentials and Mark - up Language - HTML

Fig. 1.25.1 Steps in CSS cascade

1.25.2 Inheritance
 In CSS, if a property of an element has no associated declarations then using
inheritance technique the value for this property can be obtained.
 In an HTML document, the tags have parent-child relationships. For example,
<title> tag is always inside the <head> tag, so the <head> tag is the parent of the
<title> tag. Similarly <p> tag is defined inside the <body> tag. Then <body> becomes
parent of <p> tag.
 In cascading style sheets, inheritance is based on tree structure of the document
itself.
 An element inherits the value for its properties by checking the parent element. If
the parent has the value for the property demanded by the child then this property
value can be inherited. If the parent down not have this value, then its parent (i.e.
grandparent) is checked. If this parent has no such property value then its parent is
checked. This process is continued until a root element is obtained.
 Thus the search will be made in upward direction from the parent of the element to
the root of the tree or to the <html> tag of the document.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 111 Web Essentials and Mark - up Language - HTML

 Inheritance can be defined as a concept in which child always inherits the properties
of parent tag along with its own properties.
 Following is an HML document in which inheritance is demonstrated.

HTML Document
<!DOCTYPE html>
<html>
<head>
<title>Inheritance Demo</title>
<style type="text/css">
p
{
font-family:Arial;
color:blue;
background-color:yellow;
}
strong
{
font-size:24px;
}
</style>
</head>
<body>
<center>
<p>This is a blue text <strong>with</strong> yellow background</p>
</center>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 112 Web Essentials and Mark - up Language - HTML

Script explanation :
In above, script <p> tag has some properties as Arial font, blue font color and yellow
background. The <strong> tag has only one property can that is font-size which is
assigned by the value 24px. But in the body section, <strong> tag is the child of <p> tag.
And note that <strong> inherits the properties of <p> tag. Hence the text defined
under<strong> tag is also blue colored with yellow background.
Now just modify by the above script as follows and observe the sample output.

HTML Document [inheritance1.html]


<!DOCTYPE html>
<html>
<head>
<title>Inheritance Demo</title>
<style type="text/css">
li
{
font-style:italic
}
p
{
font-family:Arial;
color:blue;
background-color:yellow
}
strong
{
font-size:24px
}
</style>
</head>

<body> Added <li> tag as grand parent for


<center> <strong> tag.
<li>
<p>This is a blue text <strong>with</strong> yellow background</p>
</li>
</center>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 113 Web Essentials and Mark - up Language - HTML

Output

Note that the above style sheet contains the nested tags -
<li>
…..<p>
………….<strong>
………….</strong>
…..</p>
</li>
The <li> tag contains the italic property. Hence the text inside the <strong> tag becomes
italic. That means <strong> tag has inherited the italic property from its grandchild.
1.26 Text Properties SPPU : March-20, Marks 5

The font properties can be setting different types of fonts, styles and sizes.

1.26.1 Font Families


The font-family denotes different types of fonts such as Arial, Times New Roman,
Script, monospace and so on. Following are some examples of generic fonts
Generic Font Name Example

sans-serif Arial, Helvetica, Futura

cursive Zapf-chancery

fantasy Critter, Cottonwood

monospace Courier, Prestige

serif Times New Roman,Garamond

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 114 Web Essentials and Mark - up Language - HTML

Let us see usage of font-family property in HTML document.


HTML Document[FontFamily.html]
<!DOCTYPE html>
<html>
<head>
<title>Font Family Demo</title>
<style type="text/css">
h1 Output
{
font-family:Arial;
}
h2
{
font-family:script;
}
h3
{
font-family:‘Times New Roman’;
}
h4
{
font-family:fantasy;
}
h5
{
font-family:Garamond;
}
</style>
</head>
<body>
<h1>This text is in Arial </h1>
<h2>This text is in script </h2>
<h3>This text is in Times New Roman</h3>
<h4> This text is in fantasy</h4>
<h5> This text is in Garamond</h5>

</body>
</html>

If the font name has more than one word then the name should be enclosed by the
single quotes. Although quotes are not mandatory, it is a good practice to use quotes for
specifying the font name.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 115 Web Essentials and Mark - up Language - HTML

1.26.2 Font Sizes


This property is used to specify the size of the font. One can specify the font size in
points (pts), pixels (px) or in percentage (%). We can also specify the font size using the
relative values such as small, medium, large. Use of font size in such a way is relative.
And the disadvantage of using such relative sizes is that one cannot have the strict control
over the font-size. Different browsers may have different font size values.
In the following HTML document we will use the font-size property.

HTML Document[FontSize.html]
<!DOCTYPE html>
<html>
<head>
Output
<title>Font-Size Demo</title>
<style type="text/css">
h1
{
font-size:10pt;
}
h2
{
font-size:20px;
}
h3
{
font-size:xx-large;
}
h4
{
font-size:250%;
}

</style>
</head>
<body>
<h1>Programming the Web</h1>
<h2>Programming the Web</h2>
<h3>Programming the Web</h3>
<h4>Programming the Web</h4>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 116 Web Essentials and Mark - up Language - HTML

1.26.3 Font Variants


The font variation can be achieved by making setting the font in upper case or in lower
case.
We use font-variant property for this purpose.

Value Meaning

normal The font can be displayed in normal form.

small-caps The font can be displayed in small capital letters.

HTML Document [FontVariant.html]


<!DOCTYPE html>
<html>
<head>
<title>Font-Variant Demo</title>
<style type="text/css">
h1
Output
{
font-variant:small-caps;
}

</style>
</head>
<body>
<h1>Programming the Web</h1>
</body>
</html>

1.26.4 Font Styles


Various font styles are -
 normal
 italic
 oblique
The illustration is as given below -

HTML Document[FontSt.html]
<!DOCTYPE html>
<html
<head>
<title>Font-Style Demo</title>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 117 Web Essentials and Mark - up Language - HTML

<style type="text/css">
h3.normal { font-style:normal;}
h3.italic { font-style:italic;}
h3.oblique { font-style:oblique;}
</style>
</head>
<body>
<h3 class="normal">Programming the Web</h3>
<h3 class="italic">Programming the Web</h3>
<h3 class="oblique">Programming the Web</h3>
</body>
</html>
Output

1.26.5 Font Weights

Various font styles are -


 Normal (by default)
 Bold
 Bolder
 Lighter
The illustration is as given below –

HTML Document[FontWt.html]
<!DOCTYPE html>
<html>
<head>
<title>Font-Weight Demo</title>
<style type="text/css">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 118 Web Essentials and Mark - up Language - HTML

p.normal { font-weight:normal;}
p.bold { font-weight:bold;}
p.bolder { font-weight:bolder;}
p.lighter { font-weight:lighter;}
</style>
</head>
<body>
<p class="normal">Programming the Web</p>
<p class="bold">Programming the Web</p>
<p class="lighter">Programming the Web</p>
<p class="bolder">Programming the Web</p>
</body>
</html>
Output

1.26.6 Font Shorthands


 We can specify more than one font properties in a list.
For example

HTML Document[Fontshrthnd.html]
<!DOCTYPE html>
<html>
<head>
<title>Font Properties</title>
<style type="text/css">
p.myfont {font-family:Courier New;
font-style:italic;
font-weight:bold;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 119 Web Essentials and Mark - up Language - HTML

font-size:28pt;
}
</style>
</head>
<body>
<p class="myfont">I Love my Country!!!</p>
</body>
</html>
Output

1.26.7 Text Decoration


Using text decoration property we can include special features in the text. Various
properties of text decoration are,
 underline
 overline
 line-through

HTML Document[TxtDecor.html]
<!DOCTYPE html>
<html>
<head>
<title>Text Decoration</title>
<style type="text/css">
p.linethrough {text-decoration:line-through;}
p.underline {text-decoration:underline;}
p.overline {text-decoration:overline;}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 120 Web Essentials and Mark - up Language - HTML

p.normal {text-decoration:normal;}

</style>
</head>
<body>
<p class="linethrough"> This text is having linethrough </p>
<p class="overline"> This text is having overline </p>
<p class="underline"> This text is having underline </p>
<p class="normal"> This text is a normal text </p>

</body>
</html>
Output

1.26.8 Alignment of Text


Using cascading style sheets we can align the text. This alignment can be done using
following properties such as -

Property Value Meaning

text-align left Aligning the text to the left.

text-align right Aligning the text to the right

text-align center Alignment of text at the centre.

text-indent value in inches Desired indentation of the text can be applied.

Following is script which uses various text alignment properties.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 121 Web Essentials and Mark - up Language - HTML

HTML Document [TextAlignCSS.html]


<!DOCTYPE html>
<html>
<head>
<title>Text Alignment Demo</title>
<style type="text/css">
h1
{
font-family:Arial;
font-size:15px;
text-align:left;
}
h2
{
font-family:Arial;
font-size:15px;
text-align:right;
}
h3
{
font-family:Arial;
font-size:15px;
text-align:center;
}
</style>
</head>

<body>
<h1>This line is aligned at left</h1>
<h2>This line is aligned at right</h2>
<h3>This line is aligned at center</h3>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 122 Web Essentials and Mark - up Language - HTML

Output

Example 1.26.1 How to you create a multi colour text on a web page using CSS ?

SPPU : March-20, Marks 5


Solution :
<!DOCTYPE html>
<html>
<head>
<title>Rainbow Effect</title>
</head>
<body>
<h1>
<span style="color:violet">P</span>
<span style="color:indigo">r</span>
<span style="color:green">o</span>
<span style="color:blue">g</span>
<span style="color:orange">r</span>
<span style="color:yellow">a</span>
<span style="color:red">m</span>
</h1>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 123 Web Essentials and Mark - up Language - HTML

1.27 Bootstrap SPPU : May-18, Dec.-19, Marks 9

 Bootstrap is open source, front end web framework. It is used for designing
web-site and web applications.
 Bootstrap helps the developer to create responsive designs. Responsive web design
means creating the web site which automatically adjusts itself to look good on all
the devices. These devices range from small phones to large desktops screens.
 Bootstrap includes HTML, CSS and JavaScript based design templates which
includes forms, buttons, tables, navigation, modals and so on.

Features of Bootstrap

Setting up Environment
There are two ways to use Bootstrap in a webpage.
1) The first way is to use a CDN or Content Delivery Network. Using
bootstrap CDN means that we will not download and store the bootstrap
files in our server or local machine. We will just include the bootstrap CSS
and JavaScript links on our page.
2) The second way is downloading and storing a copy Bootstrap files in our
web server or local machine. We can download the Bootstrap from
https://getbootstrap.com/
I have created a folder named bootstrap-3.3.7 and downloaded my Bootstrap in this
folder. After getting downloaded I can see three folders in it namely css, fonts and js
 If we want to use the CDN then we will include Bootstrap CSS as follows -
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
 If we want to use our own downloaded copy then we will use
<link rel="stylesheet"
href="bootstrap-3.3.7/css/bootstrap.min.css">
 Similarly the jquery can be used as
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js"></script>
Or
<script src="jquery-3.0.0.min.js"></script>

Components of Bootstrap
1. HTML 5 : The Bootstrap uses the HTML elements and CSS properties, hence the
code is contained within the <doctype>.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 124 Web Essentials and Mark - up Language - HTML

<!DOCTYPE html>
<html lang=”en”>
<head>
<meta charset="utf-8">
… …
Script declarations
</head>
<body>


</body>
</html>
2. The mobile-first : Bootstrap 3 is designed to be responsive to mobile devices.
Mobile-first styles are part of the core framework.
For proper rendering the <meta> tag inside the <head> section is specified. It is
specified as follows -
<meta name="viewport" content="width=device-width, initial-scale=1">
The width=device-width part sets the width of page which is based on the
screen-width of the device.
The initial-scale = 1 part sets the initial zoom level when the page is loaded on the
browser.

3. Container
The container element is for wrapping the site contents. There are two classes for the
container -
i) Container : It provides a responsive fixed width container.
ii) Container-fluid : It provides full width container occupying the entire width of
the viewport.

How to write first Bootstrap Code ?


Step 1 : Open a Notepad and type the following code. Save it using the filename
extension .html

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 125 Web Essentials and Mark - up Language - HTML

BootstrapDemo.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script
src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
</head>
<body>
<div class="container" style="background-color:grey;">
<h1 >Enjoying Web Page Design with Bootstrap</h1>
<p>The .container class is here and it provides fixed width container</p>
</div>
</body>
</html>
Output

Similarly if we change the <div> element class to container-fluid we will get the
content to be occupied the entire web page. It can be demonstrated by modifying the
above script as follows -

BootstrapDemo.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 126 Web Essentials and Mark - up Language - HTML

href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script
src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
</head>
<body>

<div class="container-fluid" style="background-color:grey;">


<h1 >Enjoying Web Page Design with Bootstrap</h1>
<p>The .container class is here and it provides fixed width container</p>
</div>

</body>
</html>
Output

1.27.1 Grid System


 In Bootstrap there are 12 columns across the page. It is not always necessary to
have 12 columns we can group the columns and wider columns can be created.
 The Bootstrap’s Grid system is responsive. That means as we resize the browser
window, the columns arrangement gets changed as per the screen size.
 There are four classes of Bootstrap’s Grid system and those are -
Class Purpose

xs It is used for phones

sm It is used for tablet screen

md It is used for small laptops

lg It is for laptops and desktops.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 127 Web Essentials and Mark - up Language - HTML

The above classes can be combined to create more dynamic and flexible display.

Structure of Bootstrap Grid


The typical structure of Bootstrap Grid is as follows -
<div class="row">
<div class="col-*-*"></div>
<div class="col-*-*"></div>
</div>
<div class="row">
<div class="col-*-*"></div>
<div class="col-*-*"></div>
<div class="col-*-*"></div>
</div>


In above structure we adding the row by
<div class=”row”>
And then adding the column for that row using
<div class="col-*-*"></div>
Here first * indicates the class as xs or sm or md or so on. The second * indicates the
number of columns. We can add at the most 12 columns.
Let us understand how to use Grid system with a simple example
GridDemo.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script
src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>

</head>
<body>

<div class="container-fluid">
<div class="row">
<div class="col-sm-3" style="background-color:grey;">One</div>
<div class="col-sm-3" style="background-color:aqua;">Two</div>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 128 Web Essentials and Mark - up Language - HTML

<div class="col-sm-3" style="background-color:grey;">Three</div>


<div class="col-sm-3" style="background-color:aqua;">Four</div>
</div>
</div>
</body>
</html>
Output

If we resize the browser window we get the columns to be stacked one upon other

Similarly we can create the columns of unequal width, if we change the <col-sm>. For
example -
<div class="col-sm-8" style="background-color:grey;">One</div>
<div class="col-sm-4" style="background-color:aqua;">Two</div>

1.27.2 Typography
 In this section we will learn how to display the text in different style using
Bootstrap elements.
 By default font size is 14 px.
 The HTML elements will be displayed with different style in Bootstrap.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 129 Web Essentials and Mark - up Language - HTML

Heading
The tags <h1> to <h6> are used to display the heading. For example
HeadingDemo.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script
src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
Output
</head>
<body>
<div class="container">
<h1> This line is of 36px </h1>
<h2> This line is of 30px </h2>
<h3> This line is of 24px </h3>
<h4> This line is of 18px </h4>
<h5> This line is of 14px </h5>
<h6> This line is of 12px </h6>
</div>
</body>
</html>

The small element


The <small> element is used to create the small light text in heading. For example
HeadingDemo.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 130 Web Essentials and Mark - up Language - HTML

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script
src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
Output
</head>
<body>
<div class="container">
<h1> This line is of <small>36px</small> </h1>
<h2> This line is of <small>30px</small> </h2>
</div>
</body>
</html>

The mark element


The <mark> element can be used to highlight the important text present in the line.
Here is the simple illustration
MarkDemo.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script
src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>

</head>
<body>

<div class="container">
<p> This line is an <mark>important</mark> message </p>
</div>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 131 Web Essentials and Mark - up Language - HTML

Output

The <pre> element


For displaying the text on multiple lines we can use <pre> tag. Here is the simple
example of this tag.
PreDemo.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script
src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>

</head> Output
<body>

<div class="container">
<pre>
Humty Dumty
sat on a wall.
Jack and Jill
went up the hill.
Twinkle Twinkle
little star
How I wonder
What you are!!!
</pre>
</div>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 132 Web Essentials and Mark - up Language - HTML

Colors and Background


 There are some contextual classes using which specific meaning can be represented
through the colors. The classes for text colors are -
.text-muted, .text-primary, .text-success, .text-info, .text-warning, .text-danger
 Similarly we can align the text to left, right or center using text-left, text-right and
text-center.
 These are called contextual classes which provides the meaning through text.
 Let us use these classes in following demo application

TextDemo.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script
src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
</head>
<body>
<div class="container">
<p class="text-left">This line is left aligned</p>
<p class="text-right">This line is right aligned</p>
<p class="text-center">This line is at center </p>
<p class="text-muted">This line is using muted class</p>
<p class="text-primary">This line is using primary class</p>
<p class="text-success">This line is using success class</p>
<p class="text-info">This line is using info class</p>
<p class="text-warning">This line is using warning class</p>
<p class="text-danger">This line is using danger class</p>
</div>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 133 Web Essentials and Mark - up Language - HTML

Output

Similarly we can set background color for these classes as follows :

TextBGDemo.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script
src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>

</head>
<body>
<div class="container">
<p class="bg-primary">This line is using primary class</p>
<p class="bg-success">This line is using success class</p>
<p class="bg-info">This line is using info class</p>
<p class="bg-warning">This line is using warning class</p>
<p class="bg-danger">This line is using danger class</p>
</div>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 134 Web Essentials and Mark - up Language - HTML

Output

1.27.3 Tables
The <table> tag is used to create the table. The <tr> tag is used for rows and <td> tag is
used for columns. The heading in the table can be denoted within <thead><th> </th>
</thead> tag while remaining contents of the table are specified in <tbody> tag.
The following example demonstrates the use of table tag.

TableDemo1.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script
src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
</head>
<body>
<div class="container">
<table class="table">
<thead>
<tr><th> Name </th><th> City </th></tr>
</thead>
<tbody>
<tr>
<td>AAA</td>
<td>Pune</td>
</tr>
<tr>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 135 Web Essentials and Mark - up Language - HTML

<td>BBB</td> Output
<td>Mumbai</td>
</tr>
<tr>
<td>CCC</td>
<td>Chennai</td>
</tr>
</tbody>
</div>
</body>
</html>

For having the grids to the table, we simply change the


<table class="table">
to
<table class="table table-bordered">

1.27.4 Images
 For displaying the images the <img src=””> tag is used. You have to specify the
image file name within the double quotes.
 There are three classes that are used to display the image. These classes are -
1. img-rounded : The image is displayed in a border-circle of radius 6px.
2. img-circle : The image is displayed in circle of radius 500px
3. img-thumbnail : The image is displayed in a rectangle having padding and grey
border.
Here is illustrative example of displaying images.

ImgDemo.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script
src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 136 Web Essentials and Mark - up Language - HTML

</head>
<body>
<img src = "bookImg.jpg" class = "img-rounded">
<img src = "bookImg.jpg" class = "img-circle">
<img src = "bookImg.jpg" class = "img-thumbnail">
</body>
</html>
Output

1.27.5 Button
 In Bootstrap we can create the buttons of different styles. Various button classes are
used as follows -
.btn, .btn-default, .btn-primary, .btn-success, .btn-info, .btn-warning,
.btn-danger, .btn-link
 The example code is as follows -

ButtonDemo.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script
src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
</head>
<body>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 137 Web Essentials and Mark - up Language - HTML

<button type="button" class="btn">Basic</button>


<button type="button" class="btn btn-default">Default</button>
<button type="button" class="btn btn-primary">Primary</button>
<button type="button" class="btn btn-success">Success</button>
<button type="button" class="btn btn-info">Info</button>
<button type="button" class="btn btn-warning">Warning</button>
<button type="button" class="btn btn-danger">Danger</button>
<button type="button" class="btn btn-link">Link</button>
</body>
</html>
Output

We can also create active or disabled buttons using active and disabled class. The
illustration is as follows -
ButtonDemo1.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script
src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
</head>
<body>
<button type="button" class="btn btn-success">Success</button>
<button type="button" class="btn btn-success active">Active</button>
<button type="button" class="btn btn-success disabled">Disabled</button>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 138 Web Essentials and Mark - up Language - HTML

Output

1.27.6 Form
 In Bootstrap there are three types of form layouts.
1. Vertical Form 2. Horizontal Form 3. Inline Form
 For using the form we must add the <div> element as <div class=”form-group”>.
The required controls such as <input>, <select>, <textarea> and so on can be added
within this <div> class.
 Let us discuss and learn how to create the above mentioned types of forms –

1. Vertical or Basic Form


To create the vertical or basic form use following steps –
Step 1 : Add a role to form element as -
<form role=”form”>
Step 2 : Inside the <div class=”from-group”> wrap all the controls
Step 3 : While adding any textual control such as <text>, <textarea> and <select> add the
class “form-control”
Here is example code –

FormDemo1.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 139 Web Essentials and Mark - up Language - HTML

href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script
src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>

</head>
<body>
<form role = "form">

<div class = "form-group">

<label for = "name">User Name</label>

<input type = "text" class = "form-control" id = "name">


</div>

<div class = "form-group">

<label for = "pwd">Password</label>

<input type = "password" class = "form-control" id = "pwd">

</div>

<div class = "checkbox">

<label><input type = "checkbox"> Show Me Always</label>

</div>

<button type = "submit" class = "btn btn-default">Submit</button>

</form>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 140 Web Essentials and Mark - up Language - HTML

Output

2. Horizontal Form
To create the vertical or basic form use following steps –
Step 1 : Add a role to form element as -
<form role=”form”> and form class=”form-horizontal”
Step 2 : Inside the <div class=”from-group”> wrap all the labels and controls
Step 3 : While adding any textual control such as <text>, <textarea> and <select> add the
class “form-control”
Step 4 : Add a class of “control-label” to the labels.
Here is example code –
FormDemo2.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script
src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
</head>
<body>
<form class ="form-horizontal" role = "form">
<div class = "form-group">
<label class="control-label col-sm-4" for = "name">User Name</label>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 141 Web Essentials and Mark - up Language - HTML

<div class="control-label col-sm-8">


<input type = "text" class = "form-control" id = "name">
</div>
</div>
<div class = "form-group">
<label class="control-label col-sm-4" for = "pwd">Password</label>
<div class="control-label col-sm-8">
<input type = "password" class = "form-control" id = "pwd">
</div>
</div>
<div class="form-group">
<div class="col-sm-offset-4 col-sm-8">
<div class = "checkbox">
<label><input type = "checkbox"> Show Me Always</label>
</div>
</div>
</div>
<div class="form-group">
<div class="col-sm-offset-4 col-sm-8">
<button type = "submit" class = "btn btn-default">Submit</button>
</div>
</div>
</form>
</body>
</html>
3. Inline Form
 In an inline form, all of the elements are inline, left-aligned, and the labels are
alongside.
 To create the inline form use following steps –
Step 1 : Add a role to form element as -
<form role=”form”>
And the class as “form-inline” to the <form> element.
Step 2 : Inside the <div class=”from-group”> wrap all the controls
Step 3 : While adding any textual control such as <text>, <textarea> and <select> add the
class “form-control”
Here is example code –
FormDemo3.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 142 Web Essentials and Mark - up Language - HTML

<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script
src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>

</head>
<body>
<form class="form-inline" role = "form">
<div class = "form-group">
<label for = "name">User Name</label>
<input type = "text" class = "form-control" id = "name">
</div>

<div class = "form-group">


<label for = "pwd">Password</label>
<input type = "password" class = "form-control" id = "pwd">
</div>

<div class = "checkbox">


<label><input type = "checkbox"> Show Me Always</label>
</div>

<button type = "submit" class = "btn btn-default">Submit</button>

</form>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 143 Web Essentials and Mark - up Language - HTML

Review Questions

1. Write short note on Bootstrap.


SPPU : May-18, Marks 4
2. Write short note on Bootstrap ? Write a program to demonstrate button styles (warning,
danger, default, primary, link, success) ?
SPPU : Dec.-19, Marks 9

1.28 Multiple Choice Questions


Q.1 A collection of hyperlinked documents on the internet forms the ______.

a World Wide Web (WWW) b e-mail system


c mailing list d hypertext markup language
Q.2 Which of the following is a popularly used internet protocol ?

a HTML b TCP/IP
c IPX d None of these
Q.3 FTP stands for _____.

a File Transmission Protocol b File Transfer Program


c File Transfer Protection d File Transfer Protocol
Q.4 Which layer of the TCP / IP stack corresponds to the OSI model transport layer ?

a Host to host b Application


c Internet d Network access
Q.5 Which of the following is not a web browser ?

a Opera b Microsoft edge


c www d Google chrome
Q.6 What services are not a provided by Webservers ?

a Serving web pages b Running gateway programs


c Resource sharing d Server side scripting
Q.7 HTML is stand for ___.

a Higher Text Modeling Language b Huge Text Modeling Library


c Hyper Text Modeling Library d Hyper Text Markup Language
Q.8 HTML is a subset of ______.

a HTTP b SGML
c XML d None of these

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 144 Web Essentials and Mark - up Language - HTML

Q.9 All the HTML tags are enclosed within ______.

a <?> b <>
c ## d {}
Q.10 What does <br> tag do ?
a Long break b Paragraph break
c Line break d None of these
Q.11 Which tag tells the browser where the page starts and stops ?
a <html> b <body>
c <head> d <title>
Q.12 The main container for <TR>, <TD> and <TH> is _______.
a <list> b <frame>
c <table> d none of the above
Q.13 Which of the following is not a newly added element in HTML5 ?
a Article b Audio
c Nav d Frameset
Q.14 In HTML5, which element may be used within content to represent material that is
tangential _____.

a aside b cite
c article d class
Q.15 CSS stands for _____.
a Color and Style Specification b Cascading Style Sheets
c Concurrent Style Specification d None of these
Q.16 The property in CSS used to change the background color of an element is _____.
a bgcolor b color
c background-color d all of the above
Q.17 The property in CSS used to change the color of a text is _____.
a bgcolor b color
c background-color d all of the above
Q.18 Which of the following attributes is used to specify elements to bind style rules to ____.
a id b class
c tag d all of the above

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 145 Web Essentials and Mark - up Language - HTML

Answer Keys for Multiple Choice Questions :

Q.1 a Q.2 b Q.3 d Q.4 a Q.5 c

Q.6 c Q.7 d Q.8 b Q.9 b Q.10 c

Q.11 a Q.12 c Q.13 d Q.14 a Q.15 b

Q.16 c Q.17 b Q.18 d



TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 1 - 146 Web Essentials and Mark - up Language - HTML

Notes

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


UNIT- II

2 Client Side Technologies


: JavaScript and DOM
Syllabus
JavaScript : Introduction to JavaScript, JavaScript in perspective, basic syntax, variables and data
types, statements, operators, literals, functions, objects, arrays, built in objects, JavaScript debuggers.
DOM : Introduction to Document Object Model, DOM history and levels, intrinsic event handling,
modifying element style, the document tree, DOM event handling, jQuery, Overview of Angular JS.

Contents
2.1 Introduction to JavaScript
2.2 JavaScript in Perspective

2.3 Basic Syntax

2.4 Identifiers, Keywords and Comments


2.5 Data Types ............................................... May-18, 19, ........................... Marks 5

2.6 Literals

2.7 Other Primitive Types


2.8 Variables

2.9 Operators
2.10 Input and Output

2.11 Statements

2.12 Querying and Handling Properties


2.13 Functions ............................................... April-18, Dec.-18, ................ Marks 5

2.14 Built in Objects


2.15 Creation of Object ............................................... Dec.-18,................................ Marks 5

2.16 Arrays ............................................... May-18, 19, .......................... Marks 5

2.17 Strings

(2 - 1)
Web Technology 2-2 Client Side Technologies : JavaScript and DOM

2.18 JavaScript Debuggers


2.19 Introduction to Document Object Model (DOM) ....... Dec.-19,................................. Marks 5

2.20 DOM History and Levels


2.21 The Document Tree ............................................... April-18, May-19, .................. Marks 5

2.22 Modifying Element Style........................................... May-18, Dec.-19,

............................................... March-20,............................. Marks 5

2.23 DOM Event Handling ............................................... April-18, Dec.-18,

............................................... May-19, March-20, ............. Marks 5

2.24 Form Validation in JavaScript .................................. Dec.-18,................................ Marks 5


2.25 jQuery ............................................... May-19, ................................ Marks 5

2.26 Overview of Angular JS............................................ May-18, 19,

............................................... Dec.-18, 19,........................... Marks 6

2.27 Multiple Choice Questions

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2-3 Client Side Technologies : JavaScript and DOM

Part - I : JavaScript

2.1 Introduction to JavaScript


JavaScript was developed by Netscape in 1995. At that time its name was LiveScript.
Later on Sun Microsystems joined the Netscape and then they developed LiveScript. And
later on its name is changed to JavaScript.

2.1.1 Difference between Java and JavaScript

Sr. No. Java JavaScript

1. Java is a programming language. JavaScript is a scripting language.

2. Java is an object oriented programming Javascript is not an object oriented


language. programming language. Its object
model is far different than a typical
object oriented programming language
such as C++ or Java.

3. Java is strongly typed language and the In JavaScript variables need not be
type checking is done at compile time. declared before their use. Checking the
compatibility of type can be done
dynamically.

4. Objects in Java are static. That means the In JavaScript the objects are dynamic.
number of data members and method are That means we can change the total
fixed at compile time. data members and method of an object
during execution.

2.2 JavaScript in Perspective


Following are some features of JavaScript.
1. Browser Support : For running the JavaScript in the browser there is no need to
use some plug-in. Almost all the popular browsers support JavaScripting.
2. Structure Programming Syntax : The Javascript supports much commonly the
structured language type syntax. Similar to C-style the programming blocks can
be written.
3. It automatically inserts the semicolon at the end of the statement, hence there is
no need to write semicolon at the end of the statement in JavaScript.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2-4 Client Side Technologies : JavaScript and DOM

4. Dynamic Typing : It supports dynamic typing, that means the data type is
bound to the value and not to the variable. For example one can assign integer
value to a variable say ‘a’ and later on can assign some strg the ing value to the
same variable in JavaScript.
5. Run Time Evaluation : Using the eval function the expression can be evaluated
at run time.
6. Support for Object : JavaScript is object oriented scripting language. However
handling of objects in JavaScript is somewhat different that the conventional
object oriented programming languages. JavaScript has a small number of in-
built objects.
7. Regular Expression : JavaScript supports use of regular expressions using which
the text-pattern matching can be done. This feature can be used to validate the
data on the web page before submitting it to the server.
8. Function Programming : In JavaScript functions are used. One function can
accept another function as a parameter. Even, one function can be assigned to a
variable just like some data type. The function can be run without giving the
name.

2.3 Basic Syntax


The JavaScript can be directly embedded within the HTML document or it can be
stored as external file.

Directly embedded JavaScript


The syntax of directly embedding the JavaScript in the HTML is
<script type=“text/javascript”>



</script>

Example 2.3.1 Write a JavaScript to display welcome message in JavaScript.


Solution :
<!DOCTYPE html >
<html >
<head>
<title> My First Javascript </title>
</head>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2-5 Client Side Technologies : JavaScript and DOM

<body>
<center>
<script type="text/javascript">
/*This is the First JavaScript*/
document.write(" Welcome to First Page of Javascript");
</script>
</center>
</body>
</html>
Output

Script Explanation :
In above script
1) We have embedded the javaScript within
<script type="text/javascript">

</script>

2) A comment statement using /* and */. Note that this type of comment will be
recognized only within the <script> tag. Because, JavaScript supports this kind of
comment statement and not the XHTML document.

3) Then we have written document.write statement, using which we can display


the desired message on the web browser.

Indirectly Embedding JavaScript

If we want to embed the JavaScript indirectly, that means if the script is written in
some another file and we want to embed that script in the HTML document then we must
write the script tag as follows -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2-6 Client Side Technologies : JavaScript and DOM

<script type=“text/javascript” src=“MyPage.js”>



Javascript is which is to be embedded
is in the file MyPage.js


</script>
We will follow the following steps to use the external JavaScript file.
Step 1 : Create an XHTML document as follows -

XHTML Document[FirstPg.html]
<!DOCTYPE html >
<html>
<head> This is an external javascript
<title> My First Javascript </title> file; it can be specified with the
</head> attribute src
<body>
<center>
<script type="text/javascript" src="my_script.js">
</script>
</center>
</body>
</html>

Step 2 :

JavaScript[my_script.js]
/*This is the First JavaScript*/
document.write(" Welcome to First Page of Javascript");
Step 3 : Open the HTML document in Internet Explorer and same above mentioned
output can be obtained.

Advantages of indirectly embedding of JavaScript


1. Script can be hidden from the browser user.
2. The layout and presentation of web document can be separated out from the
user interaction through the JavaScript.

Disadvantages of indirectly embedding of JavaScript


1. If small amount of JavaScript code has to be embedded in XHTML document
then making a separate JavaScript file is meaningless.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2-7 Client Side Technologies : JavaScript and DOM

2. If the JavaScript code has to be embedded at several places in XHTML document


then it is complicated to make separate JavaScript file and each time invoking the
code for it from the XHTML document.

2.4 Identifiers, Keywords and Comments

1. Identifiers
Identifiers are the names given to the variables. These variables hold the data value.
Following are some conventions used in JavaScript for handling the identifiers -
1. Identifiers must begin with either letter or underscore or dollar sign. It is then
followed by any number of letters, underscores, dollars or digits.
2. There is no limit on the length of identifiers.
3. The letters in the identifiers are case-sensitive. That means the identifier INDEX,
Index, index, inDex are considered to be distinct.
4. Programmer defined variable names must not have upper case letters.

2. Reserved words
Reserved words are the special words associated with some meaning. Various reserve
words that are used in JavaScript are enlisted as below -

break Continue delete for in return throw var with

case default else function instanceof switch try void

catch do finally if new this typeof while

3. Comments
JavaScript supports following comments.
1. The // i.e a single line comment can be used in JavaScript.
2. The /* and */ can be used as a multi-line comment.
3. The XHTML <!--> and <--> is also allowed in JavaScript

4. Semicolon
While writing the JavaScript the web programmer must give semicolon at the end of the
statements.

2.5 Data Types SPPU : May-18, 19, Marks 5

JavaScript uses six types of values - number, string, boolean, null, object and function

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2-8 Client Side Technologies : JavaScript and DOM

Number : Number is a numeric value that can be integer or float. It can be used
calculation.
String : String is a collection of characters. It is enclosed within single quote or double
quote. A string may contain numbers but these numbers can not be used for calculations.
Boolean : The Boolean values are true and false. These values can be compared with the
variables or can be used in assignment statement.
Null : The null value can be assigned by using the reserved word null. The null means no
value. If we try to access the null value then a runtime error will occur.
Object : Object is for an entity that represents some value. For example - window object is
a value using which the window is created. Form is an object upon which some
components such as button, checkbox, radio buttons can be placed and used.

Review Questions

1. Explain the different data types available in JavaScript. SPPU : May-18, Marks 5

2. What are different data types available in JavaScript ? Explain with correct syntax of
declaration of it. SPPU : May-19, Marks 5

2.6 Literals
There are two types of literals used in JavaScript and those are numeric literals and
string literals. The numeric literals are called numbers. These numbers can include
integer values, floating point or double precision values. For example -
10
10.3
10.0
10.
10E3
10.2E4
10.e2
10e-3
are all valid numeric literals.
The string literals are the sequence of characters. It can be written in double quotes “ ”
or in single quotes ‘ ‘. For example
‘Rain Rain come soon ‘

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2-9 Client Side Technologies : JavaScript and DOM

2.7 Other Primitive Types


The other primitive types are -
 Boolean
The Boolean values are true and false. These values can be compared with the
variables or can be used in assignment statement.
 Null
The null value can be assigned by using the reserved word null. The null means no
value. If we try to access the null value then a runtime error will occur.
 Undefined
If a variable is explicitly declared and not assigned any value to it then it is an
undefined value. If we try to display the undefined value then on the browser the
word “undefined” will be displayed. There is no reserved word for undefined
primitive type.

2.8 Variables
In JavaScript we can declare the variable using the reserved word var. The value of
this variable can be anything; it can be numeric or it can be string or it can be a Boolean
value.
JavaScript[VarDemo.html]
<!DOCTYPE html >
<html >
<head>
<title> Variables in Javascript </title>
</head>
<body>
<script type="text/javascript">
var a,b,c;
var string;
Variable declaration is done using var.
a=2;
Note that there is no data type required
b=3; for handling variables.
c=a+b;
string ="The result = ";
document.write("Performing addition of 2 and 3. "+"<br/>");
document.write(string);
document.write(c);
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 10 Client Side Technologies : JavaScript and DOM

Output

Note that using var we can define the variable which is of type numbers (2, 3 or 5) as
well as the string “The result”.

2.9 Operators
Various operators used by JavaScript are as shown in following Table -

Type Operator Meaning Example

Arithmetic + Addition or unary plus c=a+b

– Subtraction or unary minus d=–a

* Multiplication c = a*b

/ Division c = a/b

% Mod c = a%b

Relational < Less than a<4

> Greater than b > 10

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 11 Client Side Technologies : JavaScript and DOM

<= Less than equal to b < =10

>= Greater than equal to a >= 5

== Equal to x == 100

!= Not equal to m != 8

Logical && And operator 0 && 1

|| Or operator 0 ||1

Assignment = Is assigned to a=5

+= add a value then assign a + = 5 means

a=a+5

-= subtract a value then assign a – = 10 means

a = a – 10

/= divide the value then assign a /= 2

*= multiply and then assign a *= 5

Increment ++ Increment by one ++i or i++

Decrement -- Decrement by one – – k or k– –

Conditional operator
The conditional operator is ? The syntax of conditional operator is
Condition?expression1:expression 2
Where expression1 denotes the true condition and expression2 denotes false condition.
For example :
a>b?true:false
This means that if a is greater than b then the expression will return the value true
otherwise it will return false.
Expressions
JavaScript makes use of mathematical statements using operators
and operands.
These statements are called expressions.
For example - Following Fig. 2.9.1 shows a simple expression.

Fig. 2.9.1 An expression

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 12 Client Side Technologies : JavaScript and DOM

2.10 Input and Output

2.10.1 The document.write


 For displaying the message on the web browser the basic method being used is
document.write. To print the desired message on the web browser we write the
message in double quotes inside the document.write method.
 For example
document.write(“Great India”);
 We can pass the variable instead of a string as a parameter to the document.write.
For example
var my_msg=”Great India”;
document.write(my_msg);
Note that the variable my_msg should not be passed in double quotes to
document.write otherwise the result the string “my_msg” will be printed on the browser
instead of the string “Great India”.
 We can combine some HTML tags with the variable names in document.write so
that the formatted display can be possible on the web browser.
For example - if we want to print the message “Great India” on the web browser in
bold font then we can write following statements -
var my_msg=“Great_India”;
document.write(“<strong>”+my_msg+“</strong>”);

2.11 Statements

2.11.1 If Statement
As a selection statement we use various types of if statements. These statements are -
1. if - The syntax of if is
if(condition)
statement if the condition is true
2. if…else - The syntax of if…else is
if(condition)
statement if the condition is true
else
statement if the condition is false
3. if…else if - The syntax of if…else if is
if(condition)

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 13 Client Side Technologies : JavaScript and DOM

statement if the condition is true


else if(condition)
statement if another condition is true
else if(condition)
statement if another condition is true

else
statement
Some times we can have nested if…statements, which work similar to C or C++. Here is a
sample JavaScript.
JavaScript[IfDemo.html]
<!DOCTYPE html>
<html>
<head>
<title>If else Demo</title>
</head>
<body>
<script type="text/javascript">
var a,b,c;
a=10;b=20;c=30;
if(a>b)
{
if(a>c)
document.write("<h3>a is largest number</h3>");
else
document.write("<h3>c is largest number</h3>");
}
else
{
if(b>c)
document.write("<h3>b is largest number</h3>");
else
document.write("<h3>c is largest number</h3>");
}
</script>
</body>
</html>
Script Explanation
The above document is to find the largest number from the given three numbers. We
have used nested if…else statements. The script is pretty simple, in which first of all we

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 14 Client Side Technologies : JavaScript and DOM

have compared a with b, if a is greater than b then we have compared a with c. Similarly
in the else part b is compared with c. Thus all the three numbers get compared with each
other and the largest number is found out among the three. Since already in our program
we have set the a, b and c values as 10, 20 and 30 respectively the output should be c is
largest number and here comes the output on web browser.
Output

We can use various operators such as arithmetic operator, logical operator, relational
operators and so on in the if statement. Following JavaScript makes use of such operators.
JavaScript[IfElseDemo.html]
<!DOCTYPE html>
<html>
<head>
<title>If else Demo</title>
</head>
<body>
<script type="text/javascript">
var marks;
marks=80;
if(marks<40)
document.write("You are failed");
else if(marks>=40 && marks<50)
document.write("You are passed");
else if(marks>=50 && marks<60)
document.write("You have got Second class");
else if(marks>=60 && marks<66)
document.write("You have got First class");
else
document.write("You are Distinction Holder");

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 15 Client Side Technologies : JavaScript and DOM

</script>
</body>
</html>
Output

In above script if we change the values of the marks variable then appropriate message
will get displayed on the web browser.

2.11.2 Switch Statement


Switch case statement is basically to execute the desired choice. The syntax of this
control structure is similar to that in C or C++.
switch(choice)
{
case identifier: statement
break

default: statement
}
JavaScript[SwitchDemo.html]
<!DOCTYPE html>
<html>
<head>
<title>Switch Case Demo</title>
</head>
<body>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 16 Client Side Technologies : JavaScript and DOM

<script type="text/javascript">
d=new Date();
ch=d.getMonth();
switch(ch)
{
case 0: document.write("January");
break;
case 1: document.write("February");
break;
case 2: document.write("March");
break;
case 3: document.write("April");
break;
case 4: document.write("May");
break;
case 5: document.write("June");
break;
case 6: document.write("July");
break;
case 7: document.write("August");
break;
case 8: document.write("September");
break;
case 9: document.write("October");
break;
case 10: document.write("November");
break;
case 11: document.write("December");
break;
}
</script>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 17 Client Side Technologies : JavaScript and DOM

Script Explanation : In this script,


1) We have used the object Date which returns the value of the current date.
2) Then using getMonth() method the month value can be obtained. The month
value starts from 0 to 11 representing January to December. This value is basically
obtained from system date function. The month is taken in variable ch according
to the value in ch the corresponding case will get executed.

2.11.3 Loop Statement

2.11.3.1 while Loop


while statements help us in implementing the iterative logic of the program. The
syntax of while is as follows -
Some initial condition;
while(terminating condition)
{
some statements;
stepping condition;
}
The while is implemented by following JavaScript.
<!DOCTYPE html>
<html>
<head>
<title>while Demo</title>
</head>
<body>
<table border=1 align="center">
<th>Number</th><th>Square</th>
<script type="text/javascript">
i=1;
while (i<=10)
{
document.write("<tr><td>"+i+"</td><td>"+(i*i)+"</td></tr>");
i++;
}
</script>
</table>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 18 Client Side Technologies : JavaScript and DOM

Output

2.11.3.2 do..while Loop


The do-while loop is similar to the while loop, the only difference is that the do-while
executes at least once. The syntax of do…while is
do
{

}while(condition);
The following JavaScript illustrates use of do…while
JavaScript[DoWhile.html]
<!DOCTYPE html>
<html>
<head>
<title>Do-while Demo</title>
</head>
<body>
<script type="text/javascript">
counter=1;
do
{
document.write("This statement number: "+counter);
document.write("<br>");
counter++;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 19 Client Side Technologies : JavaScript and DOM

}while(counter<=5);
</script>
</body>
</html>
Output

2.11.3.3 for Loop


This is the most commonly used programming construct. The syntax of for loop is
for(initial condition; terminating condition; stepping condition)
Here is a JavaScript which makes use of for loop
JavaScript[ForLop.html]
<!DOCTYPE html>
<html>
<head>
<title>For Loop Demo</title>
</head>
<body>
<table border=1 align="center">
<th>Number</th><th>Square</th>
<script type="text/javascript">
for (i=1; i<=10; i++)
{
document.write("<tr><td>"+i+"</td><td>"+(i*i)+"</td></tr>");
}
</script>
</table>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 20 Client Side Technologies : JavaScript and DOM

Output

2.11.3.4 break Statement


Similar to C or C++, the break statement is used to break the loop. It is given be
keyword break. The following script shows the use of break.
JavaScript[breakDemo.html]
<!DOCTYPE html>
<html>
<head>
<title>Break Statement</title>
</head>
<body>
<script type="text/javascript">
for(i=10;i>=0;i--)
{
if(i==5)
break;
}
document.write("My Lucky number is "+i);
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 21 Client Side Technologies : JavaScript and DOM

Output

2.11.3.5 The continue Statement


The continue statement is used in a loop in order to continue (skip). The keyword
continue is used to make use of continue statement in a loop.
Javascript Program[ContinueDemo.html]
<!DOCTYPE html>
<html>
<head>
<title>Continue Statement</title>
</head>
<body>
<script type="text/javascript">
for(i=10;i>=0;i--)
{
if(i==5)
{
x=i;
continue;
}
document.write(i);
document.write("<br>");
}
document.write("The number "+x+" is missing in above list" );
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 22 Client Side Technologies : JavaScript and DOM

Output

2.12 Querying and Handling Properties


 One of the important features of JavaScript is its interactivity with the user.
 There are three types of popup boxes used in JavaScript by which user can interact
with the browser.
alert box : In this type of popup
box some message will be
displayed.

confirm box : In this type of popup


box in which the message about
confirmation will be displayed.
Hence it should have two buttons
Ok and Cancel.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 23 Client Side Technologies : JavaScript and DOM

Prompt box is a type of popup box


which displays a text window in
which the user can enter
something. Hence it has two
buttons Ok and Cancel.

JavaScript[PopupBox.html]
<!DOCTYPE html>
<html >
<head>
<title>Introduction to pop up box</title>
</head>
<body>
<p>Experiment with the popup boxes by clicking the buttons(OK and Cancel) on them</p>

<script type="text/javascript">
if(confirm("do you agree?"))
alert("You have agreed");
else
input_text=prompt("Enter some string here..."," ");
/*the value entered in prompt box is returned
and stored in the variable text */
alert("Hi "+input_text);
</script>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 24 Client Side Technologies : JavaScript and DOM

If we click on OK button then an alert box will appear.

On load, the confirm box appears and if we click on Cancel button then the prompt
box will appear. We can type some string within it.

Click OK button and we will get the alert box as follows -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 25 Client Side Technologies : JavaScript and DOM

Thus alert, confirm and prompt boxes cause the browser to wait for user response. The
user responds by clicking the button on these popup boxes.
Script Explanation

On loading this script using web browser first of all a confirm box will be displayed. If
we click on OK button an alert box will appear. Otherwise a prompt box will be
displayed. Again if we click on the OK button of prompt box again an alert box will
appear which will display the string which you have entered on prompt box. If you run
the above script you will get all these effects.

Example 2.12.1 Develop a javascript to generate ‘ARMSTRONG NUMBERS’ between the


ranges 1 to 100. [e.g. : 153 is an Armstrong number, since sum of the cube of the digits is
equal to the number i.e. [13 + 53 + 33 = 153].
Solution :
<html>
<body>
<table border="1" allign="center">
<th>Armstrong Numbers</th>
<script type="text/javascript">
var num,i,temp,sum;
var n=0;
i=1;
do
{
num=i;
sum=0;
while(num>0)
{

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 26 Client Side Technologies : JavaScript and DOM

n=num%10;
n=parseInt(n);
num=num/10;
num=parseInt(num);
sum=sum+(n*n*n);
}
if(sum==i)
{
document.write("<tr><td>"+i+"</td></tr>");
}
i++;
}while(i<=1000);
</script>
</table>
</body>
</html>

Example 2.12.2 Write a JavaScript that displays table as per following : (Calculate the squares
and cubes of the numbers from 0 to 10).
Number Square Cube
1 1 1
2 4 8
3 9 27
4 16 64
5 25 125
6 36 216
7 49 343
8 64 512
9 81 729
10 100 1000
Solution :
<html>
<head>
<title>Sqaure and Cube value table</title>
</head>
<body>
<table border=1 align="center">
<th>Number</th><th>Square</th><th>Cube</th>
<script type="text/javascript">
for (i=1; i<=10; i++)
{
document.write("<tr><td>"+i+"</td><td>"+(i*i)+"</td><td>"+(i*i*i)+"</td></tr>");

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 27 Client Side Technologies : JavaScript and DOM

}
</script>
</table>
</body>
</html>

Example 2.12.3 Write a script that reads an integer and displays whether it is a prime number
or not.
Solution :
<html>
<head>
<title>PRIME NUMBER DEMO</title>
</head>
<body>
<script type="text/javascript">
var num=prompt("Type number here.","");
var b;
var flag=1;
for(i=2;i<num;i++)
{
b=num%i;
if(b==0)
{

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 28 Client Side Technologies : JavaScript and DOM

flag=0;
break;
}
}
if(flag==0)
alert(num+" is not a prime number");
else
alert(num+" is a prime number");
</script>
</body>
</html>

Output

2.13 Functions
SPPU : April-18, Dec.-18, Marks 5
 We can write the functions in the JavaScript for bringing the modularity in the
script.
 Separate functions can be created for each separate task. This ultimately helps in
finding the bug from the program efficiently.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 29 Client Side Technologies : JavaScript and DOM

2.13.1 Defining a Function


 We can define the function anywhere in the script either in head or body section or
in both. But it is a standard practice to define the function in the head section and
call that function from the body section.
 The keyword function is used while defining the function.
 The syntax for defining the function is
function name_of _function (arg1,arg2,…argn)
{

Statements
}

2.13.2 Writing a Function


Here is a simple illustration in which we have written a function my_fun()
JavaScript[FunDemo.html]

<!DOCTYPE html>
<html>
<head>
<title>Function Demo</title>
<script type="text/javascript">
function my_fun()
{
document.write("This statement is within the function"); Definition of function
}
</script>
</head>
<body>
<center>
<script type="text/javascript">
document.write("This statement is before a function call");
document.write("<br>");
my_fun(); // call to the function
</script>
</center>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 30 Client Side Technologies : JavaScript and DOM

Output

Script Explanation
The above code is pretty simple. We have defined one function named my_fun in the
head section of the HTML document and called it from the body section. The
corresponding write statements are used to display the messages on the browser
window.

2.13.3 Adding an Arguments


 We can pass some arguments to the function.
 The syntax is
function function_name(aregument1, argument2…,argumentn)
{
//body of function
}

2.13.4 Scope of Variable and Argument


 Scope is the block or area of program in which particular variable or argument is
accessible.
 The scope is defined using two types of variables - Local Scope and Global Scope.
Local Scope
If a variable is defined inside a function then that variable is a local variable and its
scope is a local scope. That also means that the local variable is accessible only within a
function in which it is defined. It is not accessible outside that function.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 31 Client Side Technologies : JavaScript and DOM

Following program shows the use of local variable.


JavaScript example for demonstrating scope of local variable
<!DOCTYPE html>
<html>
<head>
<script type="text/javascript">
function A()
{
var a=100//local variable
document.getElementById("id1").innerHTML=
"From function A(): a = "+a
}
function B()
{
document.getElementById("id2").innerHTML=
"From function B(): a = "+a
}
</script>
</head>
<body>
<p id="id1"></p>
<p id="id2"></p>
<script type="text/javascript">
A()
B()
</script>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 32 Client Side Technologies : JavaScript and DOM

Script Explanation :
In above JavaScript,
1) We have created two functions namely A() and B().
2) Inside the A() function variable a is declared and initialized to the value 100. The
value of this variable is displayed using the element<p>…</p>
3) Inside the B() function, we are trying to display the value of same variable a
using <p>…</p> . But note that the output does not display value of variable a
through function B(). This is because variable a is a local variable declared in
function A(). Hence its scope is upto the function A(). Outside this function, the
variable a is undefined.
Global Scope
A variable is called global variable, if it is defined outside the function. The variable
having global scope is accessible by any function.
Following example illustrates the use of global variable.
JavaScript example for demonstrating the scope of global variable
<!DOCTYPE html>
<html>
<head>
<script type="text/javascript">
var a=100//Global variable
function A()
{
document.getElementById("id1").innerHTML
="From function A(): a = "+a
}
function B()
{
document.getElementById("id2").innerHTML
="From function B(): a = "+a
}
</script>
</head>
<body>
<p id="id1"></p>
<p id="id2"></p>
<script type="text/javascript">
A()
B()
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 33 Client Side Technologies : JavaScript and DOM

Output

2.13.5 Calling a Function from with Argument


In JavaScript, we can pass an argument to the function. Following JavaScript shows
how to pass an argument to the function. In the following program I have written a
simple function for addition of two numbers. The values of two numbers are 10 and 20
respectively. Inside this function the addition of these two arguments is carried out and
result is displayed on the Browser page.
<!DOCTYPE html>
<html>
<head>
<script type="text/javascript">
function add(a,b)//function to which arguments a and b are passed
{
c=a+b
document.write("Addition = "+c)
}
</script>
</head>
<body>
<h4> Passing Arguments to the function </h4>
<script type="text/javascript">
var x=10;
var y=20
add(x,y)
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 34 Client Side Technologies : JavaScript and DOM

Output

2.13.6 Calling a Function without an Argument


A function can also be called without passing any argument. In this case, all the
required variables are declared and used within that function. Following program shows
how to call a function without passing an argument.
JavaScript Document
<!DOCTYPE html>
<html><head>
<script type="text/javascript">
function add()
{
var a=10
var b=20
c=a+b
document.write("Addition = "+c)
}
</script>
</head>
<body>
<h4> Function without passing argument</h4>
<script type="text/javascript">
add()
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 35 Client Side Technologies : JavaScript and DOM

Output

2.13.7 Calling a Function from HTML

For calling a function from HTML normally, JavaScript events are used. For example -

JavaScript Document

<!DOCTYPE html>
<html>
<head>
<script type="text/javascript">
function A()
{
alert("Inside the function A");
}
</script>
</head>
<body onload="A()">
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 36 Client Side Technologies : JavaScript and DOM

Output

2.13.8 Function Calling another Function


We can call one function from another function. This is called nested functions. In the
following code, there is a call for function B() from function A().
<!DOCTYPE html>
<html>
<head>
<script type="text/javascript">
function A()
{
B();//calling another function
}
function B()
{
alert("Inside function B() via function A()");
}
</script>
</head>
<body onload="A()">
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 37 Client Side Technologies : JavaScript and DOM

Output

2.13.9 Returning a Value from Function


 We can return some value from the function using a keyword return.
 This return value is either stored in variable or directly displayed on the browser
window.
 Following is a simple illustration in which the value is returned from the function
and is directly displayed on the browser window using document.write.
JavaScript[FunRetDemo.html]
<!DOCTYPE html>
<html>
<head>
<title>Function Demo</title>
<script type="text/javascript">
function my_fun()
{
str="I am function returned value";
return str;
}
</script>
</head>
<body>
<center>
<script type="text/javascript">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 38 Client Side Technologies : JavaScript and DOM

document.write("This statement is before a function call");


document.write("<br>");
document.write("<h3>"+my_fun()+"<h3>");
</script>
</center>
</body>
</html>
Output

Review Questions

1. List and brief any five functions in JavaScript. SPPU : April-18, Marks 5
2. Explain how to call JavaScript function from HTML page. SPPU : Dec.-18, Marks 5

2.14 Built in Objects


In JavaScript object is a collection of properties. These properties are nothing but the
members of the classes from Java or C++. For instance - in JavaScript the object Date() is
used which happens to the member of the class in Java.

2.14.1 Math Objects

 For performing the mathematical computations there are some useful methods
available from math object.

 For example if we want to find out minimum of two numbers then we can write -
document.write(math.min(4.5,7.8));
The above statement will result in 4.5. Thus using various useful methods we can
perform many mathematical computations.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 39 Client Side Technologies : JavaScript and DOM

 Here are some commonly used methods from math object.

Method Meaning

sqrt(num) This method finds the square root of num.

abs(num) This method returns absolute value of num.

ceil(num) This method returns the ceil value of num. For example ceil(10.3) will return 11.

floor(num) This method returns the floor value of num. For example floor(10.3) will return 10.

log(num) This method returns the natural logarithmic value of num. For example log(7.9) will
return 2.

pow(a,b) This method will compute the ab. For example pow(2,5) will return 32.

min(a,b) Returns the minimum value of a and b.

max(a,b) Returns the maximum value of a and b.

sin(num) Returns the sine of num.

cos(num) Returns the cosine of num.

tan(num) Returns the tangent of num.

exp(num) Returns the exponential value i.e. enum .

JavaScript Program[MathDemo.html]
<!DOCTYPE html>
<html >
<head>
<title>Math Demo</title>
</head>
<body>
<center>
<h3>Square root of 100 is </h3>
<script type="text/javascript">
var num=100;
document.write("<h3>"+Math.sqrt(num)+"</h3>");
</script>
</center>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 40 Client Side Technologies : JavaScript and DOM

Output

2.14.2 Number Objects


Various properties of number object are -

Property Meaning

MAX_VALUE Largest possible number gets displayed.

MIN_VALUE Smallest possible number gets displayed.

NaN When not a number then NaN is displayed.

PI The value of PI gets displayed.

POSITIVE_INFINITY The positive infinity gets displayed.

NEGATIVE_INFINITY The negative infinity gets displayed.

Using Number.property_name we can display the property value. Following JavaScript


uses the property of negative infinity.

JavaScript[NumberDemo.html]
<!DOCTYPE html>
<html>
<head>
<title>Number Object Demo</title>
</head>
<body>
<center>
<script type="text/javascript">
document.write(Number.NEGATIVE_INFINITY);
</script>
</center>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 41 Client Side Technologies : JavaScript and DOM

Output

2.14.3 Date Objects


 This object is used for obtaining the date and time.
 This date and time value is based on computer’s local time (system’s time) or it can
be based on GMT (Greenwich Mean Time).
 Nowadays this GMT is also known as UTC i.e. Universal Co-ordinated Time. This
is basically a world time standard.
 Following are the commonly used methods of Date object.

Method Meaning

getTime() It returns the number of milliseconds. This value is the difference


between the current time and the time value from 1st January 1970.

getDate() Returns the current date based on computers local time.

getUTCDate() Returns the current date obtained from UTC.

getDay() Returns the current day. The day number is from 0 to 6 i.e. from
Sunday to Saturday.

getUTCDay() Returns the current day based on UTC. The day number is from 0 to
6 i.e. from Sunday to Saturday.

getHours() Returns the hour value ranging from 0 to 23, based on local time.

getUTCHours() Returns the hour value ranging from 0 to 23, based on UTC timing
zone.

getMilliseconds() Returns the milliseconds value ranging from 0 to 999, based on local
time.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 42 Client Side Technologies : JavaScript and DOM

getUTCMilliseconds() Returns the milliseconds value ranging from 0 to 999, based on UTC
timing zone.

getMinutes() Returns the minute value ranging from 0 to 59, based on local time.

getUTCMinutes() Returns the minute value ranging from 0 to 59, based on UTC timing
zone.

getSeconds() Returns the second value ranging from 0 to 59, based on local time.

getUTCSeconds() Returns the second value ranging from 0 to 59, based on UTC timing
zone.

setDate(value) This function helps to set the desired date using local timing or UTC
timing zone.

setHour(hr,minute,second,ms) This function helps to set the desired time using local or UTC timing
zone. The parameters that can be passed to this function are hour,
minute, seconds and milliseconds. Only hour parameter is
compulsory and rest all are the optional parameters.

In the following web document we are making use of Date() object and some useful
methods of it.

JavaScript[DateDemo.html]
<!DOCTYPE html>
<html>
<head>
<title>Date Demo</title>
</head>
<body>
<script type="text/javascript">
var my_date=new Date();
document.write("The date is: "+my_date.toString()+"<br>");
document.write("Today's date is "+my_date.getDate()+"<br>");
document.write("This is the month of "+my_date.getMonth()+"<br>");
document.write("The current year is "+my_date.getFullYear()+"<br>");
document.write("Now, Hour = "+my_date.getHours()+"<br>");
document.write("Minutes = "+my_date.getMinutes()+"<br>");
document.write("Seconds = "+my_date.getSeconds()+"<br>");
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 43 Client Side Technologies : JavaScript and DOM

Output

Script Explanation :
1. In the above script we have created an instance my_date of the object Date().
2. Then using my_date.toString() method we can display the current date along
with the time.
3. Then using the functions like getDate(), getMonth(), getFullYear() we are
displaying the date, month and year separately.
4. Similarly using the functions getHours(), getMinutes() and getSeconds() we can
display the current hour, minute and seconds separately.

2.14.4 Boolean Objects


 This object is the simplest kind of object which is used especially when we want to
represent true and false values.
 Here is a simple JavaScript in which the Boolean type variable is used -

Javascript Program
<html>
<body>
<script type="text/javascript">
var temp=new Boolean(false);
document.write("<b>"+"The boolean value is: ");
document.write(temp.toString());
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 44 Client Side Technologies : JavaScript and DOM

Output

2.14.5 String Objects


 String is a collection of characters.
 In JavaScript using string object many useful string related functionalities can be
exposed off.
 Some commonly used methods of string object are concatenating two strings,
converting the string to upper case or lower case, finding the substring of a given
string and so on.
 Here is a listing of some methods of string.

Method Meaning

concat(str) This method concatenates the two strings. For example - s1.concat(s2) will
result in concatenation of string s1 with s2.

charAt(index_val) This method will return the character specified by value index_val.

substring(begin,end) This method returns the substring specified by begin and end character.
toLowerCase() This function is used to convert all the uppercase letters to lower case.

toUpperCase() This function is used to convert all the lowercase letters to upper case.
valueOf() This method returns the value of the string.

There is one important property of string object and that is length. For example
var my_str=”Hello”;
var len; Length of the string “Hello” will be
len=my_str.length; stored in the variable len

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 45 Client Side Technologies : JavaScript and DOM

Here is sample program in which some methods of string object are used.
JavaScript[StringDemo.html]
<!DOCTYPE html>
<html>
<head>
<title>String Properties and Methods Demo</title>
</head>
<body>
<strong>
<script type="text/javascript">
var s1="Hello ";
var s2="Parth!";
document.write("First string is: "+s1+"<br>");
document.write("Second string is: "+s2+"<br>");
document.write("Concatenating two strings: "+s1.concat(s2)+"<br>");
document.write("Finding length of Second string : "+s2.length+"<br>");
document.write("The character at 0th position of First string is : "+s1.charAt(0)+"<br>");
document.write("The First string can be converted to upper case as : "+s1.toUpperCase());
</script>
</strong>
</body>
</html>
Output

Example 2.14.1 Write a script that inputs a line of text, tokenizes it with String method split
and displays the tokens in reverse order.
Solution :
<html>
<body>
<script type="text/javascript">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 46 Client Side Technologies : JavaScript and DOM

var str=new String("I like writing in javascript");


var a=new Array();
a=str.split(' ');
document.write("<strong>The original string is</strong>"+"<br/>");
for(i=0;i<a.length;i++)
document.write(a[i]+" ");
document.write("<br/>");
document.write("<strong>The reversed string is</strong>"+"<br/>");
for(i=a.length-1;i>=0;i--)
document.write(a[i]+" ");
</script>
</body>
</html>
Output

2.15 Creation of Object SPPU : Dec.-18, Marks 5

 The web designer can create an object and can set its properties as per his
requirements.
 The object can be created using new expression.
 Initially the object with no properties can be set using following statements.
Myobj=new Object();

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 47 Client Side Technologies : JavaScript and DOM

 Then using dot operator we can set the properties for that object.
 The object can then be modified by assigning the values to this object.

JavaScript[ObjectDemo.html]
<!DOCTYPE html>
<html>
<head>
<title>Object Creation Demo</title>
</head>
<body>
<strong>
<script type="text/javascript">
var Myobj;
var n,i;
//creating an object
Myobj=new Object();
//setting the propertis for newly created object
Myobj.id=10;
Myobj.name="Anuradha";
document.write("The ID is "+Myobj.id+"<br/>");
document.write("The Name is "+Myobj.name);
</script>
</strong>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 48 Client Side Technologies : JavaScript and DOM

Alternative method of creating an object and modifying the properties is as given


below -
var Myobj={name:"Anuradha",id:10};
Then using document.write statement we can display the property values as follows -
document.write("The ID is "+Myobj.id+"<br/>");
document.write("The Name is "+Myobj.name);
The property of created object can be deleted using an expression delete. Normally the
property of an object is deleted in order to free the allocated memory so that this memory
can be reused by other process.

Review Question

1. How to create an object in JavaScript ? Explain with suitable examples.


SPPU : Dec.-18, Marks 5

2.16 Arrays SPPU : May-18,19, Marks 5

 Definition of Arrays : Arrays is a collection of similar type of elements which can


be referred by a common name.
 Any element in an array is referred by an array name followed by “[“followed by
position of the element followed by].
 The particular position of element in an array is called array index or subscript.
For example -

Fig. 2.16.1 Arrays

 Normally the first element in an array is stored at 0th location, however we can start
storing the element from any position.

2.16.1 Declaring an Array


 In JavaScript the array can be created using Array object.
 Suppose, we want to create an array of 10 elements then we can write,
var ar = new Array(10);

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 49 Client Side Technologies : JavaScript and DOM

 Using new operator we can allocate the memory dynamically for the arrays.
 In the brackets the size of an array is mentioned and the var ar denotes the name of
the array. Thus by the above sentence an array ar will be created in which we can
store 10 elements at the most. Sometimes the above statement can be written like
this
var ar;
ar=new Array(10);

2.16.2 Initializing an Array


 Initialization is the process of assigning a value when either a variable or array is
declared. For example
int count=10//variable initialization
 While initializing an array -
1) Declare name of the array
2) Make use of the keyword new
3) Each value within an array as an ‘array element’ must be separated by
comma.
 For example -

Fig. 2.16.2

2.16.3 Defining an Array Elements


 The elements in the array are stored from index 0.
 For example - elements in array 10, 20, 30, 40, 50 are stored as follows -

Fig. 2.16.3

 Following is a simple JavaScript that illustrates the initialization of array by


defining the array elements.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 50 Client Side Technologies : JavaScript and DOM

JavaScript Document
<!DOCTYPE html>
<html>
<head>
<title>Array Demo</title>
</head>
<body>
<strong>
<script type="text/javascript">
a=new Array(5);//creation of array
for(i=0;i<5;i++)
{
a[i]=i;
document.write(a[i]+"<br>");//displaying array
}
document.write("Another way of initialization"+"<br>");
b=new Array(11,22,33,44,55);//creation of array
for(i=0;i<5;i++)
{
document.write(b[i]+"<br>");//displaying array
}
document.write("Yet another way of initialization"+"<br>");
var c=[100,200,300,400,500];//creation of array
for(i=0;i<5;i++)
{
document.write(c[i]+"<br>");//displaying array
}
</script>
</strong>
</body>
</html>

Script Explanation : In above JavaScript, as you can notice that, an array can be
initialized in three different ways which is shown by boldface. Hence an output of above
script will be

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 51 Client Side Technologies : JavaScript and DOM

Output

Example 2.16.1 Write a JavaScript to define the array elements and to find the length of array.
Solution :
<!DOCTYPE html>
<html>
<head>
<title>Array Demo</title>
</head>
<body>
<script type="text/javascript">
a=new Array(11,22,33,44,55);//creation of array
var len=a.length
document.write("The length of array is: "+len)
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 52 Client Side Technologies : JavaScript and DOM

Output

Script Explanation : In above JavaScript, We have used length property to calculate


length of the array. This actually gives total number of elements in the array.

2.16.4 Looping an Array


 Looping an array means visiting each element present in the array.
 Following JavaScript illustrates how to loop or iterate through the elements of
array -
JavaScript Document
<!DOCTYPE html>
<html>
<head>
<title>for Loop Demo</title>
</head>
<body>
<script type="text/javascript">
Days=new Array();
Days[0]="Sunday";
Days[1]="Monday";
Days[2]="Tuesday";
Days[3]="Wednesday";
Days[4]="Thursday";
Days[5]="Friday";
Days[6]="Saturday";
for(i=0;i<Days.length;i++)
{
document.write(Days[i]+"<br>");
}
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 53 Client Side Technologies : JavaScript and DOM

Output

2.16.5 Adding an Array Element


 We can add the element in the array at the end. This increases the size of the array.
 Following example illustrates this idea -
JavaScript Document
<!DOCTYPE html>
<html>
<head>
<title>for Loop Demo</title>
</head>
<body>
<script type="text/javascript">
a=new Array();
a[0]=10;
a[1]=20;
a[2]=30
a[3]=40
a[4]=50;
document.write("The elements in the array are...<br/>");
for(i=0;i<a.length;i++)
{
document.write(a[i]+" ");
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 54 Client Side Technologies : JavaScript and DOM

document.write("<br/><br/>The element is added in the array...<br/>");


a[a.length]=60;
document.write("<br/>Now, The elements in the array are...<br/>");
for(i=0;i<a.length;i++)
{
document.write(a[i]+" ");
}
</script>
</body>
</html>
Output

2.16.6 Sorting an Array Element


 The elements can be sorted using the built in function sort.
 Sorting is basically a process of arranging the elements in ascending order or
increasing order.
 For example -
JavaScript Document
<!DOCTYPE html>
<html>
<head>
<title>Sorting Demo</title>
</head>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 55 Client Side Technologies : JavaScript and DOM

<body>
<script type="text/javascript">
a=new Array();
a[0]=40;
a[1]=30;
a[2]=10
a[3]=50
a[4]=20;
document.write("The elements in the array are...<br/>");
for(i=0;i<a.length;i++)
{
document.write(a[i]+" ");
}
document.write("<br/><br/><b>The array is sorted...</b><br/>");
a.sort();
document.write("<br/>Now, The elements in the array are...<br/>");
for(i=0;i<a.length;i++)
{
document.write(a[i]+" ");
}
</script>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 56 Client Side Technologies : JavaScript and DOM

2.16.7 Combining Array Elements into String


 In JavaScript it is possible to combine the array elements into a string.
 We need to use two functions for combining array elements into string and those
are -
1) Join() 2) concat()
 There is difference between join() and concat() function. The concat() method
separates each value with a comma. The join() method also uses a comma to
separate values, but you can specify a character other than a comma to separate
values.
JavaScript Document
<!DOCTYPE html>
<html>
<head>
<title>Combing Array Demo</title>
</head>
<body>
<script type="text/javascript">
a=new Array();
a[0]="Red";
a[1]="Orange";
a[2]="Yellow"
a[3]="Green"
a[4]="Blue";
a[5]="Indigo";
a[6]="Violet";
document.write("<h3> The join() method</h3>");
var str1=a.join(' ');
document.write(str1);
document.write("<h3> The concat() method</h3>");
var str2=a.concat();
document.write(str2);

</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 57 Client Side Technologies : JavaScript and DOM

Output

2.16.8 Changing Elements of an Array


There are various methods that help in changing the elements of array.
1) Shift Method

This method removes the first element of the array. For example -
<!DOCTYPE html>
<html>
<head>
<title>Changing Array Demo</title>
</head>
<body>
<script type="text/javascript">
a=new Array();
a[0]=10
a[1]=20
a[2]=30
a[3]=40
a[4]=50
document.write("<h4> The shift() method</h4>");
var num=a.shift();
document.write(num);
document.write("<h4>The elements in array are ...</h4>");
for(i=0;i<a.length;i++)

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 58 Client Side Technologies : JavaScript and DOM

document.write(a[i]+" ");
</script>
</body>
</html>
Output

2) Push Method
The push method is used to create a new element at the end of the array.
For example -
<!DOCTYPE html>
<html>
<head>
<title>Changing Array Demo</title>
</head>
<body>
<script type="text/javascript">
a=new Array();
a[0]=10
a[1]=20
a[2]=30

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 59 Client Side Technologies : JavaScript and DOM

a[3]=40
a[4]=50
document.write("<h4>The elements in array are ...</h4>");
for(i=0;i<a.length;i++)
document.write(a[i]+" ");
document.write("<h4> Calling The push() method</h4>");
a.push(60);
document.write("<h4>The elements in array are ...</h4>");
for(i=0;i<a.length;i++)
document.write(a[i]+" ");
</script>
</body>
</html>
Output

3) Pop Method
This method returns and removes the last element of the array. For example -
<!DOCTYPE html>
<html>
<head>
<title>Changing Array Demo</title>
</head>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 60 Client Side Technologies : JavaScript and DOM

<body>
<script type="text/javascript">
a=new Array();
a[0]=10
a[1]=20
a[2]=30
a[3]=40
a[4]=50
document.write("<h4>The elements in array are ...</h4>");
for(i=0;i<a.length;i++)
document.write(a[i]+" ");
document.write("<h4> Calling The pop() method</h4>");
var val=a.pop();
document.write("The element returned is "+val)
document.write("<h4>The elements in array are ...</h4>");
for(i=0;i<a.length;i++)
document.write(a[i]+" ");
</script>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 61 Client Side Technologies : JavaScript and DOM

4) Reverse Method
The reverse method is used to reverse the elements present in the array. For example
<!DOCTYPE html>
<html>
<head>
<title>Changing Array Demo</title>
</head>
<body>
<script type="text/javascript">
a=new Array();
a[0]=10
a[1]=20
a[2]=30
a[3]=40
a[4]=50
document.write("<h4>The elements in array are ...</h4>");
for(i=0;i<a.length;i++)
document.write(a[i]+" ");
document.write("<h4> Calling The reverse() method</h4>");
a.reverse();
document.write("<h4>The elements in array are ...</h4>");
for(i=0;i<a.length;i++)
document.write(a[i]+" ");
</script>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 62 Client Side Technologies : JavaScript and DOM

Review Question

1. Explain how to create and read array elements in JavaScript.


SPPU : May-18,19, Marks 5

2.17 Strings
 String is a collection of characters.
 Some commonly used methods of string object are concatenating two strings,
converting the string to upper case or lower case, finding the substring of a given
string and so on.
 The string is written within the quotes- either single quote or double quote.
For example -
var myname=’ABC’

2.17.1 Manipulating a String


Manipulating a string means, changing one string to another, joining two strings,
changing the string from upper case to lower case or from lower case to upper.
There are some commonly used methods of string

Method Meaning

concat(str) This method concatenates the two strings. For example s1.concat(s2) will
result in concatenation of string s1 with s2.

charAt(index_val) This method will return the character specified by value index_val.

substring(begin,end) This method returns the substring specified by begin and end character.

toLowerCase() This function is used to convert all the uppercase letters to lower case.

toUpperCase() This function is used to convert all the lowercase letters to upper case.

valueOf() This method returns the value of the string.

There is one important property of string object and that is length. For example
var my_str=”Hello”;
var len; Length of the string “Hello” will be
len=my_str.length; stored in the variable len

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 63 Client Side Technologies : JavaScript and DOM

2.17.2 Joining a String


We can join two strings using + operator. For example -
<!DOCTYPE html>
<html>
<script type="text/javascript">
var Firstname="AAA"
var Lastname=" BBB"
var name=Firstname+Lastname
alert(name);
</script>
</body>
</html>
Output

2.17.3 Receiving a Character from Given Position


The charAt() is a method that returns the character from the specified index. The index
of a first character is 0; the second character is 1 and so on. Javascript characters in a string
are indexed from left to right.
If no index is provided to charAt() method, then the default is 0. Following program
illustrates how to receive character from given position.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 64 Client Side Technologies : JavaScript and DOM

JavaScript Document
<!DOCTYPE html>
<html>
<script type="text/javascript">
var str="ABC"
alert("The character at first position of string: "+str+" is: "+str.charAt(0))
</script>
</body>
</html>
Output

2.17.4 Retrieving a Position of Character in a String


 For finding the position of particular character we use indexOf function.
 It returns the position of the first occurrence of a specified value in a string.
 This method is case sensitive.
 Example
<!DOCTYPE html>
<html>
<script type="text/javascript">
var str="I love India - my country"
var n=str.indexOf("India");
alert("The word 'India' is from index: "+n+" in the text: "+str)
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 65 Client Side Technologies : JavaScript and DOM

Output

2.17.5 Dividing Text


 Any text is made up of words. We can divide the text into a collection of these
words. For example - User may enter his/her complete name as first name, middle
name and surname. By dividing the text, we can get firstname, middle name and
surname separated.
 Usually split() function is used to divide the text.
 The split() method creates a new array and then copies portions of the string, called
a substring, into its array element.
 Syntax : The split method is used in the following manner -
var newStrArray=textname.split(delimiter character)
JavaScript Document
<!DOCTYPE html>
<html>
<script type="text/javascript">
var Name="Shivaji Shahaji Bhosale"
var list=Name.split(' ')
alert("First Name: "+list[0]+"\nMiddle Name: "+list[1]+"\nLast Name: "+list[2])
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 66 Client Side Technologies : JavaScript and DOM

Output

2.17.6 Copying a Substring


There are two useful methods for copying a substring - i) substring() and ii) substr()

1. Use of substring

The syntax of substring is


substring(start, end)
where start indicates the starting index and end indicates the ending index for
extracting substring.
Following program shows use of substring() function for retrieving the substring and
then copying it to some other string at the end.
<!DOCTYPE html>
<html>
<script type="text/javascript">
var Name1="Shivaji Shahaji Bhosale"
var Name2="Sambhaji"
var sub_str=Name1.substring(16,23)
document.write("<br/>The Name1: "+Name1)
document.write("<br/>The Surname: "+sub_str)
document.write("<br/>The Name2: "+Name2)
document.write("<br/><b>Copying the surname for Name2...</b>")
var Name3=Name2+" "+sub_str

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 67 Client Side Technologies : JavaScript and DOM

document.write("<br/>The Name3: "+Name3)


</script>
</body>
</html>
Output

2. Use of substr
The substr method is also used to extract the substring from the text. The syntax for
substr is as follows
substr(start,length)
where start indicates the starting index and length indicates the number of characters to
be extracted.
Following example shows how to extract some substring using substr() method and then
copy this substring to another text.
JavaScript Document
<!DOCTYPE html>
<html>
<script type="text/javascript">
var Name1="Shivaji Shahaji Bhosale"
var Name2="Sambhaji"
var sub_str=Name1.substr(16,7)
document.write("<br/>The Name1: "+Name1)
document.write("<br/>The Surname: "+sub_str)

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 68 Client Side Technologies : JavaScript and DOM

document.write("<br/>The Name2: "+Name2)


document.write("<br/><b>Copying the surname for Name2...</b>")
var Name3=Name2+" "+sub_str
document.write("<br/>The Name3: "+Name3)
</script>
</body>
</html>
Output

2.17.7 Converting String to Number and Number to String


1. Converting String to Number

For converting string to number we have different types of functions based on type of
numbers - That means if string is to be converted to integer(a number without decimal
point) then the method parseInt() is used. If string is to be converted to float value then
the method parseFloat() is used.
Example
<!DOCTYPE html>
<html>
<script type="text/javascript">
var str="100";
var a=parseInt(str)//converting string 100 to number 100
var b=200;
result=str+b

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 69 Client Side Technologies : JavaScript and DOM

document.write("<br/>Adding 200 to '100' = "+result)


result=a+b
document.write("<br/>Adding 200 to 100 = "+result)
</script>
</body>
</html>
Output

2. Converting Number to String

Using toString() method we can convert a number to string. For example -


<!DOCTYPE html>
<html>
<script type="text/javascript">
var num=100;
var str=num.toString()
document.write("<br/>The 100 value is converted to string "+str)
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 70 Client Side Technologies : JavaScript and DOM

Output

2.17.8 Changing Case of String


Using toLowerCase(), we can convert the capital letters in the string to small letter. For
example
<!DOCTYPE html>
<html>
<script type="text/javascript">
var str="WELCOME FRIENDS";
var newstr=str.toLowerCase()
document.write("<br/>The "+str+" is converted to: "+newstr)
</script>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 71 Client Side Technologies : JavaScript and DOM

Using toUpperCase() method we can convert the small letters to capital letters.
For example -
<!DOCTYPE html>
<html>
<script type="text/javascript">
var str="welcome friends";
var newstr=str.toUpperCase()
document.write("<br/>The "+str+" is converted to: "+newstr)
</script>
</body>
</html>
Output

2.17.9 Finding Unicode of a Character


 Computer can not understand characters. It understands only numbers. Hence
whenever user types some letter, it gets converted automatically to a number called
Unicode number. The computer can understand this Unicode number only.
 Unicode is a standard that assigns a number to every character, number, and
symbol that can be displayed on a computer screen.
 The charCodeAt() is a methods that returns Unicode of a string. For example -
<!DOCTYPE html>
<html>
<script type="text/javascript">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 72 Client Side Technologies : JavaScript and DOM

var ch='a'
var n=ch.charCodeAt()
document.write("<br/>The letter '"+ch+"' has a unicode as: "+n)
</script>
</body>
</html>
Output

 Similarly, we can obtain the letter or character from a Unicode using the method
fromCharCode(). For example
<!DOCTYPE html>
<html>
<script type="text/javascript">
var n=97
var ch=String.fromCharCode(n)
document.write("<br/>The unicode "+n+" is for letter : "+ch)
</script>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 73 Client Side Technologies : JavaScript and DOM

2.18 JavaScript Debuggers


 When any syntactical error occurs in the web document then we get nothing on the
output. That is neither output nor any diagnostic message is getting displayed on
the browser window. This becomes annoying for the developer to design the
desired web page in proper direction. We can receive the error messages by making
some settings in browser window. Apart from there are some debugging techniques
using which the errors in the script can be identified and then handled.
 JavaScript is a scripting language which is very much similar to a programming
language. It supports the arrays, functions and control statements. Hence
debugging the javascript is just similar to debugging any programming language.
 The standard traditional method of debugging the JavaScript is by use of alert() to
display the values of corresponding variables. But it is a complex method of
debugging as within the loop if we write the alert statement then each time the
popup window will appear to display the corresponding messages.
 However we can make use of some other API methods for debugging the javascript.
 Another way is to use the log() function console API. Following is a simple script
that illustrates how to debug the values of the variable using the log() function of
console.
<!DOCTYPE html>
<html>
<head>
<title>Continue Statement</title>
</head>
<body>
<script type="text/javascript">
for(i=10;i>=0;i--) Here x==5 is true hence it will return
{
true along with the message.
if(i==5)
{
x=i;
console.log('x is equal to 5', x == 5);
continue;
}
console.log('i= '+i,i == 5);
document.write(i);
document.write("<br>");

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 74 Client Side Technologies : JavaScript and DOM

document.write("The number "+x+" is missing in above list" );


</script>
</body>
</html>
Just open the above code in Google Chrome. Press F12, click on the Console to get the
debugging done using the log function. Here is the snapshot for the same.
Output

Part - II : DOM

2.19 Introduction to Document Object Model (DOM)


SPPU : Dec.-19, Marks 5
 The Document Object Modeling (DOM) is for defining the standard for accessing
and manipulating HTML, XML and other scripting languages.
 It is the W3C recommendation for handling the structured documents.
 Normally the structured information is provided in XML, HTML and many other
documents.
 Hence DOM provides the standard set of programming interfaces for working with
XML and XHTML and JavaScript.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 75 Client Side Technologies : JavaScript and DOM

What is DOM ?

Document Object Model (DOM) is a set of platform independent and language neutral application
programming interface (API) which describes how to access and manipulate the information stored in
XML, HTML and JavaScript documents.

Review Question

1. Explain Document Object Model (DOM) with suitable example.


SPPU : Dec.-19, Marks 5

2.20 DOM History and Levels


 Various levels of DOM are enlisted in the following Table -
Level Description

DOM 0 This model is supported by the early browsers. This level could support JavaScript. This
version was implemented in Netscape 3.0 and Internet Explorer 3.0 browsers.

DOM 1 This version was issued in 1998 which was focused on XHTML and XML.

DOM 2 This version was issued in 2000 that could specify the style sheet. It also supports the
event model and traversal with in the documents.

DOM 3 This is the current release of DOM specification published in 2004. This version could
deal with XML with DTD and schema, document validations, document views and
formatting.

2.21 The Document Tree SPPU : April-18, May-19, Marks 5

 Basically DOM is an Application Programming Interface (API) that defines the


interface between HTML document and application program. That means, suppose
application program is written in Java and this Java program wants to access the
elements of HTML web document then it is possible by using a set of application
programming interfaces (API) which belongs to the DOM.
 The DOM contains the set of interfaces for the document tree node type. These
interfaces are similar to the Java or C++ interfaces. They have objects, properties
and methods which are useful for respected node type of the web document.
 The documents in DOM are represented using a tree like structure in which every
element is represented as a node. Hence the tree structure is also referred as DOM
tree.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 76 Client Side Technologies : JavaScript and DOM

 For example : Consider following XHTML document.


<html>
<head>
<title>This is My Web Page </title>
</head>
<body>
<h1>Hello Friends </h1>
<h2>How are you?</h2>
</h3>See you</h3>
</body>
</html>
 The DOM tree will be

Fig. 2.21.1 DOM structure for simple web document

 We can describe some basic terminologies used in DOM tree as follows -


1. Every element in the DOM tree is called node.
2. The topmost single node in the DOM tree is called the root.
3. Every child node must have a parent node.
4. The bottommost nodes that have no children are called leaf nodes.
5. The nodes that have the common parent are called siblings.

Review Question

1. What is the purpose of DOM node tree ? Draw DOM node tree for simple HTML page.
SPPU : April-18, May-19, Marks 5

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 77 Client Side Technologies : JavaScript and DOM

2.22 Modifying Element Style SPPU : May-18, Dec.-19, March-20, Marks 5

We can access or change the contents of document by using various methods. Some
commonly used properties and methods of DOM are as follows :

Methods
Method Meaning

getElementById This method is used to obtain the specific element which is specified by
some id within the script.

createElement This method is used to create an element node.

createTextNode Useful for creating a text node.

createAttribute Useful for creating attribute.

appendChild For adding a new child to specified node, this method is used.

removeChild For removing a child node of a specific node, this method is used.

getAttribute This method is useful for returning the specified attribute value.

setAttribute This method is useful for setting or changing the specified attribute to the
specified value.

Properties

Property Meaning

attributes This property is used to get the attribute nodes of the node.

parentNode This DOM property is useful for obtaining the parent node of the specific
node.

childNodes This DOM property is useful for obtaining the child nodes of the specific
node.

innerHTML It is useful for getting the text value of a node.

2.22.1 Accessing Elements using DOM


 There are several ways by which we can access the elements of the web document.
 To understand these methods of accessing we will consider one simple web
document as follows.
<html >
<head>
<title>This is My Web Page </title>
</head>
<body>
<form name=“form1”>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 78 Client Side Technologies : JavaScript and DOM

<input type=”text” name=“myinput”/>


</form>
</body>
</html>

Method 1
 Every XHTML document element is associated with some address. This address is
called DOM address.
 The document has the collection of forms and elements. Hence we can refer the text
box element as
var Dom_Obj=document.forms[0].elements[0];
 But this is not the suitable method of addressing the elements. Because if we change
the above script as

<form name=“form1”>
<input type=“button” name= “mybutton”/>
<input type=”text” name=“myinput”/>
</form>

then index reference gets changed. Hence another approach of accessing the elements
is developed.

Method 2
 We can access the desired element from the web document using JavaScript method
getElementById. The element access can be made as follows -
var Dom_Obj=document.getElementById(“myinput”);
 But if the element is in particular group, that means if there are certain elements on
the form such as radio buttons or check boxes then they normally appear in the
groups. Hence to access these elements we make use of its index. Consider the
following code sample
<form id=”Food”>
<input type=“checkbox” name=“vegetables” value=”Spinach” />Spinach
<input type=“checkbox” name=“vegetables” value=”FenuGreek” />FenuGreek
<input type=“checkbox” name=“vegetables” value=”Cabbage” />Cabbage
</form>
 For getting the values of these checkboxes we can write following code.
var Dom_obj=document.getElementById(“Food”);
for(i = 0 ; i < Dom_Obj.vegetables.length ; i++)
document.write(Dom_Obj.vegetables[i]+“<br/>”);

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 79 Client Side Technologies : JavaScript and DOM

2.22.2 Modifying Elements using DOM

Appending an element Using DOM


We can add new node in the HTML document using the DOM method appendChild
method
Following example illustrates the idea.
<!DOCTYPE html>
<html>
<body>

<div id="div1">
<p id="p1">The first sentence in HTML document.</p>
<p id="p2">The second sentence in HTML document.</p>
</div>

<script>
var pnode = document.createElement("p");
var node = document.createTextNode("This is newly added sentence in HTML document.");
pnode.appendChild(node);
var element = document.getElementById("div1");
element.appendChild(pnode);
</script>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 80 Client Side Technologies : JavaScript and DOM

Inserting an element Using DOM


We can insert a node in between the nodes by using appendChild and insertBefore
method. For example -
<!DOCTYPE html>
<html>
<body>

<div id="div1">
<p id="p1">First Sentence</p>
<p id="p2">Second Sentence</p>
</div>

<script>
var pnode = document.createElement("p");
var node = document.createTextNode("Newly Added Sentence!!!");
pnode.appendChild(node);
var element = document.getElementById("div1");
var nextnode = document.getElementById("p2");
element.insertBefore(pnode,nextnode);
</script>

</body>
</html>
Output

Removing an element Using DOM


We can remove or delete particular from HTML document using DOM’s removeChild
method.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 81 Client Side Technologies : JavaScript and DOM

Here is the illustration.


<!DOCTYPE html>
<html>
<body>

<div id="div1">
<p id="p1">First Sentence</p>
<p id="p2">Second Sentence</p>
<p id="p3">Third Sentence</p>
</div>

<script>
var parentnode = document.getElementById("div1");
var node = document.getElementById("p2");
parentnode.removeChild(node);
</script>
</body>
</html>
Output

Example 2.22.1 Write a JavaScript to display sum of two elements. Make use of appropriate
DOM method.

Solution :
<!Doctype html>
<html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 82 Client Side Technologies : JavaScript and DOM

<head>
<script type="text/javascript">
function getSum()
{
var number1=document.getElementById("number1").value;
var number2=document.getElementById("number2").value;
var num1=Number(number1);
var num2=Number(number2);
alert(num1+num2);
}
</script>
</head>
<body>
<form>
Enter Num1:<input type="text" id="number1" /><br/> <br/>
Enter Num2:<input type="text" id="number2" /><br/>
<input type="button" value="SUM" onclick="getSum()"/>
</form>
</body>
</html>

Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 83 Client Side Technologies : JavaScript and DOM

Example 2.22.2 Write a JavaScript to welcome the user by his/her name when he enters his/her
name in textbox. Make use of appropriate DOM method.
Solution :
<!Doctype html>
<html>
<head>
<script type="text/javascript">
function display()
{
var name=document.getElementsByName("user");
alert("Welcome "+name[0].value);
}
</script>
</head>
<body>
<form>
Enter Name:<input type="text" name="user" /><br/> <br/>
<input type="button" value="Greet" onclick="display()"/>
</form>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 84 Client Side Technologies : JavaScript and DOM

Review Questions

1. Write a program of your choice to demonstrate the use of properties of DOM.


SPPU : May-18, Marks 5

2. Explain the following document object properties with proper syntax.


i) document.getElementById() ii) document.getElementByClass()
iii) document.getElementByName(). SPPU : Dec.-19, March-20, Marks 5

2.23 DOM Event Handling SPPU : April-18, Dec.-18, May-19, March-20, Marks 5

 Definition of Event : Event is an activity that represents a change in the


environment. For example mouse clicks, pressing a particular key of keyboard
represent the events. Such events are called intrinsic events.
 Definition of Event Handler : Event handler is a script that gets executed in
response to these events. Thus event handler enables the web document to respond
the user activities through the browser window.
 JavaScript support this special type of programming in which events may occur and
these events get responded by executing the event handlers. This type of
programming is called event-driven programming.
 Events are specified in lowercase letters and these are case-sensitive.
 Event Registration : The process of connecting event handler to an event is called
event registration. The event handler registration can be done using two methods -
o Assigning the tag attributes
o Assigning the handler address to object properties.

Internet Programming
On occurrence of events the tag attribute must be assigned with some user defined
functionalities. This will help to execute certain action on occurrence of particular event.
Commonly used events and tag attributes are enlisted in the following table -

Events Intrinsic event Meaning Associated tags


attribute

<button>
<input>
blur onblur Losing the focus. <a>
<textarea>
<select>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 85 Client Side Technologies : JavaScript and DOM

<input>
change onchange On occurrence of some change. <textarea>
<select>
When user clicks the mouse button. <a>
click onclick
<input>

When user double clicks the mouse <a>


dblclick ondblclick button. <input>
<button>
<a>
<input>
focus onfocus When user acquires the input focus. <select>
<textarea>

When user releases the key from the Form elements such as
keyup onkeyup keyboard. input,button,text,textarea
and so on.

Form elements such as


keydown onkeydown When user presses the key down input,button,text,textarea
and so on.

Form elements such as


keypress onkeypress When user presses the key. input,button,text,textarea
and so on.

When user clicks the left mouse Form elements such as


mousedown onmousedown button. input,button,text,textarea
and so on.

When user releases the left mouse Form elements such as


mouseup onmouseup button. input,button,text,textarea
and so on.

Form elements such as


mousemove onmousemove When user moves the mouse. input,button,text,textarea
and so on.

When the user moves the mouse Form elements such as


mouseout onmouseout away from some element. input,button,text,textarea
and so on.

When the user moves the mouse Form elements such as


mouseover onmouseover away over some element. input,button,text,textarea
and so on.
load onload After getting the document loaded. <body>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 86 Client Side Technologies : JavaScript and DOM

reset onreset When the reset button is clicked. <form>

submit onsubmit When the submit button is clicked. <form>

On selection. <input>
select onselect
<textarea>

unload onunload When user exits the document. <body>

The use of these tag attributes for handling the events is illustrated by following code sample.

That means when the user clicks the button then as an event handler a user defined
function My_fun() gets called. Basically in this function user writes the instructions that
need to be executed on the button click event.

Example 2.23.1 Discuss the properties of mouse events associated with DOM2 with an
example.
Solution : Various types of mouse events associated with DOM2 are click, mousedown,
mouseup, mouseout and mouseover.

Events Intrinsic event Meaning Associated tags


attribute

When user clicks the left Form elements such as


mousedown onmousedown
mouse button. input,button,text,textarea and so on.

When user releases the Form elements such as


mouseup onmouseup
left mouse button. input,button,text,textarea and so on.

When user moves the Form elements such as


mousemove onmousemove
mouse. input,button,text,textarea and so on.

When the user moves the Form elements such as


mouseout onmouseout mouse away from some input,button,text,textarea and so on.
element.

When the user moves the Form elements such as


mouseover onmouseover mouse away over some input,button,text,textarea and so on.
element.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 87 Client Side Technologies : JavaScript and DOM

When user clicks the <a>


click onclick
mouse button. <input>

When user double clicks <a>


dblclick ondblclick the mouse button. <input>
<button>

Following is an example in which image can be dragged and dropped anywhere in the
HTML document. Accordingly the co-ordinates will be displayed.
<html>
<head>
<title> Drag and Drop Demo</title>
<script type = "text/javascript">
var X_offset, Y_offset, Item;
function Catch_function(e)

{
Registering the mouse event with
Item = e.currentTarget; the help of addEventListener
var posX = parseInt(Item.style.left); function.
var posY = parseInt(Item.style.top);
X_offset = e.clientX - posX;
Y_offset = e.clientY - posY;
document.addEventListener("mousemove", Move_function, true);
document.addEventListener("mouseup", Drop_function, true);
e.stopPropagation();
e.preventDefault();

}
function Move_function(e)
{
Item.style.left = (e.clientX - X_offset) + "px";
Item.style.top = (e.clientY - Y_offset) + "px";
e.stopPropagation();
}
function Drop_function(e)
{
document.removeEventListener("mouseup", Drop_function, true);
document.removeEventListener("mousemove", Move_function, true);
e.stopPropagation();
}
</script>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 88 Client Side Technologies : JavaScript and DOM

</head>
<body>
<h3>
Click on image below-drag it, move it and then drop anywhere!!!
<br /><br />
<img src="lamp1.jpg"
style = "position: absolute;
top: 100px;
left: 100px;
border:2px solid;"
onmousedown = "Catch_function(event);" />
</h3>
</body>
</html>
Output

2.23.1 Handling Events from the Body Elements


To understand how events works in JavaScript let us put some Form components on
the JavaScript. The onload event gets activated as soon as the web page gets loaded in the
browser’s window. Following script along with its output illustrate the onload tag
attribute.

JavaScript[OnloadDemo.html]

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"


"http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Demo of onload Tag Attibute</title>
<script type="text/javascript">
function my_fun()
{

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 89 Client Side Technologies : JavaScript and DOM

//This message will be displayed on page loading

alert("Welcome");
} When web document gets
</script> loaded on the browser window
</head>
then my_fun() will be called
<body onload="my_fun()">
</body>
</html>
Output

Example 2.23.2 Write an HTML page and also provide a JavaScript for accepting a user ID and
password from the user to ensure that input is not empty.
SPPU : April-18, In Sem, Marks 5
Solution :
<!DOCTYPE html>
<html>
<head>
<script type="text/javascript">
function my_fun()
{
var mypwd=document.getElementById("pwd");

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 90 Client Side Technologies : JavaScript and DOM

var myuname=document.getElementById("uname");
if(myuname.value=="")
{
alert("You have not entered the name");
myuname.focus();
return false;
}
if(mypwd.value=="")
{
alert("You have not entered the password");
mypwd.focus();
return false;
}
else
{
alert("Congratulations!!!");
return true;
}
}
</script>
</head>
<body>
<center>
<form id="form1">
<label> Enter your name
<input type="text" value="" id="uname" />
</label>
<label> Enter your password
<input type="password" value="" id="pwd" />
</label>
<br/><br/>
<input type="submit" onsubmit="my_fun();"/>
<input type="reset" value="Reset" name="reset"/><br/>
</form>
</center>
</body>
</html>

Example 2.23.3 Explain with example how to access values of textbox of form using JavaScript ?
SPPU : March-20, Marks 5
Solution :
<!DOCTYPE html>
<html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 91 Client Side Technologies : JavaScript and DOM

<head>
<script type = "text/javascript">
function getNum()
{
var num = document.getElementById("Data").value;
var a = Number(num);
alert(a);
}
</script>
</head>
<body>
<form>
Enter some Number: <input type="text" id="Data"/><br/><br/>
<input type ="button" value="Click Me" onclick='getNum()'/>
</form>
</body>
</html>

Review Question

1. Write a program of your choice to demonstrate DOM.


SPPU : Dec.-18, May-19, March-20, Marks 5

2.24 Form Validation in JavaScript SPPU : Dec.-18, Marks 5

 Various control objects are placed on the form. These control objects are called
widgets.
 These widgets used in JavaScript are - Textbox, Push button, Radio button,
Checkbox and so on.
 In JavaScript the validation of these widgets is an important task.
 Let us understand the validation of form elements with the help of examples -

Example 2.24.1 Write a JavaScript for password verification.

Solution :
<!DOCTYPE html>
<html>
<head>
<title>Demo of onlclick Tag Attibute</title>
<script type="text/javascript">
function my_fun()
{
var mypwd=document.getElementById("pwd");

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 92 Client Side Technologies : JavaScript and DOM

var my_re_pwd=document.getElementById("re_pwd");
if(mypwd.value=="")
{
alert("You have not entered the password");
mypwd.focus();
return false;
}
if(mypwd.value!=my_re_pwd.value)
{
alert("Password is not verified, Re-enter both the passwords");
mypwd.focus();
mypwd.select();
return false;
}
else
{
alert("Congratulations!!!");
return true;
}
}
</script>
</head>
<body>
<center>
<form id="form1">
<label> Enter your password
<input type="password" value="" id="pwd" />
</label>
<br/><br/>
<label> Re-Enter the password
<input type="password" value="" id="re_pwd" onblur="my_fun();"/>
</label><br/>
<input type="submit" value="Submit" name="submit" onsubmit="my_fun();"/>
<input type="reset" value="Reset" name="reset"/><br/>
</form>
</center>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 93 Client Side Technologies : JavaScript and DOM

Output (Run1)

Output (Run2)

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 94 Client Side Technologies : JavaScript and DOM

Output(Run3)

Example 2.24.2 Write JavaScript to validate a for consisting of Name, Age, Address, EmailID,
hobby (check box), Gender(radio box), country(Drop down menu).

Solution : ApplicationForm.html
<html>
<head>
<title>The Student Registration Form</title>
<script type=text/javascript>
function validate()
{

var i;
var name_str=document.my_form.name;
var phoneID=document.my_form.ph_txt;
var ph_str=document.my_form.ph_txt.value;
var str=document.my_form.Email_txt.value;
if((name_str.value==null)||(name_str.value==""))
{
alert("Enter some name") Validating Name
return false
}
if(document.my_form.Age_txt.value=="")// validating age
{
alert("Enter Some Age")
return false
}

if((document.my_form.Age_txt.value<"5")&&(document.my_form.Age_txt.value>"21"))

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 95 Client Side Technologies : JavaScript and DOM

{
alert("Invalid Age")
return false
}

if(ph_str.length<1 ||ph_str.length>11)
{
alert("Invalid length of Phone Number")
return false
} Validating Phone Number
for (i = 0; i < ph_str.length; i++)
{
var ch = ph_str.charAt(i);
if (((ch < "0") || (ch > "9"))){
alert("Invalid Phone Number")

phoneID.focus()
return false
}
}

var index_at=str.indexOf("@")
var len=str.length
var index_dot=str.indexOf(".")
var emailID=document.my_form.Email_txt
if ((emailID.value==null)||(emailID.value==""))
{ Validating Email ID
alert("Please Enter your Email ID")
emailID.focus()
return false
}
if (str.indexOf("@")==-1)
{
alert("Invalid E-mail ID")
return false
}
if (str.indexOf(".")==-1 || str.indexOf(".")==0
|| str.indexOf(".")==index_at)
{
alert("Invalid E-mail ID")
return false Validating Email ID
}

if (str.indexOf("@",(index_at+1))!=-1)
{
alert("Invalid E-mail ID")
return false
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 96 Client Side Technologies : JavaScript and DOM

if (str.indexOf(" ")!=-1)

{
alert("Invalid E-mail ID")
return false
}
if (!document.my_form.group1[0].checked && !document.my_form.group1[0].checked)
{
alert("Please Select Sex");
return false;
}
if (!document.my_form.group1[0].checked && !document.my_form.group1[0].checked)
{
alert("Please Select Sex");
return false;
}
return true

}
</script>
</head>
<body bgcolor=aqua>
<center><h3>Application Form</h3></center>
<form name=my_form onsubmit=validate()>
<strong>Name: </strong>
<input type=text name=name><br/>

<strong>Age: </strong>
<input type=text name=Age_txt><br/>

<strong>Phone No:</strong>
<input type=text name=ph_txt><br/>
<strong>Email: </strong>
<input type=text name=Email_txt><br/><br/>
<strong>Sex: </strong>
<input type="radio" name="group1" value="Male">Male
<input type="radio" name="group1" value="Female">Female<br/><br/><br/>
<strong>Hoby: </strong>
<input type="checkbox" name ="option1" value="Singing">Singing<br/>
<input type="checkbox" name ="option1" value="Reading">Reading<br/>
<input type="checkbox" name ="option1" value="T.V.">Watching T.V<br/>
<br/><br/>
<strong>Country:</strong>
<select name="My_Menu">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 97 Client Side Technologies : JavaScript and DOM

<option value="India">India</option>
<option value="China">China</option>
<option value="Shrilanka">Shrilanka</option>
</select>
<center>
<input type=submit value=Submit></br>
</center>

</body>
</html>
Output

Example 2.24.3 Design a HTML form for validation the users with fields user name and
password and ok button which should receive the input from the user and responses as
authorized or invalid user name or invalid password.
Solution :
<head>
<title>HTML FORM</title>
<script type=text/javascript>
function validate()
{
var user=document.form1.username;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 98 Client Side Technologies : JavaScript and DOM

var pass=document.form1.password;
if((user.value==null)||(user.value==""))
{
alert("Enter some user name");
}
if((pass.value==null)||(pass.value==""))
{
alert("Enter some password");

}
if(user.value=="admin")
{
alert("Valid user name");

}
if(pass.value=="password")
{
alert("Valid password");
}
else
alert("Invalid username/password");
}
</script>
</head>
<body>
<form id="form1" name="form1" onsubmit=validate()>
<table width="510" border="0" align="center">
<tr> <td>Username:</td>
<td><input type="text" name="username"/></td>
</tr>
<tr> <td>Password</td>
<td><input type="password" name="password"/></td>
</tr>
<tr>
<td>&nbsp;</td>
<td><input type="submit" name="button" value="OK" /></td>
</tr>
</table>
</form>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 99 Client Side Technologies : JavaScript and DOM

Example 2.24.4 Write a Javascript to validate radio button, operator field and check box.

Solution : JavaScript Program


<html>
<head>
<script LANGUAGE="JavaScript">

function ValidateForm(form)
{

if ((form.gender[0].checked == false ) && ( form.gender[1].checked == false ))


{ alert ( "Please choose your Gender: Male or Female" );
return false;
}
if ((form.status[0].checked == false ) && ( form.status[1].checked == false ))
{ alert ( "Please choose your choice: AC or non AC" );
return false;
}
if ( form.course.selectedIndex == 0 )
{ alert ( "Please select Some Course." );
return false;
}
return true;
}
</script>
</head>
<body>
<br>
<form>
Your Gender: <input type="radio" name="gender" value="Male"> Male
<input type="radio" name="gender" value="Female"> Female
<br/>
Choice: <input type="checkbox" name="status">AC
<input type="checkbox" name="status"> Non AC
<br/>
Course:
<select name="course">
<option value="">Select an Option:</option>
<option value="Computer">Computer</option>
<option value="Mechanical">Mechanical</option>
<option value="E&Tc">E&Tc</option>
</select>
<br/><br/>
<input type="button" name="SubmitButton" value="Submit"

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 100 Client Side Technologies : JavaScript and DOM

onClick="ValidateForm(this.form)">
<input type="reset" value="Reset">
</form>
</body>
</html>

Example 2.24.5 Design a form to accept workshop registration details from participants and
validate any five fields using JavaScript ? (Assume suitable structure)
SPPU : Dec.-18, Marks 5
Solution :
<html>
<head>
<title>The Workshop Registration Form</title>
<script type=text/javascript>
function validate()
{

var i;
var name_str=document.my_form.name;
var phoneID=document.my_form.ph_txt;
var ph_str=document.my_form.ph_txt.value;
var str=document.my_form.Email_txt.value;
if((name_str.value==null)||(name_str.value==""))//validating name
{
alert("Enter some name")
return false
}
if(document.my_form.Age_txt.value=="")// validating age
{
alert("Enter Some Age")
return false
}

if((document.my_form.Age_txt.value<"5")&&(document.my_form.Age_txt.value>"21"))
{
alert("Invalid Age")
return false
}

if(ph_str.length<1 ||ph_str.length>11) //validating phone number


{
alert("Invalid length of Phone Number")
return false

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 101 Client Side Technologies : JavaScript and DOM

}
for (i = 0; i < ph_str.length; i++)
{
var ch = ph_str.charAt(i);
if (((ch < "0") || (ch > "9"))){
alert("Invalid Phone Number")

phoneID.focus()
return false
}
}

var index_at=str.indexOf("@")
var len=str.length
var index_dot=str.indexOf(".")
var emailID=document.my_form.Email_txt
if ((emailID.value==null)||(emailID.value==""))
{
alert("Please Enter your Email ID")
emailID.focus()
return false
}
if (str.indexOf("@")==-1) //validating email ID
{
alert("Invalid E-mail ID")
return false
}
if (str.indexOf(".")==-1 || str.indexOf(".")==0
|| str.indexOf(".")==index_at)
{
alert("Invalid E-mail ID")
return false
}

if (str.indexOf("@",(index_at+1))!=-1)
{
alert("Invalid E-mail ID")
return false
}
if (str.indexOf(" ")!=-1)

{
alert("Invalid E-mail ID")

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 102 Client Side Technologies : JavaScript and DOM

return false
}
if (!document.my_form.group1[0].checked && !document.my_form.group1[0].checked)
{
alert("Please Select Sex");
return false;
}
if (!document.my_form.group1[0].checked && !document.my_form.group1[0].checked)
{
alert("Please Select Sex");
return false;
}
return true

}
</script>
</head>
<body bgcolor=aqua>
<center><h3>Registration Form</h3></center>
<form name=my_form onsubmit=validate()>
<strong>Name: </strong>
<input type=text name=name><br/>

<strong>Age: </strong>
<input type=text name=Age_txt><br/>

<strong>Phone No:</strong>
<input type=text name=ph_txt><br/>
<strong>Email: </strong>
<input type=text name=Email_txt><br/><br/>
<strong>Sex: </strong>
<input type="radio" name="group1" value="Male">Male
<input type="radio" name="group1" value="Female">Female<br/><br/><br/>
<strong>Hoby: </strong>
<input type="checkbox" name ="option1" value="Singing">Singing<br/>
<input type="checkbox" name ="option1" value="Reading">Reading<br/>
<input type="checkbox" name ="option1" value="T.V.">Watching T.V<br/>
<br/><br/>
<strong>Country:</strong>
<select name="My_Menu">
<option value="India">India</option>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 103 Client Side Technologies : JavaScript and DOM

<option value="China">China</option>
<option value="Shrilanka">Shrilanka</option>
</select>
<center>
<input type=submit value=Submit></br>
</center>
</body>
</html>

Part - III : jQuery

2.25 jQuery SPPU : May-19, Marks 5

2.25.1 Introduction to jQuery


 JQuery is a fast and concise library created by John Rosig in 2006. The moto of this
web document is Write less do more. This scripting is very easy to learn. The
JQuery is actually a Javascript library.
 JQuery runs almost all the browsers.
 It adds up many advanced, cross-browser functions to standard
Advantages of using jQuery

1. It works on almost all the platforms - This is called as cross platform


compatibility.
2. It has large and advanced set of functionalities.
3. It is lightweight about 19 kB in size.
4. It supports AJAX technology.
5. It offers event handling to capture a wide variety of events such as button clicks,
mouse move and so on.
6. It supports plenty of built in animation effects to make the web document live
and eye catching.
7. It supports DOM manipulations. That means it is easy to select DOM elements,
traverse them and modifying their content using jQuery.
Disadvantages of using jQuery

1. Without the use of jquery-1.10.2.min.js either locally or from the internet we can
not make use of the library functions of jQuery.
2. The jQuery coding must be done in support of JavaScript, AJAX, ASP, PHP and
so on to get the advantage of its library functionality.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 104 Client Side Technologies : JavaScript and DOM

2.25.2 Basic Syntax


Basically the jQuery code is written in following form.
$(selector).action()
The $ sign denotes the access to jQuery.
The (selector) finds the HTML elements such as <p>, <div>, <h1>,<form><button> and
so on.
The action() denotes the actions to be performed on selector elements.
Document ready event : All the jQuery methods are written in document ready event.

2.25.3 Loading jQuery


 The load() method loads data from a server and puts the returned data into the
selected element.
 Syntax
$(selector).load()
 Example

jQuery Document[LoadDemo.html]
<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
<script>
$(document).ready(function()
{
$("img").load();
});
</script>
</head>
<body>
<h2> Loading Image</h2>
<img src="img1.jpg" alt="flower">
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 105 Client Side Technologies : JavaScript and DOM

Output

We can load some external file using the load function for that purpose we need to pass
URL to the load function.
<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script>
$(document).ready(function(){
$("button").click(function(){
$("#div1").load("input.html");
});
});
</script>
</head>
<body>
<div id="div1"><h2>Loading File</h2></div>
<button>Click to load file</button>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 106 Client Side Technologies : JavaScript and DOM

2.25.4 Selecting Elements

1. The element selector


As we know hat, the selectors can be the basic HTML elements such as<p>, <div>, <h1>,
<form><button> and so on.
Let us understand jQuery coding with the help of simple example in which the HTML
element <p> is used. Following code can be written using a simple text editor like
notepad. Save the code with any suitable file name and extension .html

SelectorDemo.html
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js">
</script>
<script>
$(document).ready(function()
{
$("button").click(
function()
{
$("p").hide();
}
);
});
</script>
</head>

<body>
<div>This statement is remains on browser</div>
<p>This statement will disappear</p>
<button>Click</button>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 107 Client Side Technologies : JavaScript and DOM

Output

On clicking the button we will get

Script Explanation :
In the above code, within the ready function the jQuery code is written.
For the button element selector the action is click. This action invokes the <p> element
and the action associated with this element is hide. This means that when user clicks the
button the text written within the <p> </p> will be hidden or disappeared.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 108 Client Side Technologies : JavaScript and DOM

2. Use of * as a selector
The * means all. If we include selector as * then the corresponding action will be
associated with all the HTML elements. The sample code for demonstrating this action is
as follows -
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js">
</script>
<script>
$(document).ready(function()
{
$("button").click(
function()
{
$("*").hide();
}
);
});
</script>
</head>

<body>
<h1> This is a header </h1>
<div>This second statement</div>
<p>This is another statement</p>

<button>Click</button>
</body>
</html>
Output
On clicking the click button all the contents of the web page will be hidden and black document
will be displayed.

3. The id selector
The id can be associated with the HTML element. In the following example we have
used <div> element to which the id named myid is associated. On button click event the
function is invoked to hide the sentence written using the <div id=”myid”>.
To find the element with particular id write # and then name of the id.
<html>
<head>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 109 Client Side Technologies : JavaScript and DOM

<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js">
</script>
<script>
$(document).ready(function(){
$("button").click(function(){
$("#myid").hide();
});
});
</script>
</head>
<body>
<div>This is first line</div>
<p>This is another line for paragraph</p>
<div id="myid">This sentence will be hidden on clicking the button</div>
<button>Click to Hide</button>
</body>
</html>
Output

On clicking the Hide button we get following effect

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 110 Client Side Technologies : JavaScript and DOM

4. The .class selector


The class selector is also used to find the specific html element. The element is written
along with class=”classname” and to find this element write a dot character followed by
classname. Following example illustrates this
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js">
</script>
<script>
$(document).ready(function(){
$("button").click(function(){
$(".myclass").hide();
});
});
</script>
</head>
<body>
<div>This is first line</div>
<p>This is another line for paragraph</p>
<div class="myclass">This sentence will be hidden on clicking the button</div>
<button>Click to Hide</button>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 111 Client Side Technologies : JavaScript and DOM

Output

Note : The output will be the same as above

5. The href selector


The href element is used along with the anchor tag in order to introduce hyperlink in
the web document. We can navigator to the desired web page using such hyperlinks. In
the following program on button click, the hyperlink can be hidden.
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js">
</script>
<script>
$(document).ready(function(){
$("button").click(function(){
$("[href]").hide();
});
});
</script>
</head>

<body>
<h3>This is a heading</h3>
<div>This is First paragraph.</div>
<div>
<a href="https://www.vtubooks.com">For Technical Books, Click here</a>
</div>
<button>Click to Hide</button>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 112 Client Side Technologies : JavaScript and DOM

6. The tr selector
The element tr is used to define the rows of the table. We can denote this selector along
with the css style. It is demonstrated by following web document
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js">
</script>
<script>
$(document).ready(function(){
$("tr:even").css("background-color","grey");
});
</script>
</head>

<body>
<h3>Employee Database</h3>
<table border="1">
<tr>
<th>Name</th>
<th>Department</th>
<th>Address</th>
</tr>
<tr>
<td>Archana</td>
<td>Marketing</td>
<td>Shivaji Nagar</td>
</tr>

<tr>
<td>Sujata</td>
<td>Accounts</td>
<td>M.J.Road</td>
</tr>
<tr>
<td>Amit</td>
<td>Purchase</td>
<td>Shastri Road</td>
</tr>

<tr>
<td>Nalini</td>
<td>H.R</td>
<td>ChandaniChowk</td>
</tr>

</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 113 Client Side Technologies : JavaScript and DOM

Output

2.25.5 Changing Styles


To change the style the .css() function is used. The syntax is
$(selector).css({"css property name":"css property value"});

For example -

jQuery Document[changeStyle.html]

<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js">
</script>
<script>
$(document).ready(function(){
$("button").click(function(){
$("div").css("background-color", "red");
});
});
</script>
</head>
<body>
<div style="background-color:blue">This line is blue and will be changed to red</div><br/>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 114 Client Side Technologies : JavaScript and DOM

<div style="background-color:yellow">This will be another red line</div>


<button>Change Style</button>
</body>
</html>
Output

2.25.6 Creating Elements


 The jQuery after() method inserts content AFTER the selected HTML elements. The
syntax is
$(Selector).after(“Some Text”);
 The jQuery before() method inserts content BEFORE the selected HTML elements.
The syntax is
$(Selector).before(“Some Text”);

Example

jQuery Document[InsertElement.html]
<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 115 Client Side Technologies : JavaScript and DOM

$(document).ready(function(){
$("#button1").click(function(){
$("ol").before("<b>Element:Before</b>");
});
$("#button2").click(function(){
$("ol").after("<b>Element: After</b>");
});
});
</script>
</head>
<body>
<ol>
<li>item#1</li>
<li>item#2</li>
<li>item#3</li>
</ol>
<br/><br/>
<button id="button1">Insert before</button>
<button id="button2">Insert after</button>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 116 Client Side Technologies : JavaScript and DOM

2.25.7 Appending Elements


We can add new element at the end of existing elements using the append function.
The appending of elements can be well understood by following example.
jQuery Document[AddElement.html]
<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script>
$(document).ready(function(){
$("#button").click(function(){
$("ol").append("<li>New item</li>");
});
});
</script>
</head>
<body>
<ol>
<li>item#1</li>
<li>item#2</li>
<li>item#3</li>
</ol>
<button id="button">Add List Element</button>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 117 Client Side Technologies : JavaScript and DOM

2.25.8 Removing Elements


To remove elements from the DOM there are two commonly used methods - remove
and empty jQuery .empty() method removes all the child element of the matched element
where remove() method removes set of matched elements from DOM.
$( ".content" ).empty();

$( ".content" ).remove();
Example of .remove()
<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script>
$(document).ready(function(){
$("button").click(function(){
$("#tbl").remove();
});
});
</script>
</head>
<body>
<table id="tbl" border='1'>
<tr><td> First Row</td> </tr>
<tr><td> Second Row </td></tr>
</table>
<button>Remove Element</button>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 118 Client Side Technologies : JavaScript and DOM

Example of .empty()
<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script>
$(document).ready(function(){
$("button").click(function(){
$("#tbl tr td").empty();
});
});
</script>
</head>
<body>
<table id="tbl" border='1'>
<tr><td> First Row</td> </tr>
<tr><td> Second Row </td></tr>
</table>
<button>Remove Element</button>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 119 Client Side Technologies : JavaScript and DOM

Output

Review Question

1. When to use jQuery ? What are the advantages of using jQuery over JavaScript.
SPPU : May-19, Marks 5

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 120 Client Side Technologies : JavaScript and DOM

Part - IV : Angular JS

2.26 Overview of Angular JS SPPU : May-18, 19, Dec.-18, 19, Marks 8

 Angular JS is a powerful JavaScript framework.


 It is an open source front-end enabled web application framework.
 It is licensed under Apache license version 2.0.
 It extends HTML DOM with additional attributes. It is more responsive to user
actions.

Advantages
Following are the advantages of Angular JS.
1. Built by Google Engineers : The Angular JS is maintained by dedicated Google
Engineers. That means - there is huge community for development and
enhancement.
2. MVC Support - It is based on Model View Controller (MVC) architecture which
provides separation of model, view and controller components.
3. Intuitive - It is more intuitive as it makes use of HTML as a declarative language.
Moreover, it is less brittle for reorganizing.
4. Comprehensive : AngularJS is a comprehensive solution for rapid front-end
development. It does not need any other plugins or frameworks.
5. Rich Features : There is a wide range of features supported by Angular JS such
as Data binding, dependency injection, enterprise level testing and so on.
6. Unit Testing : The Angular JS code is unit testable.
7. Reusable Code : Angular JS support for using the reusable components.
8. Less Code : It support for less code and more functionality.

Disadvantages
1. As Angular JS is based on JavaScript framework, it is not secure.
2. There are multiple ways to do the same thing with AngularJS. Sometimes, it can
be hard for novices to say which way is better for a task.

Features of Angular JS
There are core features Angular JS that are widely used by web developers. These are -
1. Data Binding : It allows the automatic synchronization between model and view
components.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 121 Client Side Technologies : JavaScript and DOM

2. Scope : There are some objects from model that can be correlated to controller
and view.
3. Controller : These are basically JavaScript functions that are bound to particular
scope.
4. Directives : The directives is designed to give HTML new functionality.
5. Filters : This feature allows to select subset from array of items.
6. Routing : This feature allows to switch between multiple views.
7. Services : There is a support for many built in services for Angular JS
8. Dependency Injection : It is a software design pattern that helps the developer
to develop and understand the application easily.

2.26.1 MVC with Angular JS


Concept of MVC
The MVC stands for Model, view and controller. It is a pattern for the architectural
framework. It consists of three parts -
1. Model : This part of the architecture is responsible for managing the application
data. This module responds to the request made from view. The model gives
instructions to controller to update when the response is made.
2. View : This part takes care of the presentation of data. The data is presented in
desired format with the help of view. This is a script based system using JSP,
ASP, PHP and so on.
3. Controller : The controller receives input, validates it, and then performs
business operations that modify the state of the data model. The controller
basically responds to user request and performs interaction with model. Refer
Fig. 2.26.1.

Fig. 2.26.1 MVC architecture

MVC in Angular JS
 Modules in AngularJS serve as containers to help you organize your application
into logical units.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 122 Client Side Technologies : JavaScript and DOM

 Modules tell AngularJS how an application is configured.


 In angular JS the Module are represented using the directive <ng-app> and module
name.
 The scope object binds the view with controller.
 In AngularJS it is possible to have multiple views for single page application.
 The ng-view and ng-template and ng-route directives support the concept of views.
 The use of controller in AngularJS is to control the flow of data. The ng-controller
directive is used for this purpose. Refer Fig. 2.26.2.

Fig. 2.26.2 MVC with angular JS

2.26.2 Directives
 In Angular JS, the capacity of HTML is extended using the ng-directives.
 The directives are specified with ng prefix.
 The three commonly used ng-directives are
1. ng-app : This directive defines an AngularJS application.
2. ng-model : This directive binds the value of HTML controls to application data.
These controls can be input, select, textarea and so on.
3. ng-bind : This directive binds application data to HTML view.

Let us now learn and understand how to develop Angular JS application.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 123 Client Side Technologies : JavaScript and DOM

Step 1 : Create an Angular JS code as follows in a Notepad. Save it using the extension
.htm or .html

AngularJS Document[FirstApp.html]
<html>
<head>
<title>My First AngularJS Application</title>
<script src =
"https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
</head>
<body>
<h1>AngularJS Application</h1>
<div ng-app = "">
<p>Enter your Name: <input type = "text" ng-model = "name"></p>
<p>Welcome <span ng-bind = "name"></span></p>
</div>
</body>
</html>
Output

Script Explanation :
1. The AngularJS script is written within <html> tags. The AngualarJS is based on
JavaScript framework. The framework for AngularJS is loaded using the <script>
tag. It is as follows -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 124 Client Side Technologies : JavaScript and DOM

<script src =
"https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
2. Defining np-app directive : The np-app directive is defined in above script as
follows -
<div ng-app = "">


</div>
3. Defining np-model directive : The textbox control is modeled using np-model
directive
<p>Enter your Name: <input type = "text" ng-model = "name"></p>
4. Defining np-bind : We can bind the value entered in the textbox with name
using np-bind directive.
<p>Welcome <span ng-bind = "name"></span></p>
Hence, we can see on the output screenshot, that whatever name entered by the user
gets bound with the Welcome message.
The above output can be viewed by opening any popular web browser and by
entering the URL of corresponding AngularJS script.
Various Directives supported by AngularJS are -
1. ng-app 2. ng-init
3. ng-model 4. ng-repeat
Let us discuss these directives with suitable scripting examples
1. ng-app Directive :
This directive starts the AngularJS application. It basically defines the root element. It
initializes the application automatically when the web page containing the AngularJS
code is loaded. For example -
<div ng-app="">

</div>
2. ng-init Directive :
The ng-init directive is used for initialization of AngularJS data.
For example :
DirectiveDemo1.html
<html>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>
<div ng-app="" ng-init="msg='I love my country!!!'">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 125 Client Side Technologies : JavaScript and DOM

<h3>{{msg}}</h3>
</div>
</body>
</html>
Output

3. ng-model : The ng-model directive binds the value of HTML control to


application data. These controls can be input, select, textarea and so on. For
example -

AngularJS Document[FirstApp.html]
<html>
<head>
<title>My First AngularJS Application</title>
<script src =
"https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
</head>
<body>
<h1>AngularJS Application</h1>
<div ng-app = "">
<p>Enter your Name: <input type = "text" ng-model = "name"></p>
<p>Welcome <span ng-bind = "name"></span></p>
</div>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 126 Client Side Technologies : JavaScript and DOM

Output

Name in text box are


represented using
ng-model directive
and is linked with
application data
using ng-bind

4. ng-repeat : The ng-repeat element directive repeats the HTML element.

AngularJS Document [DirectiveRepeat.html]


<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>
<div ng-app="" ng-init="nums=[10,20,30,40,50]">
<p>The elements are -</p>
<ul>
<li ng-repeat="i in nums">
{{ i }}
</li>
</ul>
</div>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 127 Client Side Technologies : JavaScript and DOM

Output

2.26.3 Expression
 In AngularJS the expressions are written within {{ }}. For example - {{2 + 3}} is
expression.
 AngularJS binds data to HTML using Expressions.
 AngularJS solves the expression and return the result of evaluation.
 The expressions in AngularJS are just similar to JavaScript expressions. The
expression contains literals, variables and operators.

AngularJS Document[ExpressionDemo.html]
<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>
<div ng-app="">
<h4>Expression Demo</h4>
<p> Addition of 10 and 20 = {{ 10+20 }}</p>
</div>

</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 128 Client Side Technologies : JavaScript and DOM

Output

Now from above code if we remove ng-app directive then the expression won't be
evaluated. For instance -

<body>
<div>
<h4>Expression Demo</h4>
<p> Addition of 10 and 20 = {{ 10+20 }}</p>
</div>
</body>
</html>

We can assign the values to variables and then evaluate an expression. This
initialization of variable can be using ng-init. For example -
<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>
<div ng-app="" ng-init="a=10;b=20">
<h4>Expression Demo</h4>
<p> Addition = {{ a+b }}</p>
<p> Multiplication = {{ a*b }}</p>
</div>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 129 Client Side Technologies : JavaScript and DOM

Output
The output will be displayed as 30 and 200
Similarly we can assign strings to variables and can display them. For example

AngularJS Document[ExpressionDemo1.html]
<html>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>
<h1>Expression Demo</h1>

<div ng-app = "" ng-init = "names = {first:'AAA',second:'BBB',third:'CCC'}">


<p>First Two names are: {{names.first + " , " + names.second}}</p>
</div>
</body>
</html>
Output

2.26.4 Controllers
 The use of controller in AngularJS is to control the flow of data. The ng-controller
directive is used for this purpose.
 The controller is JavaScript object containing properties and functions.
 Each controller accept $scope as a parameter which refers to the application/module
that controller is to control.
 We can use controller with properties, methods and external files.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 130 Client Side Technologies : JavaScript and DOM

Controller with Properties


The controller is defined with properties. These properties are then assigned with
some values. It is illustrated by following example
AngularJS Document[ControllerDemo.html]
<!DOCTYPE html>
<html>
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>

<div ng-app="MyApp" ng-controller="MyController">

User: <input type="text" ng-model="user"><br/><br/>


City: <input type="text" ng-model="city"><br/>
<br/>
User {{user + " "}} lives in city {{ city + "!!!"}}

</div>

<script>
var app = angular.module('MyApp', []);
app.controller('MyController', function($scope)
{
$scope.user = "AAA";
$scope.city = "Pune"; Properties
});
</script>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 131 Client Side Technologies : JavaScript and DOM

Script Explanation :
In above script,
1. We have used two directives div-app and div-controller which are defined with
some suitable attribute name. In above case div-app attribute is "MyApp" and
div-controller attribute is "MyController".
2. The MyController function is basically a JavaScript function and AngularJS will
invoke the controller using $scope object.
3. The controller creates two properties namely - 'user' and 'city'. Using $scope
object these properties are assigned with values 'AAA' and 'Pune'
4. The ng-model binds these input fields to the controller properties.

Controller with Method


In above script the controller has two properties. But we can define a method for the
controller. Following example illustrates how to use controller method.

AngularJS Document[ControllerMethodDemo.html]
<!DOCTYPE html>
<html>
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>
<div ng-app="MyApp" ng-controller="MyController">
User: <input type="text" ng-model="user"><br/><br/>
City: <input type="text" ng-model="city"><br/>
<br/>
Address: {{address_function()}}
</div>
<script>

var app = angular.module('MyApp', []);


app.controller('MyController', function($scope) {
$scope.user = "AAA";
$scope.city = "Pune"; Properties
$scope.address_function=function() { Method definition
return $scope.user +" lives in city "+$scope.city;
};
});
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 132 Client Side Technologies : JavaScript and DOM

Output

Script Explanation :
In above script
1. The two properties user and city are defined. Along with them, a method named
Address_function() is invoked.
2. This function returns the string containing values to the properties.
3. This function is then bounded to HTML.

Controller with external File

We can write and save the controller in some external file. This file can be then
invoked in the HTML document. Here is the illustration.
Step 1 : Create a file in Notepad. Name it with extension .js.

External File[MyController.js]
angular.module('MyApp', []).controller('MyController', function($scope) {
$scope.user = "AAA";
$scope.city = "Pune";
$scope.address_function=function() {
return $scope.user+" "+$scope.city;
}
});
Step 2 : Create a HTML document invoking the external js file created in above step.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 133 Client Side Technologies : JavaScript and DOM

HTML Document[ControllerFileDemo.html]
<!DOCTYPE html>
<html>
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>

<div ng-app="MyApp" ng-controller="MyController">

User: <input type="text" ng-model="user"><br/><br/>


City: <input type="text" ng-model="city"><br/>
<br/>
Address:{{user + " lives in " + city}}
</div>
<script src="MyController.js"> </script>
</body>
</html>
Output

2.26.5 Filters
 Filters are used to modify the data.
 These are used along with expressions or directives using pipe (|) character.
 Commonly used filters are -
Filter Purpose

uppercase Converts the text to uppercase.

lowercase Converts the text to lower case.

currency Converts the number into currency format.

orderBy Arranges the elements of the array based on criteria.

filter Selects the subset of items from array.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 134 Client Side Technologies : JavaScript and DOM

1. Example Demonstrating uppercase filter


AngularJS Document[FilterDemo1.html]
<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>

<div ng-app="MyApp" ng-controller="MyController">


<p>The name is {{ user | uppercase }}</p>

</div>

<script>
angular.module('MyApp', []).controller('MyController', function($scope) {
$scope.user = "aaa"
});
</script>
</body>
</html>
Output

2. Example Demonstrating lowercase Filter


AngularJS Document[FilterDemo2.html]
<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>

<div ng-app="MyApp" ng-controller="MyController">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 135 Client Side Technologies : JavaScript and DOM

<p>The name is {{ user | lowercase }}</p>

</div>

<script>
angular.module('MyApp', []).controller('MyController', function($scope) {
$scope.user = "AAA"
});
</script>

</body>
</html>
Output

3. Example Demonstrating currency Filter


AngularJS Document[FilterDemo3.html]
<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>

<div ng-app="MyApp" ng-controller="MyController">


<p>The amount is {{ amount | currency }}</p>

</div>

<script>
angular.module('MyApp', []).controller('MyController', function($scope) {
$scope.amount = 100
});

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 136 Client Side Technologies : JavaScript and DOM

</script>

</body>
</html>
Output

4. Example Demonstrating filter Filter


AngularJS Document[FilterDemo4.html]
<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>

<div ng-app="MyApp" ng-controller="MyController">


<p>The cities having character 'u' are </p>
<ul>
<li ng-repeat="cty in city | filter:'u'">
{{cty}}
</li>
</ul>
</div>

<script>
angular.module('MyApp', []).controller('MyController', function($scope) {
$scope.city = [
'Pune',
'Mumbai',
'Delhi',
'Chennai',
'Surat',

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 137 Client Side Technologies : JavaScript and DOM

'Kolkatta',
'Dehradun'
];

});
</script>

</body>
</html>
Output

The above code can be modified in such a way that user is allowed to type a character
in textbox. The list of cities containing the character typed by the user can be displayed.
AngularJS Document[FilterDemo4.html]
<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>

<div ng-app="MyApp" ng-controller="MyController">


<p>The cities having characters typed in textbox are -</p>
<p><input type="text" ng-model="ch"></p>
<ul>
<li ng-repeat="cty in city | filter:ch">
{{cty}}
</li>
</ul>
</div>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 138 Client Side Technologies : JavaScript and DOM

<script>
angular.module('MyApp', []).controller('MyController', function($scope) {
$scope.city = [
'Pune',
'Mumbai',
'Delhi',
'Chennai',
'Surat',
'Kolkatta',
'Dehradun'
];

});
</script>

</body>
</html>
Output

5. Example Demonstrating orderBy Filter


AngularJS Document[FilterDemo5.html]
<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>

<div ng-app="MyApp" ng-controller="MyController">


<h3>The names are listed in ascending order of city name </h3>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 139 Client Side Technologies : JavaScript and DOM

<ul>
<li ng-repeat="i in personinfo | orderBy:'city'">
{{i.name +" lives in " +i.city}}
</li>
</ul>
</div>

<script>
angular.module('MyApp', []).controller('MyController', function($scope) {
$scope.personinfo = [
{name:'AAA',city:'Pune'},
{name:'BBB',city:'Banglore'},
{name:'CCC',city:'Chennai'},
{name:'DDD',city:'Delhi'},
{name:'EEE',city:'Mumbai'},
];

});
</script>

</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 140 Client Side Technologies : JavaScript and DOM

2.26.6 Tables
The ng-repeat directive is used for displaying each row of the table.
Following script demonstrates how to display the information in tabular form
AngularJS Document[TableDemo.html]

<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>
<div ng-app="MyApp" ng-controller="MyController">
<h3>Student Data</h3>
<table border="1">
<tr>
<th>Name</th><th>City</th>
</tr>
<tr ng-repeat="p in personinfo">
<td>{{p.name}}</td>
<td>{{p.city}}</td>
</tr>
</table>
</div>
<script>
angular.module('MyApp', []).controller('MyController', function($scope) {
$scope.personinfo = [
{name:'AAA',city:'Pune'},
{name:'BBB',city:'Banglore'},
{name:'CCC',city:'Chennai'},
{name:'DDD',city:'Delhi'},
{name:'EEE',city:'Mumbai'},
];

});
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 141 Client Side Technologies : JavaScript and DOM

Output

We can display the above table using the ascending order of city names and for that
purpose we need to use the filter orderBy. The illustrative code is as follows -
AngularJS Document
<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>

<div ng-app="MyApp" ng-controller="MyController">


<h3>Student Data</h3>
<table border="1">
<tr>
<th>Name</th><th>City</th>
</tr>
<tr ng-repeat="p in personinfo | orderBy:'city'">
<td>{{p.name}}</td>
<td>{{p.city}}</td>
</tr>
</table>
</div>

<script>
angular.module('MyApp', []).controller('MyController', function($scope) {

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 142 Client Side Technologies : JavaScript and DOM

$scope.personinfo = [
{name:'AAA',city:'Pune'},
{name:'BBB',city:'Banglore'},
{name:'CCC',city:'Chennai'},
{name:'DDD',city:'Delhi'},
{name:'EEE',city:'Mumbai'},
];

});
</script>
</body>
</html>

Tables with CSS


It is possible to apply the CSS style to the table. For instance following script shows the
odd rows in blue and even rows in yellow color
AngularJS Document[TableCSSDemo.html]
<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<style>
table,tr,td { Table with border of 2px and
border:2px solid; padding of 5 px
padding: 5px;
}
table tr:nth-child(odd) { Setting the style: odd rows are having
background-color:blue; background color blue
}
table tr:nth-child(even) { Setting the style: even rows are having
background-color:yellow; background color yellow
}

</style>
<body>
<div ng-app="MyApp" ng-controller="MyController">
<h3>Student Data</h3>
<table>
<tr>
</tr>
<tr ng-repeat="p in personinfo">
<td>{{p.name}}</td> Displaying table with ng-repeat
<td>{{p.city}}</td> directive
</tr>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 143 Client Side Technologies : JavaScript and DOM

</table>
</div>

<script>
angular.module('MyApp', []).controller('MyController', function($scope) {
$scope.personinfo = [
{name:'AAA',city:'Pune'},
{name:'BBB',city:'Banglore'},
{name:'CCC',city:'Chennai'},
{name:'DDD',city:'Delhi'},
{name:'EEE',city:'Mumbai'},
];

});
</script>
</body>
</html>
Output

2.26.7 Modules
 We can write the script in AngularJs using different modules. Basically the modules
help in separation of logic such as controller, service, application etc.
 The modules can be defined in separate .js files.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 144 Client Side Technologies : JavaScript and DOM

 Most commonly there are two modules - application module and controller
module.
 Let us understand how to use modules in AngularJs with the help of example.
 First consider the following code without module -
AngularJS Document
<!DOCTYPE html>
<html>
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>

<div ng-app="MyApp" ng-controller="MyController">


User: <input type="text" ng-model="user"><br/><br/>
City: <input type="text" ng-model="city"><br/>
<br/>
Address: {{address_function()}}
</div>
<script>
var app = angular.module('MyApp', []);
app.controller('MyController', function($scope) {
$scope.user = "AAA";
$scope.city = "Pune";
$scope.address_function=function() {
return $scope.user +" lives in city "+$scope.city;
};
});
</script>
</body>
</html>
Now we will create three modules from above code -
1. Application module
2. Controller Module
3. Driver Module or Use Module
Step 1 : Creating Application Module
For application module we will simply declare the application module using
angular.module function. We've passed an empty array to it. This array generally
contains dependent modules.
AngularJS Document[MyAppDemo.js]
var App=angular.module('MyApp', []);

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 145 Client Side Technologies : JavaScript and DOM

Step 2 : Creating Controller Module


The controller MyController is declared using App.controller function.

AngularJS Document[MyControllerDemo.js]
App.controller('MyController', function($scope) {
$scope.user = "AAA";
$scope.city= "Pune"
$scope.address_function=function() {
return $scope.user+" "+$scope.city;
}

});
Step 3 : Creating Driver or use Module
This module will invoke the above modules and will display the result. The two
scripts defined in above steps are included in this document using the <script src> tag.
Then using ng-app and ng-controller directives the MyAppDemo.js and
MyController.js modules are mapped.

AngularJS Document[ModuleDemo.html]
<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<script src = "MyAppDemo.js"></script> Invoking external modules
<script src = "MyControllerDemo.js"></script>
<body>
<div ng-app="MyApp" ng-controller="MyController">
User: <input type="text" ng-model="user"><br/><br/>
City: <input type="text" ng-model="city"><br/>
<br/>
Address:{{user + " lives in " + city}}
</div>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 146 Client Side Technologies : JavaScript and DOM

Step 4 : The output can be viewed as

2.26.8 Forms
 Form is a collection of various controls.
 AngularJS support two types of controls - data binding and validation controls.
 Various controls supported by AngularJS forms are -
o Input
o Select
o Button
o textarea

1. Input Control
User can type some text in the text box and the same text can be displayed on the
AngularJS document. For this binding we use inside the <form> tag.
<input type="text" ng-model ="name">
Following example illustrates the use of input control. When user types the text inside
the text box, it will be displayed along with the Welcome message.
AngularJS Document[InputDemo.html]
<html>
<head>
<title>Input Control Demo</title>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 147 Client Side Technologies : JavaScript and DOM

<script src =
"https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
</head>
<body>
<div ng-app = "">
<form>
<p>Enter your Name: <input type = "text" ng-model = "name"></p>
</form>
<p>Welcome {{name}}</p>
</div>
</body>
</html>
Output

2. Checkbox
We can have checkbox components on the Web document using AngularJS. For
having checkbox , the input type must be "checkbox"
<input type="checkbox" ng-model="chked">
Here is an illustrative example for checkbox

AngularJS Document[CheckBoxDemo.html]
<!DOCTYPE html>
<html>
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>
<div ng-app="">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 148 Client Side Technologies : JavaScript and DOM

<form>
Check the checkbox
<input type="checkbox" ng-model="chked">
</form>
<h4 ng-show="chked">When you check the checkbox this message will be displayed</h4>
</div>
</body>
</html>
Output

3. Radio Button
The radio button is basically a group of buttons which allows you to choose one value
at a time.
Let us see an illustrative script that uses Radio button control
AngularJS Document[RadioButtonDemo.html]
<!DOCTYPE html>
<html>
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body ng-app="">
<form>
Select the color:<br/>
<input type="radio" ng-model="color" value="r">Red <br/>
<input type="radio" ng-model="color" value="g">Green <br/>
<input type="radio" ng-model="color" value="b">Blue <br/>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 149 Client Side Technologies : JavaScript and DOM

</form>
<div ng-switch="color">
<div ng-switch-when="r">
<p> You have chosen Red Color </p>
</div>
<div ng-switch-when="g">
<p> You have chosen Green Color </p>
</div>
<div ng-switch-when="b">
<p> You have chosen Blue Color </p>
</div>
</div>
</body>
</html>
Output

Script Explanation
1. We have used <form> </form> tag inside which the <input type="radio"> is taken
for display of radio button.
2. The ng-model directive is used to bind radio buttons with HTML document, the
ng-model is created for a group "color". the values are set as "r", "g" or "b".
3. In this script we have taken ng-switch directive to hide and show HTML sections
depending on the value of the radio buttons. When the value of particular radio
button is matched, then corresponding message is displayed.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 150 Client Side Technologies : JavaScript and DOM

4. The selectbox
The dropdown list can be created using <select> <option> tags. For example -
AngularJS Document[SelectBoxDemo.html]
<!DOCTYPE html>
<html>
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body ng-app="">
<form>
Select the color:<br/>
<select ng-model="color">
<option value="r">Red <br/>
<option value="g">Green <br/>
<option value="b">Blue <br/>
</select>
</form>
<div ng-switch="color">
<div ng-switch-when="r">
<p> You have chosen Red Color </p>
</div>
<div ng-switch-when="g">
<p> You have chosen Green Color </p>
</div>
<div ng-switch-when="b">
<p> You have chosen Blue Color </p>
</div>
</div>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 151 Client Side Technologies : JavaScript and DOM

5. The button
We can create a button control and invoke some functionality at its click event. For
example
AngularJS Document[ButtonDemo.html]
<html>
<script src =
"https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>
<div ng-app = "MyApp" ng-controller="MyController">
<form>
<p>Enter your Name: <input type = "text" ng-model = "name"></p>
<input type = "button" value = "Click Me" ng-click="display()"></p>
</form>
<p>Welcome {{username}}</p>
</div>
<script>
var app = angular.module('MyApp', []);
app.controller('MyController', function($scope) {
$scope.name = "AAA";
$scope.display=function() {
$scope.username=$scope.name;
};
});
</script>
</body>
</html>
Output

In above script on ng-click event the function display is invoked. This function
displays the name typed by the user in the input text box.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 152 Client Side Technologies : JavaScript and DOM

2.26.9 Includes
We cannot include one HTML document inside another HTML document. But using
AngularJS we can include html document. Following program illustrates it
Step 1 : Create a simple HTML document as follows -

HTML Document[TestFile.html]
<html>
<body>
<h2> Hello!!!</h2>
</body>
</html>
Step 2 : Now create AngularJS script. Make use of ng-include directive.

AngularJS Document[IncludeDemo.html]
<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body ng-app="">
<div ng-include="'TestFile.html'"></div>
</body>
</html>
Step 3 : Open the web browser and get the output as follows -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 153 Client Side Technologies : JavaScript and DOM

We can also define the input controls in one HTML document, and initialize the values
to input control in another file.For example
Step 1 : Create an AngularJS document as follows -

AngularJS Document[IncludeDemo1.html]
<html>
<script src =
"https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>

<div ng-app = "MyApp" ng-controller="MyController">


<div ng-include = "'myFile.htm'"></div>
<script>
var App = angular.module("MyApp", []);

App.controller('MyController', function($scope) {
$scope.user = "AAA";
$scope.city = "Pune";
$scope.address_function=function() {
return $scope.user +" lives in city "+$scope.city;
};
});
</script>
</body>
</html>
Step 2 : The myFile.html document that is included in above step is as follows -
HTML Document : [myFile.html]
<table border = "1">
<tr>
<td>Enter user name:</td>
<td><input type = "text" ng-model = "user"></td>
</tr>
<tr>
<td>Enter city: </td>
<td><input type = "text" ng-model = "city"></td>
</tr>

<tr>
<td>Information: </td>
<td>{{user +" lives in "+city}}</td>
</tr>
</table>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 154 Client Side Technologies : JavaScript and DOM

Output

2.26.10 Views
 View is basically the content which is shown to the user. User can wish to see the
application in different views, accordingly that view can be displayed to the user.
 In AngularJS it is possible to have multiple views for single page application.
 The ng-view and ng-template and ng-route directives support the concept of views.
 The $routeProvider services are required for supporting the application containing
views.
 The $routeProvider services are used to map the particular view with
corresponding HTML page using templateUrl.
 The ngRoute module routes your application to different pages without reloading
the entire application. It is used in angular.module.
Step 1 : Create the main page for invoking the view pages.

AngularJS Document[ViewDemo.html]
<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular-route.js"></script>

<body ng-app="myApp">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 155 Client Side Technologies : JavaScript and DOM

<p><a href="#/!">Main</a></p>

<a href="#!view1">First View</a><br/>


<a href="#!view2">Second View</a><br/>

<div ng-view></div>

<script>
var app = angular.module("myApp", ["ngRoute"]);
app.config(function($routeProvider) {
$routeProvider
.when("/", {
templateUrl : "ViewDemo.html"
})
.when("/view1", {
templateUrl : "view1.html"
})
.when("/view2", {
templateUrl : "view2.html"
});
});
</script>
</body>
</html>
Step 2 : Create view1.html page to display first view -
view1.html
<html>
<head>
<style>
h2 {
color:red;
}
</style>
</head>
<body>
<h2> This message is in RED Color </h2>
</body>
</html>
Step 3 : Create another web page for displaying second view.
view2.html
<html>
<head>
<style>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 156 Client Side Technologies : JavaScript and DOM

h2 {
color:green;
}
</style>
</head>
<body>
<h2> This message is in Green Color </h2>
</body>
</html>
Output

On clicking the first view or second view hyperlink the corresponding page will be
displayed.

2.26.11 Scopes
The scope is an object that binds the HTML with JavaScript. In other words scope
object binds view with controller. The view part is normally written in HTML and
controller part is written as JavaScript.
Let us understand the use of scope object with the help of illustrative example.

AngularJS Document[ScopeDemo.html]
<html>
<body>
<div ng-app = "MyApp" ng-controller = "MyController">
<p>Message: {{message}} <br/>Color: {{colorname}} </p>

<div ng-controller = "RedController">


<p>Message: {{message}} <br/>Color: {{colorname}} </p>
</div>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 157 Client Side Technologies : JavaScript and DOM

<div ng-controller = "BlueController">


<p>Message: {{message}} <br/> Color: {{colorname}} </p>
</div>

</div>

<script src =
"https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>

<script>
var App = angular.module("MyApp", []);

App.controller("MyController", function($scope) {
$scope.message = "In Color Demo controller";
$scope.colorname = "No-Name";
});

App.controller("RedController", function($scope) {
$scope.message = "In Red Color controller";
});

App.controller("BlueController", function($scope) {
$scope.message = "In Blue Color controller";
$scope.colorname = "BLUE";
});

</script>

</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 158 Client Side Technologies : JavaScript and DOM

Script Explanation :
In above code
1. We have created three controllers namely MyController, RedController and
BlueController.
2. There are two properties namely message and colorname.
3. Note that RedController does not have colorname property; hence it inherits this
value from MyController.
4. The scope object is used to define that values for these properties. Hence in
HTML (view) part we can simply invoke the name of the property as message
and colorname inside {{ }} and get the values assigned in respective controller.
5. Thus job of scope object is to bind the controller with view part of AngularJS
document.

2.26.12 Services
The services are functions or objects that are intended to carry out specific task.
In AngularJS there are 30 built-in services used to carry out variety of tasks.

Built-in Services
Let us understand the use of services with the help of examples -
1. The $http Service
This is a commonly used service in AngularJS. By using this service, the request
can be made to the server and the application handles the response.
Step 1 : Create a simple web document as follows -
msg.html
Well Done!!!
Step 2 : Now create a web document that will make use of $http service to get the
message stored in above html file and to display the contents.

AngularJS Document[ServiceDemo1.html]
<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>

<div ng-app="MyApp" ng-controller="MyController">


<p>Message obtained from a file is...</p>
<h1>{{message}}</h1>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 159 Client Side Technologies : JavaScript and DOM

</div>

<script>
var App = angular.module('MyApp', []);
App.controller('MyController', function($scope, $http) {
$http.get("msg.html").then(function (response) {
$scope.message = response.data;
});
});
</script>

</body>
</html>
Output

2. The $timeout Service


The $timeout service is useful to execute certain task after some time interval.
Following example displays one message on the browser and after 5 seconds another
message will be displayed.

AngularJS Document[ServiceDemo2.html]
<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>
<div ng-app="MyApp" ng-controller="MyController">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 160 Client Side Technologies : JavaScript and DOM

<p>Message will be changed after 5 seconds</p>


<h1>{{message}}</h1>

</div>
<script>
var App = angular.module('MyApp', []);
App.controller('MyController', function($scope, $timeout) {
$scope.message = "Welcome User";
$timeout(function() {
$scope.message = "Good Bye!!!";
},5000);
});
</script>

</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 161 Client Side Technologies : JavaScript and DOM

Creation of Custom Service


It is possible to create our own service. The service is normally created using two
methods
1. Factory 2. Service
Step 1 : Using factory method we can define a factory and the method that performs
specific task (i.e. service) is assigned to it.

For example
var App = angular.module("MyApp", []);
App.factory('AddService', function() {
var factory = {};
factory.addition = function(a, b) {
return a + b
}
return factory;
});
Step 2 : Using service method we can define the service and a method is then assigned to
it.

For example
App.service('CalculateService', function(AddService){
this.add = function(a,b) {
return AddService.addition(a,b);
}
});
Step 3 : Then a controller is defined and the scope object and service method is invoked in
it.
App.controller('MyController', function($scope, CalculateService) {
$scope.add = function() {
$scope.result = CalculateService.add($scope.number1,$scope.number2);
}
});
The above three steps must be applied within the <script> </script>, which acts as a
controller.
The view part is specified in <div> </div> tag.
Let us create a service for addition of two numbers.

AngularJS Document[ServiceDemo3.html]
<html>
<script src =
"https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 162 Client Side Technologies : JavaScript and DOM

<body>
<h3> Addition of two numbers </h3>
<div ng-app = "MyApp" ng-controller = "MyController">
<p>Enter first number: <input type = "number" ng-model = "number1" /></p>
<p>Enter second number: <input type = "number" ng-model = "number2" /></p>
<button ng-click = "add()">ADDITION</sup></button>
<p>Answer = {{result}}</p>
</div>

<script>
var App = angular.module("MyApp", []);

App.factory('AddService', function() {
var factory = {};

factory.addition = function(a, b) {
return a + b
}
return factory;
});

App.service('CalculateService', function(AddService){
this.add = function(a,b) {
return AddService.addition(a,b);
}
});

App.controller('MyController', function($scope, CalculateService) {


$scope.add = function() {
$scope.result = CalculateService.add($scope.number1,$scope.number2);
}
});
</script>

</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 163 Client Side Technologies : JavaScript and DOM

Output

Example 2.26.1 Write a user defined service in AngularJS for reversing the given string.

Solution :
<html>
<script src =
"https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<body>
<h3> Reversing of String </h3>
<div ng-app = "MyApp" ng-controller = "MyController">
<p>Enter some string: <input type = "text" ng-model = "s" /></p>
<button ng-click = "reverse_str()">Click to Reverse</sup></button>
<p>Reversed String is: {{result}}</p>
</div>

<script>
var App = angular.module("MyApp", []);

App.factory('MyService', function() {
var factory = {};
factory.str_operation = function(str) {
var r="";
for(var i=str.length-1;i>=0;i--)
r+=str[i];

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 164 Client Side Technologies : JavaScript and DOM

return r;
}
return factory;
});

App.service('DisplayService', function(MyService){
this.reverse_str = function(str) {
return MyService.str_operation(str);
}
});

App.controller('MyController', function($scope, DisplayService) {


$scope.reverse_str = function() {
$scope.result = DisplayService.reverse_str($scope.s);
}
});
</script>
</body>
</html>
Output

2.26.13 Dependency Injection


 Dependency Injection is a software design pattern in which an object is given its
dependencies, rather than the object creating them itself.
 AngularJS comes with a built-in dependency injection mechanism.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 165 Client Side Technologies : JavaScript and DOM

 Due to dependency injection mechanism, multiple different types of components


which can be injected into each other's dependencies.
 Advantage of dependency injection is that it makes easier to reuse, configure and
test the component in the application.
 There are core components that take part in dependency injection -
1. value 2. factory
3. service 4. Provider 5. constant
Advantages of Dependency Injection
1. The creation and consumption of values and methods(dependencies) are
separated.
2. Concurrent or independent development of dependencies is possible.
3. It facilitates the changing of dependencies when required.
4. It also allows injecting mock objects as dependencies for testing and
maintenance.
5. It is possible to reuse and configure the object due to dependency injection.
Let us discuss how the dependency injection works for AngularJS application.
1. Value
The value is a simple object. It can be number, text, or some JavaScript object. The
dependency injection can be achieved by passing values to factory, services or controller.
The value can be defined using value() function.
For example -
//define a module
Var App = angular.module("myApp", []);

//create a object as 'str' and pass it a data.


App.value("str", "abc");

//inject this value in the controller


App.controller('MyController', function($scope, DisplayService,str) {
$scope.message=str;
$scope.result = DisplayService.reverse_str($scope.message);
});

2. factory
The factory function is used to return some value. Inside this factory function the
values based on the demand of user or services are created. Typically factory function is
injected within a service to utilize the methods. For example -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 166 Client Side Technologies : JavaScript and DOM

var App = angular.module("MyApp", []);


//create factory function
App.factory('AddService', function() {
var factory = {};
factory.addition = function(a, b) {
return a + b
}
return factory;
});

// inject factory in service named 'CalculateService'


App.service('CalculateService', function(AddService){
this.add = function(a,b) {
return AddService.addition(a,b);
}
});

3. service
The service is a JavaScript object which contains set of functions to perform some
specific task. The services are injected into controller.
//creation of service named 'CalculateService'
App.service('CalculateService', function(AddService){
this.add = function(a,b) {
return AddService.addition(a,b);
}
});
//Injection of service to controller 'MyController'
App.controller('MyController', function($scope, CalculateService) {
$scope.add = function() {
$scope.result = CalculateService.add($scope.number1,$scope.number2);
}
});

4. provider
The provider is a special factory method with get() function.
In AngularJS the provider is used internally to create services, factory during the
configuration phase.
The get() function of provider is used to return the value or service or factory.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 167 Client Side Technologies : JavaScript and DOM

For example -
//define a module
var App = angular.module("MyApp", []);
...

//create a service using provider which defines a method addition to return addition of two
numbers
App.config(function($provide) {
$provide.provider('AddService', function() {
this.$get = function() {
var factory = {};

factory.addition = function(a, b) {
return a + b;
}
return factory;
};
});
});

5. constant
The values can not be injected into module.config() , hence the constants are used to
pass the values to config. For example
App.constant("configparam","value");

2.26.14 Custom Directives


 In the simplest terms, a directive in AngularJS is a reusable component.
 Directives in AngularJS encapsulate all the behavioral properties and functionalities
of an element thereby keeping all of the functionality grouped together.
 We can create directive using following steps -
Step 1 : Define Angular App
var mainApp = angular.module("myApp", []);
Step 2 : Now define directive
mainApp.directive("person", function() {
var directive = {};
directive.restrict = "EA";
directive.template = "<h1> This is my first custom directive</h1>";
return directive;
});

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 168 Client Side Technologies : JavaScript and DOM

Code Explanation :
 The directive object is defined inside the
mainApp.directive("person", function() {

Name of the directive

 We have define the directive object as


var directive = {};
The restrict 'EA' means the restriction is at the HTML element level as well as for the
HTML element with attribute.
The legal restrict values are :
1. E for Element name 2. A for Attribute
3. C for Class 4. M for Comment
By default the value is EA, meaning that both Element names and attribute names can
invoke the directive.
 Then we define the template for the directive element as
directive.template = "<h1> This is my first custom directive</h1>";
The template is basically the placeholder HTML code that can be used multiple times
for the defined directive.
 Finally the created directive object is returned from the mainApp.directive
function.
return directive;
Step 3 : Embed the directive in HTML page as
<body ng-app = "myApp">
For element level: <person></person>
For attribute level: <div person></div><br/>
</body>

Code Explanation :
Note that we have used the directive named person as HTML element as well as
attribute with <div> tag.
Step 4 : The complete code can be given as follows -

AngularJS Document[DirectiveDemo.html]
<html>
<body ng-app = "myApp">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 169 Client Side Technologies : JavaScript and DOM

For element level: <person></person>


For attribute level: <div person></div><br/>
<script src =
"https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<script>
var mainApp = angular.module("myApp", []);
mainApp.directive("person", function() {
var directive = {};
directive.restrict = "EA";
directive.template = "<h1> This is my first custom directive</h1>";
return directive;
});
</script>
</body>
</html>
Step 5 : Run the above code in Web browser

2.26.15 Internationalization
AngularJS has built-in support for internationalization of numbers and dates.
There are built-in filters such as date, currency and number.
date Filter
The date filter the date is following format -
i) Short ii) medium

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 170 Client Side Technologies : JavaScript and DOM

iii) fullDate iv) shortDate


v) mediumDate vi) longDate
vii) shortTime viii) mediumTime

currency Filter
The currency filter will use the currency symbol associated with the chosen locale
when formatting a number as a currency. We can specify the currency symbol to the
currency filter like this :
{{ curr | currency : '$' }} //dollars
{{ curr | currency : '£' }} //pounds

number Filter
The number filter formats numbers according to the chosen locale. For example in
Danish the thousand separators is specified by comma.
Setting Locale
For Internationalization we need to set the locale. The Danish locale can be set using
following script
<script src = "https://code.angularjs.org/1.2.5/i18n/angular-locale_da-dk.js"></script>

Example
Let us discuss AngularJS Document having display of date and currency in specific
form.
AngularJS Document[Internationalization.html]
<!DOCTYPE html>
<html>
<script
src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.5/angular.min.js"></script>
<script src="https://code.angularjs.org/1.2.5/i18n/angular-locale_da-dk.js"></script>
<body ng-app="myapp">
<div ng-controller="mycontroller">
<strong>Today:</strong> {{dt | date : "fullDate"}} <br/>
<strong>Amount:</strong> {{val | currency }}
</div>

<script>
var module = angular.module("myapp", []);
module.controller("mycontroller", function($scope) {
$scope.dt = new Date();
$scope.val = 555.44;
});

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 171 Client Side Technologies : JavaScript and DOM

</script>
</body>
</html>
Output

Review Questions

1. Does Angular JS support single page application via multiple views on a single page ? Justify
your answer. SPPU : May-18, Marks 6

2. List and explain events supported by angular JS to enrich form filling and validation.
SPPU : May-18, Marks 4

3. What are different ways to create service in angular JS ? Explain separation of concern in
angular JS. SPPU : May-18, Marks 6

4. Create simple angular JS application to display “Hello, Input Name” using proper directive.
SPPU : Dec.-18, May-19, Marks 6

5. List and explain various directives in angular JS. SPPU : Dec.-18, Marks 4

6. Write sample angular JS application which can demonstrate use of different expressions.
SPPU : May-19, Marks 8

7. What is angular JS ? List and explain various directives in angular JS.


SPPU : Dec.-19, Marks 8

8. Explain how angular JS integrates with HTML ?


SPPU : Dec.-19, Marks 8

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 172 Client Side Technologies : JavaScript and DOM

2.27 Multiple Choice Questions

Q.1 JavaScript is _______ language.

a programming b scripting
c application d none of these
Q.2 JavaScript is designed for this purpose.

a To apply particular style to HTML pages.


b To perform server side scripting
c To add interactivity to HTML pages.
d To execute query to the backend database
Q.3 The script tag must be placed in _______.

a head b head and body


c body d none of these
Q.4 JavaScript code can be called using _______.

a triggering event b preprocess


c function d all of the above
Q.5 Which of the following is not treated as error in JavaScript ?

a Missing Semicolons b Not declaring variables


c Division by zero d All of the above
Q.6 Among the following which one is ternary operator ?

a + b :
c – d ?
Q.7 Which of the following attribute can hold the JavaScript version ?

a Language b Script
c Version d None of the above
Q.8 JavaScript was invented by _______.

a Sir Tim Barnard Lee b W3 group


c James Gosling d Brendan Rich
Q.9 Integer variable is declared using following syntax in JavaScript _______.

a int num; b Integer num;


c var num; d integer num;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 173 Client Side Technologies : JavaScript and DOM

Q.10 JavaScript variables are _______.


a case sensitive b case non sensitive
Q.11 JavaScript is _______.
a compiled b interpreted
Q.12 The nodes in HTML are _______.
a Subclass nodes b HTML nodes
c Window nodes d Element nodes
Q.13 Which property is used to obtain browser vendor and version information ?
a Model b Version
c Browser d Navigator
Q.14 What is the result of the following code sinppet ? window location===document
location.

a False b True
c 0 d 1
Q.15 jQuery is a _______.
a Java program b query language
c JavaScript library d none of these
Q.16 _______ is the sign used as a shortcut in jQuery.
a $ b %
c @ d &
Q.17 _______ is the method used to set one or more style properties to the selected element.
a html() method b style() method
c css() method d all of the above
Q.18 Which of the jQuery function prevents the code from running before the loading of the
document finishes ?

a $(document).load() b $(document).unload()
c $(document).ready() d $(document).trim()
Q.19 AngularJS expressions are written using _______.
a (expression) b [expression]
c [[expression]] d {{expression}}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 2 - 174 Client Side Technologies : JavaScript and DOM

Q.20 Which directive initializes an AngularJS application ?


a ng-init b ng-app
c ngSrc d ng-model

Answers Keys for Multiple Choice Questions :

Q.1 b Q.2 c Q.3 b Q.4 c Q.5 c

Q.6 d Q.7 a Q.8 d Q.9 c Q.10 a

Q.11 b Q.12 d Q.13 d Q.14 b Q.15 c

Q.16 a Q.17 c Q.18 c Q.19 d Q.20 b



TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


UNIT- III

3 Java Servlets and XML

Syllabus
Servlet : Servlet architecture overview, A “Hello World” servlet, Servlets generating dynamic
content, Servlet life cycle, parameter data, sessions, cookies, URL rewriting, other Servlet
capabilities, data storage, Servlets concurrency, databases (MySQL) and Java Servlets.
XML : XML documents and vocabularies, XML declaration, XML Namespaces, DOM based XML
processing, transforming XML documents, DTD : Schema, elements, attributes.
AJAX : Introduction, Working of AJAX.

Contents
3.1 Introduction to Server Side Programming

3.2 Servlet Architecture Overview


3.3 A "Hello World" Servlet............................................. May-19, ................................. Marks 5

3.4 Servlets Generating Dynamic Content

3.5 Servlet Life Cycle ............................................... March-20,.............................. Marks 5

3.6 Servlet API

3.7 Parameter Data

3.8 Sessions
3.9 Cookies ................................................... Dec.-19,................................. Marks 5

3.10 URL Rewriting

3.11 Other Servlet Capabilities

3.12 Data Storage

3.13 Servlets and Concurrency

3.14 Databases (MySQL) and Java Servlets


3.15 XML Documents and Vocabularies .......................... Dec.-18, 19, May-19, ............ Marks 5

3.16 XML Declaration

(3 - 1)
Web Technology 3-2 Java Servlets and XML

3.17 Rules

3.18 XML Namespaces


3.19 Document Type Definition (DTD) ............................. May-18, ................................. Marks 5

3.20 Schema ............................................... May-18, ................................. Marks 5

3.21 DOM based XML Processing

3.22 Transforming XML Documents ................................... May-19, March-20, ............... Marks 5

3.23 Introduction

3.24 Working of AJAX

3.25 XMLHttpRequest Object


3.26 Coding AJAX Script ................................................... Dec.-18, 19, May-18,19 ........ Marks 8

3.27 Multiple Choice Questions

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3-3 Java Servlets and XML

Part I : Servlet

3.1 Introduction to Server Side Programming


 Server side technology deals with the data submitted by the client.
 Server side program basically handles the request made by the client. This program
then prepares the response for the client.
 The server side programming also act as a link between backend database and front
end client side programming.
 Various server side technologies include – servlet, JSP, ASP.NET, PHP and so on.

Difference between client side and server side scripting


Sr. Server side scripting Client side scripting
No.

1. The server side scripting is used to create The client side scripting is used to create the web
the web pages that provide some services. pages as a request or response to server. These
pages are displayed to the user on web browser.

2. These scripts generally run on web These scripts generally run on web browser.
servers.

3. A user's request is fulfilled by running a The processing of these scripts takes place on the
script directly on the web server to end users computer. The source code is
generate dynamic HTML pages. This transferred from the web server to the users
HTML is then sent to the client browser. computer over the internet and run directly in
the browser.

4. Uses : Processing of user request, Uses : Making interactive web pages, for
accessing to databases. interacting with temporary storages such as
cookies or local storage, sending request to server
and getting the response and displaying that
response in web browser.

5. Example : PHP, ASP.NET, nearly all the Example : HTML, CSS, JavaScript(primarily)
programming languages including C++,
Java and C#

3.2 Servlet Architecture Overview


 Servlets are basically the Java programs that run on server. These are the programs that
are requested by the XHTML documents and are displayed in the browser window as
a response to the request.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3-4 Java Servlets and XML

 The servlet class is instantiated when web server begins the execution.
 The execution of servlet is managed by servlet container, such as Tomcat.
 The servlet container is used in java for dynamically generate the web pages on the
server side. Therefore the servlet container is the part of a web server that interacts
with the servlet for handling the dynamic web pages from the client.
 Servlets are most commonly used with HTTP (i.e. Hyper Text Transfer Protocol) hence
sometimes servlets are also called as "HTTP Servlet".
 The main purpose of servlets is to add up the functionality to a web server.

Working of How Servlet Works ?


 Before learning the actual servlet programming it is very important to understand how
servlet works.

Fig. 3.2.1 How servlet works ?

1. When a client make a request for some servlet, he/she actually uses the Web
browser in which request is written as a URL.
2. The web browser then sends this request to Web server. The web server first
finds the requested servlet.
3. The obtained servlet gathers the relevant information in order to satisfy the
client’s request and builds a web page accordingly.
4. This web page is then displayed to the client. Thus the request made by the
client gets satisfied by the servlets.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3-5 Java Servlets and XML

3.2.1 Need and Advantages


 Servlets can process and store the data submitted by an HTML form.
 Servlets are useful for providing the dynamic contents. For example retrieving and
updating the databases.
 Servlets can be used in the cookies. Cookies are small programs which can make use of
the information submitted on currently accessed web pages.
 Similarly servlets are used in session tracking. The session tracking are the useful
programs that keeps track of all previously accessed the web pages.

Advantages
 The servlets are very efficient in their performance and get executed in the address
space of the belonging web server.
 The servlets are platform independent and can be executed on different web servers.
 The servlets working is based on Request-Response. Any HTML form can take the
user input and can forward this input to the servlet. The servlets are then responsible to
communicate with the back-end database and manipulate the required business logic.
These servlets embedded on the web servers using Servlets API.
 Servlets provide a way to generate the dynamic document. For instance : A servlet can
display the information of current user logged in, his logging time, his last access, total
number of access he made so far and so on.
 Multiple users can keep a co-ordination for some application among themselves using
servlets.
 Using servlets multiple requests can be synchronized and then can be concurrently
handled.

Disadvantages
 Servlet is a mixture of java skills and web related HTML skills. Hence it is difficult to
write servlets.
 It slows down the application execution.
 The java runtime environment is required on the server, if you want to execute servlet
application.

3.3 A "Hello World" Servlet SPPU : May-19, Marks 5

 When we write a servlet program, it is necessary to - i) Either implement Servlet


interface or ii) Extend a class that implements Servlet interface.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3-6 Java Servlets and XML

 While implementing Servlet interface we must include javax.servlet package. Hence


the first line in out servlet program must be,
import javax.servlet.*;
 GenericServlet class is a predefined implementation of Servlet interface. Hence we can
extend GenericServlet class in our servlet program. Similarly, the HttpServlet class is a
child class of GenericServlet class, hence we can extend this class as well while writing
the servlet program.
 Hence following are the two ways by which we can write servlet program
import javax.servlet.*; import javax.servlet.*;
import javax.servlet.http.*; import javax.servlet.http.*;
import java.io.*; import java.io.*;
public class Test extends public class Test extends
GenericServlet HttpServlet
{ {
//body of servlet //body of servlet
} }
 The servlet gets the request from the client for some service. The servlet then processes
the request and sends the response back to the client. In order to handle these issues
HttpServletRequest and HttpServletResponse are used in servlet program.
 These requests are handled with the help of some methods that are popularly known
as methods of HttpServlet. These methods are as follows,
Method Purpose

doGet This method handles the HTTP GET request

doPost This method handles the HTTP POST request

doPut This method handles the HTTP Put request.

doDelete This method handles the DELETE request.

The doGet and doPost methods


 The doGet method requests the data from the source.
 The doPost method submits the processed data to the source.
 The protocol of doGet method is as follows,
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException,IOException
 The ServletException and IOException are thrown to handle the Servlet problems
gracefully.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3-7 Java Servlets and XML

 The HttpServletRequest request : Contain the client request made by client.


 The HttpServletResponse response : Contains the response made by servlet back to the
client.
 The protocol of doPost method is same as doGet method. It is as follows -
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws
ServletException,IOException
 The GET request is more efficient than the POST request.
 The GET request is less secure than the POST request.

How to Write Servlet Program ?


Open notepad and write the first servlet code to display greeting messages. It is as
follows,

FirstServlet.java
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;

public class FirstServlet extends HttpServlet


{
public void doGet(HttpServletRequest request,HttpServletResponse response)
throws IOException,ServletException
{
response.setContentType("text/html");
PrintWriter out=response.getWriter();
out.println("<html>");
out.println("<head>");
out.println("<title>My First Servlet</title>");
out.println("<body>");
out.println("<h1>Hello How are U?</h1>");
out.println("<h2>I am enjoying this Servlet Application</h2>");
out.println("<h3>See You later!</h3>");
out.println("</body>");
out.println("</html>");
}
}

Program Explanation :
 In the above program, we have imported following files,
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3-8 Java Servlets and XML

 Out of these files java.io package is useful for taking care of I/O operations.
 The javax.servlet and javax.servlet.http are important packages containing the classes
and interfaces that are required for the operation of servlets. The most commonly used
interface from javax.servlet package is Servlet. Similarly most commonly used class in
this package is GenericServlet. The ServletRequest and ServletResponse are another
two commonly used interfaces defined in javax.servlet package.
 In the javax.servlet.http package HttpServletRequest and HttpServletResponse are
two commonly used interfaces. The HttpServletRequest enables the servlet to read
data from the HTTP request and HttpServletResponse enables the servlet to write data
to HTTP response. The cookie and HttpServlet are two commonly used classes that are
defined in this package.
 We have given class name FirstServlet which should be derived from the class
HttpServlet. (Sometimes we can derive our class from GenericServlet).
 Then we have defined doGet method to which the HTTP request and response are
passed as parameters. The commonly used basic exceptions for the servlets are
IOException and ServletException.
 The MIME type is specified as using the setContentType() method. This method sets
the content type for the HTTP response to type. In this method “text/html” is specified
as the MIME type. This means that the browser should interpret the contents as the
HTML source code.
 Then an output stream is created using PrintWriter(). The getWriter() method is used
for obtaining the output stream. Anything written to this stream is sent to the client as
a response. Hence using the object of output stream ‘out’, we can write the HTML
source code in println method as HTTP response.

How to execute Servlet program ?


Step 1 : Compile the above program using the javac command at command prompt.
D:\test>javac FirstServlet.java
The class file for this program gets generated.
Step 2 : Before running any servlet program, it is necessary to have
1. JDK installed
2. Tomcat installed.
3. Class path for above two packages must be set.
For Tomcat installation, I prefer to install the package XAMPP. The XAMP contains a
directory for tomcat. The XAMPP package contains Apache Web server, MySQL, PHP
and Perl support. It can work on both Windows and Linux operating System.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3-9 Java Servlets and XML

Step 3 : Copy the class file generated in Step 1 to the path


C : \xampp\tomcat\webapps\examples\WEB-INF\classes
Step 4 : Go to the directory
C : \xampp\tomcat\webapps\examples\WEB-INF
Open web.xml file and edit it as follows
<servlet>
<servlet-name>FirstServlet</servlet-name>
<servlet-class> FirstServlet </servlet-class>
</servlet>



<servlet-mapping>
<servlet-name> FirstServlet </servlet-name>
<url-pattern>/servlet/ FirstServlet </url-pattern>
</servlet-mapping>
The web.xml file is popularly known as deployment descriptor. This is basically the
configuration file that describes how to map the URL of web application to servlet.
<servlet>
Internal alias Name

<servlet-name>FirstServlet</servlet-name>

Actual Name of server

<servlet-class> FirstServlet </servlet-class>


</servlet>



Internal alias Name
<servlet-mapping>
<servlet-name> FirstServlet </servlet-name>

External alias Name

<url-pattern>/servlet/ FirstServlet </url-pattern>


</servlet-mapping>
The Servlet comes with two alias names, internal and external. The internal name is
used by the Tomcat and the external name is given (to be written in <FORM> tag of
HTML file) to the client to invoke the Servlet on the server. That is, there exists alias to

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 10 Java Servlets and XML

alias. All this is for security. Observe, the names are given in two different XML tags, in
the web.xml file, to make it difficult for hacking.
To invoke the FirstServlet Servlet, the client calls the server with the name
servlet/FirstServlet.
When servlet/FirstServlet call reaches the server, the Tomcat server opens the
web.xml file to check the deployment particulars. Searches such a <servlet-mapping> tag
that matches servlet/FirstServlet. servlet/FirstServlet is exchanged with FirstServlet.
Then, searches such a <servlet> tag that matches FirstServlet and exchanges with
FirstServlet class. Now the server, loads FirstServlet Servlet, executes and sends the
output of execution as response to client.

Step 5 : Start tomcat and xampp


Step 6 : Open web browser and type the command
http ://localhost/examples/servlet/FirstServlet
The output will be
Output

Review Question

1. Write a Java servlet program which will display "welcome to servlet" message.
SPPU : May-19, Marks 5

3.4 Servlets Generating Dynamic Content


 In modern web technology, the web site must be able to generate dynamic contents
as per the requirements. Servlets can generate static, dynamic or interactive web
pages.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 11 Java Servlets and XML

 Following is a simple servlet program that displays the current date and time. Note
that the time is continuously changing and on refreshing the same page, we can
note down the changes.

Example Program
import java.io.*;
import javax.servlet.*;
public class DynamicServletDemo extends GenericServlet
{
//implement service()
public void service(ServletRequest req, ServletResponse res)
throws IOException, ServletException
{
//set response content type
res.setContentType("text/html");
//get stream obj
PrintWriter out = res.getWriter();
java.util.Date date = new java.util.Date();
out.println("<h2>"+"Current Date & Time: " +date.toString()+"</h2>");
//close stream object
out.close();
}
}
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 12 Java Servlets and XML

Press F5 and refresh the current page, you will get the some changes in the output.

Program Explanation : In above program,

1. We have used Date() method of java.util class that is intended to display current
date and time.
2. The date is displayed using the date.toString() method.

3.5 Servlet Life Cycle SPPU : March-20, Marks 5

In the life cycle of servlet there are three important methods. These methods are,
1. Init
2. Service
3. Destroy

Fig. 3.5.1 Life cycle of servlet

 The client enters the URL in the web browser and makes a request. The browser then
generates the HTTP request and sends it to the Web server. (Refer Fig. 3.5.1)
 Web server maps this request to the corresponding servlet.
1. Init ( ) Method : The server basically invokes the init() method of servlet. This
method is called only when the servlet is loaded in the memory for the first time.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 13 Java Servlets and XML

Using this method initialization parameters can also be passed to the servlet in order to
configure itself.
2. service ( ) Method : Server can invoke the service for particular HTTP request using
service() method. The servlets can then read the data provided by the HTTP request
with the help of service() method.
3. destroy ( ) Method : Finally server unloads the servlet from the memory using the
destroy() method.

Example Program
Following is a simple servlet in which these three methods viz. init(), service() and
destroy() are used -
import javax.servlet.*;
import javax.servlet.http.*;
import java.io.*;

public class LifeCycle extends GenericServlet


{
public void init(ServletConfig config) throws ServletException
{
System.out.println("init");
}

public void service(ServletRequest request, ServletResponse response)


throws ServletException, IOException
{
System.out.println("from service");
PrintWriter out = response.getWriter();
out.println("Twinkle Twinkle Little Stars.");
out.print("How I wonder what you are.");
}
public void destroy()
{
System.out.println("destroy");
}
}

Program Explanation : In the above program,


1. We have first of all used an init() method to which object of the ServletConfig
interface is passed. This interface allows the servlet to get the initialization
parameters.
2. Then we have used the service() method to which the ServletRequest and

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 14 Java Servlets and XML

ServletResponse parameters are passed for making the HTTP request and
getting the HTTP response from the sevlet.
3. The output stream is created using getWriter() and along this output stream
some messages are written. These messages will then be displayed on the web
browser when the servlet gets executed.
4. Finally the destroy() function is written in order to unload the servlet from the
memory.

Review Question

1. Explain the lifecycle of servlet. Write a simple servlet to print "Hello, Good Day".
SPPU : March-20, Marks 5

3.6 Servlet API


There are two packages used to implement the Servlet. These packages are,

1) javax.servlet

2) javax.servlet.http
The classes and interfaces defined in these packages help in implementing the servlet.
Let us discuss them in detail -

3.6.1 The javax.servlet Package


 This package is used to implement the servlet. Out of many other interfaces and
classes defined in this package the most important interface is Servlet . All the
servlet must implement this interface. The interfaces and classes that are defined in
this package are enlisted below -

3.6.1.1 Interfaces

Interface Description

Servlet This interface defines all the life cycle methods.

ServletConfig This interface obtains the initialization parameters.

ServletContext Using this interface the events can be logged.

ServletRequest This interface is useful in reading the data from the client request.

ServletResponse This interface is useful in writing the data to the client response.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 15 Java Servlets and XML

1. The Servlet Interface


 This interface defines all the life cycle methods such as init(),destroy() and service().
All the servlets must implement this interface. Some of the methods provided by
this interface are -
Method Description

void init(ServletConfig s) This method is called for initialising the servlet. The
initialisation parameter is obtained from the ServletConfig
interface.

void destroy() This method is called when the servlet has to be unloaded.

ServletConfig getServletConfig() This method is used to obtain the initialisation parameters.

void Service(ServletRequest req, This method is used to implement the service that a servlet
ServletResponse res) should provide. The clients request is processed and a
response is given.

String getServletInfo() This method is used to obtain description of the servlet.

2. The ServletConfig Interface


 This interface is used to obtain the initialisation parameters. Various methods that
are used by this interface are -
Method Description

String getServletName() This method is used to obtain the name of the servlet.

String getInitParameter(String p) This method returns the value of the parameter p

Enumeration getinitParamernames() This method returns the names of initialisation parameters.

ServletContext getServletContext() This method returns the context for the servlet.

3. The ServletContext Interface


 This is the interface that enables the servlet to log events and access information
about their environment. Various methods of this interface are -
Method Description

Object getAttribute(String attribute_name) The value of the attribute attribute_name in the


current session is returned.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 16 Java Servlets and XML

void setAttribute(String attribute_name, The attribute_name is passed to the object value.


object value)

String getServerInfo() This method returns the information about the


server.

String log(String str) Writes the str to the servlet log.

String getMimeType(String file) It returns the MIME type of the file.

4. The ServletRequest Interface


 The ServletRequest interface helps in gathering the information about the client.
Various methods in ServletRequest are -
Method Description

Object getAttribute(String attribute_name) The value of the attribute attribute_name in the


current session is returned.

int getContentlength() It returns the content size of the request.

String getContentType() It returns the type of the request.

getInputStream() This method is used to read the binary data from


the request.

getProtocol() Returns the name of the protocol used.

getReader() This method is useful for reading the text from the
request.

getServerName() It returns the name of the server on which the


servlet is running.

int getServerPort() It returns the port number of the server.

5. The ServletResponse Interface


 This interface helps the servlet to formulate the response for the client’s request.
Various methods of this interface are -
Method Description

String getCharacterEncoding() This method returns the character encoding.

ServletOutputStream getOutputStream() This method returns outputstream which is used


to write the data for responding.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 17 Java Servlets and XML

PrintWriter getWriter() This method is used to write the character data to


the response.

void setContentLength(int size) This method sets the length of the content equal to
the size.

void setContentType(String Type) This methods sets the type of the content

3.6.1.2 Classes
 The javax.servlet package contains following classes.
Class Description

GenericServlet This class implements the Servlet and ServletConfig interfaces.

ServletInputStream This class provides the input stream for reading the client’s request.

ServletOutputStream This class provides the output stream for writing the client’s response.

ServletException This class is used to raise the exception when an error occurs.

1. The GenericServlet class


 This class is useful for implementing the life cycle methods. It implements the
servlet and ServletConfig interfaces. It is called "Generic" because it does not
assume that the protocol it will process will be HTTP. If we want to write our own
protocol, then we must extend this class.

2. The ServletInputStream class


 The ServletInputStream class extends the InputStream. This class provides an
input stream which is used by a servlet for reading the data from a client request.
For reading the bytes from a client the method used is readLine.

3. The ServletOutputStream class


 The ServletOutputStream class extends the OutputStream. This class provides an
output stream which is used by a servlet for writing the data for a client response. It
also defines print and println method.

4. The ServletException class


 The javax.servlet defines two servlets ServletException and UnavailableException

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 18 Java Servlets and XML

3.6.2 The javax.servlet.http Package


 The javax.servlet.http package contains a number of interfaces and classes and their
functionality makes it easy to build servlets. These servlets then work with HTTP
requests and responses.

3.6.2.1 Interface
 The following table describes the interfaces that are provided in this package
Interface Description

HttpSession The session data can be read or written using this interface.

HttpServletRequest The servlet can read the information from the HTTP request
using this interface.

HttpServletResponse The servlet can write the data to HTTP response using this
interface.

HttpSessionBindingListener This interface tells the object about its binding with the
particular session.

1. The HttpSession
 At every HTTP session, the state information is gathered. The servlet can read or
write this information using HTTPSession interface. This interface is implemented
by the server.
 Various methods used by this interface are as given below -
Method Description

String getId() This method returns the session ID.

Object getAttribute(String attribute_name) The value of the attribute attribute_name in


the current session is returned.

Enumeration getAttributeNames() Returns the attribute names.

2. The HttpServletRequest
 The HTTPServletRequest is used to obtain the information from client’s HTTP
request.
Method Description

String getMethod() It returns the HTTP method for the client request.

String getPathInfo() Returns the path information about the servlet path.

HttpSession getSession() Returns the current session.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 19 Java Servlets and XML

String getHeader(String fields) It returns the value of header fields.

Cookie [ ] getCookies() It returns the information in the cookies in the request made.

String getAuth Type() It returns the type of Authentication.

3. The HttpServletResponse
 This HtttpServletResponse interface is used to formulate an HTTP response to the
client. Various methods are -
Method Description

void addCookie(Cookie cookie) This method is used to add cookie in the response.

String encodeURL(String url) This method is used to encode the specified URL.

Boolean containsHeader(String f) This method returns true if the response header


contains the field f.
void sendError(int code) This method sends error code to the client.

4. The HttpSessionBindingListener
 When particular listener gets bound or unbound from a value within HttpSession
object then this class is required. It extends the HttpSessionEvent. Various methods
that can be defined by this interface are -
Method Description

Object getValue() This function returns the value of bounded or unbounded attribute.

String getName() This function returns the name being bound or unbound.

HttpSession getSession() This function returns the session to which the listener can be bound
or unbound.

3.6.2.2 Classes
 The following table describes the classes that are provided in this package
Class Description

Cookie This class is used to write the cookies.

HttpServlet It is used when developing servlets that receive and process HTTP
requests.
HttpSessionEvent This class is used to handle the session events.

HttpSessionBindingEvent When a listener is bound to a value.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 20 Java Servlets and XML

1) The Cookie class


 A cookie is a small piece of information that is stored in the client’s machine.
Sometimes cookies are useful to keep track of the user using the client machine.
Various methods used by this class are -
Class Description

String getValue() This function returns a value of the cookie.

void setValue(String s) This function sets the value to the cookie.

String getName() This function returns the name.

2) The HttpServlet class


 The HttpServlet class extends GenericServlet. It is used when developing servlets
that receive and process HTTP requests. Various methods of this class are -
Class Description

Void doGet(HttpServletRequest req, This method performs HTTP get request.


HttpServletResponse res)

Void doPost(HttpServletRequest req, This method performs HTTP Post request.


HttpServletResponse res)

Void doPut(HttpServletRequest req, This method performs HTTP Put request.


HttpServletResponse res)

Void service(HttpServletRequest req, This method is invoked for processing HTTP


HttpServletResponse res) request and response.

3) The HttpSessionEvent
 This method encapsulates the session event.
4) HttpSessionBindingEvent
 The HttpSessionBindingEvent class extends HttpSessionEvent. It is generated
when a listener is bound to a value. The getSession() method obtains the session to
which the listener is being bound or unbound.

3.7 Parameter Data


 Many times we need to pass some information from web browser to Web server. In
such case, the HTML document containing the FORM is written which sends the data
to the servlet present on the web server.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 21 Java Servlets and XML

 To make the form works with Java servlet, we need to specify the following attributes
for the <form> tag :
i) method=”method name”: To send the form data as an HTTP POST request to
the server.
ii) action=”URL/address of the servlet”: Specifies relative URL of the servlet which
is responsible for handling data posted from this form.
 The browser uses two methods to pass this information to web server. These methods
are GET Method and POST Method.
i) GET method : The GET method sends user information along with ? symbol
called query string. For instance
http://localhost/hello?user = aaaa&age = 20
In servlet, this information is processed using doGet() method.
ii) POST method : This is the most reliable method of sending user information to
the server from HTML form. Servlet handles this request using doPost method.

Difference between GET and POST


GET POST

Using GET request limited amount of Using POST large amount of information can be
information can be sent. sent.

GET request is not secured as This is a secured request.


information is visible in URL

This request is can be bookmarked. This request can not be bookmarked.

This request is more efficient. This request is less efficient.

How does servlet read form data ?


Servlet makes use of following three methods to read the data entered by the user on
the HTML form
1. getParameter() − You call request.getParameter() method to get the value of a
form parameter.
2. getParameterValues() − Call this method if the parameter appears more than
once and returns multiple values, for example checkbox.
3. getParameterNames() − Call this method if you want a complete list of all
parameters in the current request.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 22 Java Servlets and XML

Programming Examples
Example 3.7.1 Write a HTML that shows the following list :
C,C++,JAVA,C#
Define a form that contains a select statement and submit button. If the user selects the java
and press the submit the web page displays “The selected language is Java”.
Write a servlet program using HttpServlet and doGet method.

Solution :

 We will write two source files first one is the HTML file named test.html in which
the list of all the desired languages is displayed along with the submit button. User
has to select the language of his choice and then press the submit button.
 This data made by this request will be received by the servlet named
my_choiceservlet.java which reads the selected parameter and displays the
message about the selection made. The source files are as follows -

test.html
<html>
<body>
<center>
<form name="form1" method=GET
action="http://localhost:4040/servlets-examples/servlet/my_choiceservlet">
<b>Language:</b>
<select name="Language" size="1">
<option value="C">C</option>
<option value="C++">C++</option>
<option value="Java">Java</option>
<option value="C#">C#</option>
</select>
<br><br>
<input type="submit" value="Submit">
</form>
</body>
</html>

my_choiceservlet.java
import java.io.*;
importjavax.servlet.*;
importjavax.servlet.http.*;

public class my_choiceservlet extends HttpServlet


{
public void doGet(HttpServletRequestreq,HttpServletResponse res)

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 23 Java Servlets and XML

throwsServletException,IOException
{
String lang=req.getParameter("Language");
res.setContentType("text/html");
PrintWriter out=res.getWriter();
out.println("The selected language is "+lang);
out.close();
}
}

On clicking the submit button we will get following output.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 24 Java Servlets and XML

Example 3.7.2 Write HTML form to read user name and password. This data is sent to the
servlet. If the correct user name and password is given then welcome him/her by his/her
name otherwise display the message for invalid user.

Solution :

Step 1 : Create HTML form for accepting user name and password

Input.html
<html>
<head>
</head>
<body>
<form action="http://localhost/examples/servlets/servlet/Welcome" method ="get">
User Name:<input type="text" name="uname"/>
<br/>
Password:<input type="password" name="pwd"/>
<input type="submit" value="Submit"/>
</form>
</body>
</html>

Step 2 : Create the servlet program to read user name and password and validate it.

Welcome.java
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;

public class Welcome extends HttpServlet


{
public void doGet(HttpServletRequest req,HttpServletResponse res)
throws ServletException,IOException
{
PrintWriter out=res.getWriter();
res.setContentType("text/html");

String username=req.getParameter("uname");
String password=req.getParameter("pwd");
if ((username=="Ankita")&&(password=="1234"))
out.print("Welcome "+username);
else
out.println("Invalid username");
}
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 25 Java Servlets and XML

Example 3.7.3 Write a servlet which accept two numbers using POST methods and display the
maximum of them.

Solution :

Step 1 : The HTML document for inputting two numbers is as follows -

NumbersInput.html
<html>
<head>
<body>
<div align="center">
<br> <br>
<form action="http ://localhost/examples/servlets/servlet/MaxNumber" method="post">
Enter First Number :
<input type="text" value="" name="Number1" size=’5’>
<br/><br/> Enter Second Number :
<input type="text" value="" name="Number2" size=’5’>
<br/> <br/> <br/>
<input type="submit" value="Submit">
</form>
</div>
</body>
</html>
Step 2 : The servlet code that handles the post method and finds the maximum of the two
input numbers is as follows -

MaxNumber.java
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;

public class MaxNumber extends HttpServlet


{
protected void doPost(HttpServletRequest req, HttpServletResponse res) throws
ServletException, IOException
{
res.setContentType(“text/html”);
PrintWriter out=res.getWriter();

// get request parameters for userID and password


int a = Integer.parseInt(req.getParameter(“Number1"));
int b = Integer.parseInt(req.getParameter(“Number2"));

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 26 Java Servlets and XML

if (a>b)
out.println(“<h4>The maximum number is:”+a+"</h4>");
else
out.println(“<h4>The maximum number is :”+b+"</h4>");

}
}
Step 3 : The output is as follows -

Example 3.7.4 Write the code for converting currencies to US Dollar.

Solution :

Step 1 : We will write the simple HTML document, which will create the interface. The
user can select the type of currencies and will enter the value.
<html>
<body>
<formname="form1"method="post"
action="http://localhost/examples/servlets/servlet/DollarDemo">
Select the type of Currency:
<Select name="currency">
<option value="Euro">Euro</option>
<option value="Pound">Pound</option>
<option value="Rupees">Rupees</option>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 27 Java Servlets and XML

</select>
<br/> <br/>
Enter the value:
<input type="text" name="currencyVal" value=""/>
<br/> <br/>
<input type="submit" value="Submit"/>
</form>
</body>
</html>

Step 2 : The java servlet for converting the currency value to dollar is as given below -
import java.io.*;
import java.net.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class DollarDemo extends HttpServlet {
public void doPost(HttpServletRequest req,HttpServletResponse res)throws
ServletException,IOException,NullPointerException
{
res.setContentType("text/html");
PrintWriter out=res.getWriter();
String c=req.getParameter("currency");
double RupeeValue,EuroValue,PoundValue;
double DollarValue=0;
String value=req.getParameter("currencyVal");

if(c.equals("Rupees"))
{
RupeeValue=Double.parseDouble(value);
DollarValue=RupeeValue/61;
}
if(c.equals("Euro"))
{
EuroValue=Double.parseDouble(value);
DollarValue=EuroValue/0.77;
}
if(c.equals("Pound"))
{

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 28 Java Servlets and XML

PoundValue=Double.parseDouble(value);
DollarValue=PoundValue*1.62;
}
out.println("<p> The dollar value= "+DollarValue+"</p>");
out.close();
}
}

Output

3.8 Sessions
 When you open some application, use it for some time and then close it. This entire
scenario is named as session.
 Session state is a server-based state mechanism that lets web applications store and
retrieve objects of any type for each unique user session. That is, each browser session
has its own session state stored as a serialized file on the server, which is deserialized
and loaded into memory as needed for each request. Refer Fig. 3.8.1.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 29 Java Servlets and XML

 Because server storage is a finite resource, objects loaded into memory are released
when the request completes, making room for other requests and their session objects.
This means there can be more active sessions on disk than in memory at any one time.

Fig. 3.8.1 Session state

 Sometimes the information about the session is required by the server. This
information can be collected during the session. This process is called session tracking.
 There are three commonly used techniques used for session tracking and those are,
o Session ID
o Cookies
o URL Rewriting.

3.8.1 Session Management using Session ID


 HTTP is a stateless protocol in which each request is independent of the previous
request. And HTTP is a protocol using which user can interact with the server via web
browser and it cannot remember previously held communications but sometimes there
is serious need to keep track of previous communication sessions. This can be achieved
by session tracking.
 The session tracking technique is a mechanism by which we can keep track of
previous sessions between server and the browser.
 For sending all state information to and fro between browser and server, usually an ID
is used. This ID is basically a session-ID.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 30 Java Servlets and XML

 Thus session-ID is passed between the browser and server while processing the
information. This method of keeping track of all the information between server and
browser using session-ID is called session tracking.
 In servlets, for creating the sessions getSession() method can be used. This method
returns the object which stores the bindings with the names that use this object. And
these bindings can be managed using getAttribute(), setAttribute(), removeAttribute()
methods. Actually in session tracking two things are playing an important role -
1. One is HttpServletRequest interface which supports getSession() method.
2. The another class is HttpSession class which supports the binding managing
functions such as getAttribute(), setAttribute(), removeAttribute() and
getAttributeNames().
Let us first discuss the servlet program which returns the number of previous sessions
established between client and server. Note that any client can communicate with the
server using some web browser only!
Example 3.8.1 Write a servlet program to keep track of number of times user is visiting the
page. Display the count appropriately.

Solution : Servlet Program(SessionServletDemo)


import java.io.*;
import java.util.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class SessionServletDemo extends HttpServlet
{
public void doGet(HttpServletRequest req,HttpServletResponse res)
throws ServletException,IOException
{
res.setContentType("text/html");
HttpSession session=req.getSession();
String heading;
Integer cnt=(Integer)session.getAttribute("cnt");
if(cnt==null)
{
cnt=new Integer(0);
heading="Welcome You are accessing the page for the First Time";
}
else
{
heading="Welcome once again!";

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 31 Java Servlets and XML

cnt=new Integer(cnt.intValue()+1);
}

session.setAttribute("cnt",cnt);
PrintWriter out=res.getWriter();
out.println("<html>");
out.println("<head>");
out.println("</head>");
out.println("<body>");
out.println("<center>");
out.println("<h1>"+heading);
out.println("<h2> The number of previous access= "+cnt);
out.println("</center>");
out.println("</body>");
out.println("</html>");
}
}
Output
To get an output we will use following steps -
1. Compile the Servlet (i.e. a java program) using javac. This will generate a class
file.
2. Copy this class file to C:\your tomcat directory\examples-folder\WEB-INF\classes
3. Edit the web.xml file present at C:\your tomcat directory\examples-folder\WEB-
INF like this

<servlet>
<servlet-name>SessionServletDemo</servlet-name>
<servlet-class>SessionServletDemo</servlet-class>
</servlet>

<servlet-mapping>
<servlet-name>SessionServletDemo</servlet-name>
<url-pattern>/servlet/SessionServletDemo</url-pattern>
</servlet-mapping>
4. Start tomcat server.
5. Open the web browser and give the URL for SessionServletDemo. Following
output can be seen.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 32 Java Servlets and XML

If you simply refresh your browser either by pressing F5 or clicking the refresh button
then you will get following kind of output.

Program Explanation
1. Our class SessionServletDemo is inherited from HttpServlet class. And inside the
doGet() method we can create an object session of HttpSession class. This
method returns the current session for the corresponding request.
2. The getAttribute(string attribute) returns the value associated with the attribute.
We can pass this attribute as a parameter to this method. If there is no attribute
present then this method returns null. The data type of getAttribute() method is
void.
3. The setAttribute(string attribute, object value) is a method which assigns the
value passed as the object value to the attribute name. The data type of this
method is void.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 33 Java Servlets and XML

3.9 Cookies SPPU : Dec.-19, Marks 5

Definition : Cookies are some little information that can be left on your computer by
the other computer when we access an internet.
 Generally this information is left on your computer by some advertising agencies on
the internet. Using the information stored in the cookies these advertising agencies can
keep track of your internet usage, liking of users.
 For the applications like on-line purchase systems once you enter your personal
information such as your name or your e-mail ID then it can be remembered by these
systems with the help of cookies.
 Sometimes cookies are very much dangerous because by using information from your
local disk some malicious data may be passed to you. So it is upto you how to maintain
your own privacy and security.

3.9.1 Servlet Support for Cookies


 The cookie class is used to create cookies in servlet.
 Syntax : The Syntax for constructor for cookies are,
o Cookie()
o Cookie(String name, String value)
 Various methods used in Cookie are described in following table
Sr. No. Method Purpose

1. public string getName() It returns the name of the cookie.

2. public String getValue() It returns the value of the cookie.

3. public string setName() It sets or changes the name of the cookie.

4. public String setValue() It sets or changes the value of the cookie.

5. public void addCookie(Cookie c) The cookie is added in the response object of


HttpServletResponse interface.

6. public Cookie[] getCookies() All the cookies can be returned using this method
with the help of HttpServletRequest interface.

 In Servlet following steps are used to support for cookies

Step 1 : Creation of Cookies :


The cookie can be created in Servlet and added to response object using addCookie
method

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 34 Java Servlets and XML

Cookie cookie=new Cookie("user","XYZ");//creating cookie object


response.addCookie(cookie);//adding cookie in the response

Step 2 : Reading Cookies :


The value from the cookie can be obtained using the getName() and getValue()
methods.
Cookie[ ] my_cookies=req.getCookies();
int n=my_cookies.length;
for(int i=0;i<n;i++)
{
String name=my_cookies[i].getName();
String value=my_cookies[i].getValue();
}

3.9.2 Examples
Below is simple HTML form in which a servlet is invoked. This servlet creates a cookie
by the name My_Cookie and stores the value entered by you in the textbox of HTML
form. You can further get the information stored in the cookie by another servlet program
getCookieServlet. Hence we will write three programs -
1. Our normal HTML script in which some value is entered in the textbox.
2. The servlet program named mycookieservlet which will set a cookies and take
the value entered by you in the HTML form.
3. The another servlet program named getCookieServlet which helps us to view the
cookie.

HTML Program
<html>
<head>
<title>Demo of Cookie</title>
</head>
<body>
<form name="form1" method="post"
action="http ://localhost:8080/examples/servlet/mycookieservlet">
<h3> Enter the value for my Cookie: </h3>
<input type=text name="txt_data" size =30 value=" ">
<input type=submit value="Submit">
</form>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 35 Java Servlets and XML

Servlet Program [mycookieservlet.java]


import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class mycookieservlet extends HttpServlet
{
public void doPost(HttpServletRequest req,HttpServletResponse res)
throws ServletException, IOException
{
String txt_data = req.getParameter("txt_data");
// Create cookie.
Cookie cookie = new Cookie("My_Cookie", txt_data);
// Adding cookie to HTTP response.
res.addCookie(cookie);
// Write friendly output to browser.
res.setContentType("text/html");
PrintWriter out = res.getWriter();
out.println("<h2>MyCookie has been set to : ");
out.println(txt_data);
out.println("<br><br><br>");
out.println("This page shows that the cookie has been added");
out.close();
}
}
We have first created an object of Cookie class using which the cookie can be added
using addCookie() method.
Servlet Program[getcookieservlet.java]

import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class getCookieServlet extends HttpServlet
{
public void doGet(HttpServletRequest req,HttpServletResponse res)
throws ServletException,IOException
{
Cookie[ ] my_cookies=req.getCookies();
res.setContentType("text/html");
PrintWriter out=res.getWriter();
out.println("<b>");
int n=my_cookies.length;
for(int i=0;i<n;i++)
{

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 36 Java Servlets and XML

String name=my_cookies[i].getName();
String value=my_cookies[i].getValue();
out.println("name= "+name);
out.println("and value= "+value);
}
out.close();
}
}
In the above program using getName() and getValue() functions we can get the name
of the cookie as well as the value of the cookie respectively. The output of all the above
given three programs is as given below -
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 37 Java Servlets and XML

Example 3.9.1 Write a program that allows the user to select a favorite programming language
and post the choice to the servlet. The response is a web page in which user can click a link to
view list of book recommendations. The cookies previously stored on the client are read by the
servlet and form a web page containing the book recommendation. Use servlet, cookies and
HTML.

Solution :

Step 1 : Create an HTML page which allows the user to select the favourite programming
language. The user can submit his choice by clicking the submit button.

InputForm.html
<html>
<body>
<form name="form1" method="post"
action="http://localhost/examples/servlets/servlet/MyProgram">
<h3> Enter the favourite Programming Language: </h3>
<select name="Lang_ch">
<option value="C++">C++</option>
<option value="Java">Java</option>
<option value="PHP">PHP</option>
</select>
<input type=submit value="Submit">
</form>
</body>
</html>

Step 2 : Now create a web servlet program which reads the choice of programming
language and set this choice as cookie. The web page containing a hyperlink is created in
this servlet program. The code for this Servlet program is as follows -

MyProgram.java
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class MyProgram extends HttpServlet
{
public void doPost(HttpServletRequest req,HttpServletResponse res)
throws ServletException, IOException
{
String choice = req.getParameter("Lang_ch");
// Create cookie.
Cookie cookie = new Cookie("My_Cookie", choice);

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 38 Java Servlets and XML

// Adding cookie to HTTP response.


res.addCookie(cookie);
// Write friendly output to browser with web link
res.setContentType("text/html");
PrintWriter out = res.getWriter();
out.println("<a href='ReadChoice'><p>Click Here to read about your
favorite programming language </p></a>");
out.println("<br><br><br>");
out.println("This page shows that the cookie has been added");
out.close();
}
}
Step 3 : On clicking the hyperlink present in the above servlet, we can read the value of
cookie(which is actually the name of the favorite programming language). The following
program displays the recommended book for the programming language you have
chosen. The code is as follows -
ReadChoice.java
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class ReadChoice extends HttpServlet
{
public void doGet(HttpServletRequest req,HttpServletResponse res)
throws ServletException,IOException
{
Cookie[] my_cookies=req.getCookies();
res.setContentType("text/html");
PrintWriter out=res.getWriter();
out.println("<b>");
int n=my_cookies.length;
for(int i=0;i<n;i++)
{
String name=my_cookies[i].getName();
String value=my_cookies[i].getValue();
if(value.equals("PHP"))
{
out.println("<b>Programming Language: </b>"+value);
out.println("<br/><b>Book Name: </b>"+"PHP and MySQL Web
Development by Luke Welling and Laura Thompson");
}
else if(value.equals("Java"))
{
out.println("<b>Programming Language: </b>"+value);

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 39 Java Servlets and XML

out.println("<br/><b>Book Name: </b>"+"The Complete


Reference Java");
}
else
{
out.println("<b>Programming Language: </b>"+value);
out.println("<br/><b>Book Name: </b>"+"C++
Programming Language by Bjarne Stroustrup");
}
}
out.close();
}
}
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 40 Java Servlets and XML

Review Question

1. Explain session and cookies in servlets ? Write any one program to demonstrate session or
cookies SPPU : Dec.-19, Marks 5

3.10 URL Rewriting


This is more precise technique in which information is embedded into URL. For
instance.

The server then repsonds by putting sid=xf1234ad in response body.

The browser will demand for the required web page by putting the same URL string in
the request.

When browser makes requests for another page same URL is embedded. There by
server will come to know that the request is related to previous page and the work in
same session will get co-related.
We can send the name-value pair from one page to another using URL rewriting
method. In this method the token of name-value pair can be added at the end of URL.
The URL writing occurs in the following format

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 41 Java Servlets and XML

The parameter sent by the URL is obtained at the server side by getParameter method.
The syntax of this method is
String getParameter(String)

Example 3.10.1 Write a servlet that Welcomes the user by his/her name only if the valid
password is entered by the user. Make use of URL rewriting method.

Solution :

Step 1 : Create a registration form. I have named it as registration.html. The code for it is
as follows :

registration.html
<!doctype html>
<html>
<head>
<title> Demo For URL Rewriting </title>
<body>
<form method ="post" action="http://localhost/examples/servlets/servlet/firstpg">
User:<input type ="text" name="user" ><br/>
Password:<input type ="password" name="pwd"> <br/><br/>
<input type="submit" value="Submit">
</form>
</body>

Step 2 : Create a servlet program that reads the user name and password values entered
by the user. This servlet also compares the entered password with the valid password. If
the user enters valid password, then the request is redirected to another servlet page.
Otherwise wrong password message will be displayed. The first servlet is,

firstservlet.java
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class firstpg extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 42 Java Servlets and XML

response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
String uname = request.getParameter("user");
String pass = request.getParameter("pwd");
if(pass.equals("password"))
{
response.sendRedirect("secondpg?user_name="+uname+"");
}
else
out.println("<i> You have entered wrong password!!!</i>");
}
}

Step 3 : If user enters the valid password, then he/she is redirected to main page. This
page welcomes him/her by his/her name. The code for this servlet is as follows -

secondpg.java
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class secondpg extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {

response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
String user = request.getParameter("user_name");
out.println("<h3>Welcome "+user+" to main page!!!</h3>");
}
}

Step 4 : Compile the java files created in step 2 and step 3. Copy the class files to classes
folder of Tomcat's WEB-INF folder. Modify the web.xml file as follows -
<?xml version="1.0" encoding="ISO-8859-1"?>
...
<servlet>
<servlet-name>firstpg</servlet-name>
<servlet-class>firstpg</servlet-class>
</servlet>
<servlet>
<servlet-name>secondpg</servlet-name>
<servlet-class>secondpg</servlet-class>
</servlet>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 43 Java Servlets and XML

<servlet-mapping>
<servlet-name>firstpg</servlet-name>
<url-pattern>/servlets/servlet/firstpg</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>secondpg</servlet-name>
<url-pattern>/servlets/servlet/secondpg</url-pattern>
</servlet-mapping>
</web-app>
Start the Tomcat web server.
Open the suitable web browser and invoke the HTML document as given in Step 1.
The output will be,

On clicking submit button we will get the following page on valid password

URL Rewriting with name as


“user_name and value as “Shilpa”

3.11 Other Servlet Capabilities


In this section we will discuss various methods of HttpServletRequest and
HttpServletResponse class.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 44 Java Servlets and XML

3.11.1 Additional HttpServletRequest Method


HttpServletRequest interface adds the methods that relates to the HTTP protocol.
Following table lists various useful methods of HttpServletRequest
Method Description

String getRemoteAddr() This method returns IP address of the client who is making the
request.

String getRemoteHost() This method returns the name of the client who is making the
request.

String getProtocol() This method returns the name of the protocol, client is using.

String getHeader(String field) When the field name is given the value for the header is returned.

StringBuffer getRequestURL() This method returns the String containing the URL which is used to
access the servlet. This string does not contain the query string
appended to URL.

3.11.2 Additional HttpServletResponse Method


 HttpServletResponse interface adds the methods that relate to the HTTP response.
It extends the ServletResponse interface.
 Following table lists various useful methods of HttpServletResponse
Methods Description

void addCookie(Cookie cookie) Adds the specified cookie to the response.

void sendRedirect(String location) Sends a temporary redirect response to the client using
the specified redirect location URL and clears the
buffer.

int getStatus() Gets the current status code of this response.

String getHeader(String name) Gets the value of the response header with the given
name.

void setHeader(String name, String value) Sets a response header with the given name and value.

void setStatus(int sc) Sets the status code for this response.

void sendError(int sc, String msg) Sends an error response to the client using the specified
status and clears the buffer.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 45 Java Servlets and XML

Example Program

Step 1 :
<html>
<head>
</head>
<body>
<form action="http://localhost:8080/examples/servlets/servlet/ClientAddressServlet"
method ="get">
User Name:<input type="text" name="uname"/>
<input type="submit" value="Submit"/>
</form>
</body>
</html>

Step 2 :

ClientAddressServlet.java
import javax.servlet.*;
import javax.servlet.http.*;
import java.io.*;
public class ClientAddressServlet extends HttpServlet
{
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException
{
// Get client's IP address
String name = request.getParameter("uname");
String clientIP = request.getRemoteAddr();
// Get client's host name
String clintHost = request.getRemoteHost();
String queryString = request.getQueryString();
String protocol = request.getProtocol();
int localPort = request.getLocalPort();
response.setContentType("text/plain");
PrintWriter out = response.getWriter();

out.println("Name : " + name);


out.println("IP : " + clientIP);
out.println("Host: " + clintHost);
out.println("QueryString: "+queryString);
out.println("Local Port: "+localPort);
out.println("Protocol: "+protocol);
}
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 46 Java Servlets and XML

Output

Program Explanation : In above program,


1. In step 1 we have created an HTML form on which there is one text box and one
submit button. The name entered in the textbox is identified by the parameter
uname.
2. In step 2, we have two objects - request and response. These are basically the
objects of HttpRequest and HttpResponse classes.
3. Using request.getParameter method we invoke the uname parameter. By this,
we can access the user name entered by the user in step 1.
4. In the above program, we have used getRemoteAddr(), getRemoteAddr(),
getProtocol() methods and display the corresponding information on the web
browser.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 47 Java Servlets and XML

3.12 Data Storage


 Typical web application contains the HTML documents that often interact with
some form of data storage. This data storage can be a file system or a database
management system.
 The efficient use of file system or database management system is required by every
web application.
 There are two commonly used techniques for data storage - Java Object
Serialization and Java Database Connectivity(JDBC)
 Serialization in Java is a mechanism of writing the state of an object into a byte-
stream.
 JDBC is an API used to assist the Java programs to interact with the database
management systems(popularly handled using MySQL)
 Following is an example program that shows serialization in Java.
Serialization is the process of writing the state of the object to the byte stream. This
technique is useful when we want to store the current state of the object to the File. For
serialising the object we need to implement serializable interface. This interface does not
define any member.

Java Program[SerializProg.java]
import java.io.*;
class SerializProg
{
public static void main(String[] args)throws ClassNotFoundException,IOException
{
Myclass myobject=new Myclass("Parth",10);//creating the object
System.out.println("The object is: "+myobject);//displaying the contents of the object
ObjectOutputStream o=new ObjectOutputStream(new FileOutputStream("object.txt"));
o.writeObject(myobject);//writing the object to a file
o.flush();
o.close();
ObjectInputStream i=new ObjectInputStream(new FileInputStream("object.txt"));
Myclass newobject=(Myclass)(i.readObject());//reading the object from the file
i.close();
System.out.println("\nYou have stored :"+newobject);//displaying the object's value
}
static class Myclass implements Serializable
{
String name; Implements the serializable interface
int roll;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 48 Java Servlets and XML

public Myclass(String n,int r)


{
this.name=n;
this.roll=r;
}
public String toString()
{
return "name= "+name+" and roll= "+roll;
}
}
}
Output

Program Explanation
In above program,
1. We have created an object of class named Myclass. The members of this class are
name and roll number.
2. From the main function assigns the values to these members. This object is
written to the file named object.txt using the writeObject method.
3. Later on the value of this object can be read using the readObject method.
4. For the creation of the object we have to define a class who implements the
Serializable interface.
5. It is necessary to throw the exceptions ClassNotFoundException and
IOException

3.13 Servlets and Concurrency


 Concurrency allows multiple users to access the system. It also allows system
programs to execute concurrently. Also, the web applications implement the
concurrency. For instance, when web browser is loading some image, at the same
time it also responds to mouse clicks. This type of concurrency is achieved at the
client end in client's browser.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 49 Java Servlets and XML

 On the server side the situation is different. There can be hundreds or even
thousands of users simultaneously accessing a web site.
 Concurrent web servers handle multiple users as follows - It begins with one
servlet, executes some instruction, then suspends it for a while and start executing
the other servlet. Eventually completes the second servlet and returns back to first
servlet to execute the remaining instructions. Refer Fig. 3.13.1.

Fig. 3.13.1 Concurrency achieved by web server

Concept of Thread :
 Thread is a light weight process. It is used for concurrent execution of the tasks.
 The Java Virtual Machine maintains a data structure containing the information
about each thread. The server creates a thread for each HTTP request. The data
structure maintains the information about the state of the thread along with the
references to the HttpServletRequest and HttpServletResponse objects created by
the server.
 The Java Virtual Machine also maintains the information whether the particular
thread is currently running or not.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 50 Java Servlets and XML

 When one thread is suspended then the state of other executing thread is loaded
into Java Virtual Machine.
 Following example shows the concurrent execution of the servlet with the help of
threads

Step 1 :
<HTML>
<BODY>
<TABLE>
<TR>
<TD>
<a href ="http://localhost:8080/examples/servlets/servlet/SimpleServlet">servlet1</a>
</TD>
</TR>
<TR>
<TD>
<a href ="http://localhost:8080/examples/servlets/servlet/SimpleServlet">servlet2</a>
</TD>
</TR>
<TR>
<TD>
<a href ="http://localhost:8080/examples/servlets/servlet/SimpleServlet">servlet3</a>
</TD>
</TR>
</TABLE>
</BODY>
</HTML>

Step 2 :
import java.io.IOException;
import javax.servlet.*;
import javax.servlet.http.*;
import java.math.*;
public class SimpleServlet extends HttpServlet
{

public void doGet(HttpServletRequest req, HttpServletResponse resp)


throws ServletException, IOException
{
doPost(req, resp);
}
public void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 51 Java Servlets and XML

{
int counter = 0;
resp.getWriter().println(this);
for (int i = 0; i < 10; i++)
{
resp.getWriter().println("Counter = " + counter);
try
{
Thread.currentThread().sleep((long) Math.random() * 1000);
counter++;
}
catch (InterruptedException exc) { }
}
}
}
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 52 Java Servlets and XML

3.14 Databases (MySQL) and Java Servlets


JDBC is a Java API for database access. A servlet can connect to MYSQL and sends the
SQL commands to the database and get the required data. Hence we will first get
introduced with structured query language SQL.

3.14.1 Structured Query Language using MySQL


The MYSQL is a open source database product which can be downloaded from the
web site.
After getting installed on the machine the command prompt window for MYSQL can
appear. The screenshot is as follows -

Now let us go through some MYSQL query statements which are required while
handling the database.
1. Creating database
mysql> CREATE DATABASE mydb;
Query OK, 1 row affected (0.15 sec)

2. Displaying all the databases


mysql> SHOW DATABASES;
+-------------+
| Database |
+-------------+
| mydb |
| mysql |
| students |
| test |
+--------------+
4 rows in set (0.06 sec)

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 53 Java Servlets and XML

3. Selecting particular database


mysql> USE MYDB;
Database changed

4. Creating table
We must create a table inside a database hence it is a common practice to use create
table command after USE database command. While creating a table we must specify the
table fields.
mysql> CREATE TABLE my_table(id INT(4),name VARCHAR(20));
Query OK, 0 rows affected (0.28 sec)
Use of Primary Key : The primary key contains the unique value. The primary key
column can not contain NUL value. Each table can have only one primary key. Following
is a SQL statement used to create PRIMARY KEY.
CREATE TABLE student_table(
roll_no INT(4) NOT NULL AUTO_INCREMENT,
name VARCHAR(50) NOT NULL,
address VARACHAR(50) NOT NULL,
PRIMARY KEY(roll_no)
);
In above example the roll_no acts as a primary key for the student_table.
5. Displaying a table
After creating the table using SHOW command we can see all the existing tables in the
current database.
mysql> SHOW TABLES;
+-----------------------+
| Tables_in_mydb |
+-----------------------+
| my_table |
+-----------------------+
1 row in set (0.00 sec)

6. Displaying the table fields


For knowing the various fields of the table we may use following command
mysql> DESCRIBE my_table;
+---------+----------------+--------+------+---------- +---------+
| Field | Type | Null | Key | Default | Extra |
+---------+----------------+--------+------+-----------+--------+
| id | int(4) | YES | | NULL | |
| name | varchar(20) | YES | | NULL | |
+---------+----------------+--------+------+---------- +-------- +
2 rows in set (0.07 sec)

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 54 Java Servlets and XML

7. Inserting values into the table


We can insert only one complete record at a time. It is as shown below -
mysql> INSERT INTO my_table
-> VALUES(1,'SHILPA');
Query OK, 1 row affected (0.05 sec)

8. Displaying the contents of the table


mysql> SELECT * FROM my_table;
+------+------------+
| id | name |
+------+------------+
| 1 | SHILPA |
+-------+------------+
1 row in set (0.06 sec)
We can also write SELECT statement for selecting particular row by specifying some
condition such as -
mysql> SELECT * FROM my_table where id=1;
or
mysql> SELECT * FROM my_table where name=’SHILPA’;
Thus we can insert the rows into the table by repeatedly giving the INSERT command.
If we want to get the records in sorted manner then we use ORDER BY clause
mysql> SELECT * FROM my_table;
+-------+---------------+
| id | name |
+-------+---------------+
| 1 | SHILPA |
| 2 | SUPRIYA |
| 3 | YOGESH |
| 4 | MONIKA |
+-------+---------------+
4 rows in set (0.00 sec)
mysql> SELECT * FROM my_table ORDER BY name;
+------+-------------+
| id | name |
+------+-------------+
| 4 | MONIKA |
| 1 | SHILPA |
| 2 | SUPRIYA |
| 3 | YOGESH |
+------+-------------+
4 rows in set (0.00 sec)

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 55 Java Servlets and XML

9. Updating the record


For updating the record in the database following command can be used -
mysql> UPDATE my_table
-> SET name='PRIYANKA'
-> WHERE id=4;
Query OK, 1 row affected (0.05 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> SELECT * FROM my_table;
+------+--------------+
| id | name |
+-----+---------------+
| 1 | SHILPA |
| 2 | SUPRIYA |
| 3 | YOGESH |
| 4 | PRIYANKA |
+-----+---------------+
4 rows in set (0.00 sec)

10. Deleting record


For deleting particular record from a database
mysql> DELETE FROM my_table
-> WHERE id=3;
Query OK, 1 row affected (0.04 sec)
Then use SELECT statement for displaying the contents of the table we use following
command
mysql> SELECT * FROM my_table;
+------+---------------+
| id | name |
+------+---------------+
| 1 | SHILPA |
| 2 | SUPRIYA |
| 4 | PRIYANKA |
+------+---------------+
3 rows in set (0.00 sec)

11. For deleting the table


The table can be deleted using the command
mysql>drop table my_table;

12. Inner join


This query used to display the result from both the tables when at least one column
from both the tables is matching -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 56 Java Servlets and XML

For example
Consider table Customer
Cust_Id Name City
1 Rahul Bombay
2 Priyanka Pune
3 Supriya Banglore

Consider table Order


Order_Id Cust_Id Order_Number
10 3 1234
20 1 5678
30 1 8900

Then we can make use of inner join query as follows -


SELECT Customer.Name, Customer.city, Order.Order_Number
FROM Customer
INNER JOIN Order
ON Customer.Cust_Id=Order.Order_Id
Name City Order_Number
Rahul Bombay 5678
Rahul Bombay 8900

13. Order by clause


If we want to get the records in sorted manner then we use ORDER BY clause
mysql> SELECT * FROM my_table;
id name
1 SHILPA
2 SUPRIYA
3 YOGESH
4 MONIKA
mysql> SELECT * FROM my_table ORDER BY name;

id name

4 MONIKA

1 SHILPA

2 SUPRIYA

3 YOGESH

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 57 Java Servlets and XML

3.14.2 JDBC Perspectives


 JDBC stands for Java DataBase Connectivity.
 JDBC is nothing but an API (i.e. Application Programming Interface).
 It consists of various classes, interfaces, exceptions using which Java application can
send SQL statements to a database. The SQL is a Structured Query Language used for
accessing the database.
 JDBC is specially used for having connectivity with the RDBMS packages (such as
Oracle or MYSQL) using corresponding JDBC driver.
The JDBC API is a set of classes, interfaces and exceptions used for establishing
connection with data source. This JDBC API is defined in the java.sql and javax.sql
packages. We use following core JDBC classes and interfaces that belong to java.sql
package.
 DriverManager - When Java application needs connection to the database it invokes
the DriverManager class. This class then loads JDBC drivers in the memory. The
DriverManager also attempts to open a connection with the desired database. For JSP-
MYSQL connectivity we can get DriverManager class as -
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
1) Connection - This is an interface which represents connectivity with the data source.
The connection is used for creating the Statement instance.
Connection conn=
DriverManager.getConnection("jdbc:mysql://localhost:3306/databaseName",
"userName","password");
2) Statement - This interface is used for representing the SQL statements. Some
examples of SQL statements are,
o SELECT * FROM students_table;
o UPDATE students_table set name=’Neel’ where roll_no=’1’;
o DELETE from students_table WHERE roll_no=’10’;
The code for statement is as follows -
Statement stmt=conn.createStatement();
stmt.executeQuery("select * from mytab");
There are two specialised Statement types: PreparedStatement and
CallableStatement. The PreparedStatement represents the precompiled SQL statements.

For instance :
SELECT * from students_table WHERE name=?

The placeholder represented by ? is used in this type of statement. There are special
type setter methods that assign the values to the placeholders before the SQL statement is
executed.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 58 Java Servlets and XML

CallableStatement is represents the stored procedures. These are similar to


PreparedStatement. In this type of Statements we can assign the methods for the types of
output arguments.

3) ResultSet - This interface is used to represent the database result set. After using
SELECT SQL statement, the information obtained from the database can be
displayed using ResultSet.
4) SQLException - For handling SQL exceptions this interface is used.

3.14.2.1 How JDBC Works ?

Following is a way by which JDBC works -

1) First of all Java application establishes connection


with the data source.
2) Then Java application invokes classes and interfaces
from JDBC driver for sending queries to the data
source.
3) The JDBC driver connects to corresponding database
and retrieves the result.
4) These results are based on SQL statements which are
then returned to Java application. Fig. 3.14.1 Role of JDBC
5) Java application then uses the retrieved information
for further processing.

3.14.2.2 Difference between JDBC and ODBC


The JDBC is similar to the ODBC i.e. Open Database Connectivity. But the ODBC is
used for managing any kind of database and JDBC is specially created to support the Java
programs.

3.14.2.3 Uses of JDBC


1. JDBC helps the client to store and retrieve the data to the databases.
2. JDBC allows the client to update the databases.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 59 Java Servlets and XML

3.14.3 Steps for Connectivity between Servlet and Database


Following steps are used to connect JDBC to MYSQL

Step 1 : Import java.sql.* package in the JDBC program


Following line can be included in your JDBC program at the beginning.
import java.sql.*

Step 2 : Load JDBC Driver.


The JDBC driver for MYSQL can be loaded using following statement
Class.forName("com.mysql.jdbc.Driver");

Step 3 : Get connection using the Driver Manager


conn =
riverManager.getConnection("jdbc:mysql://localhost:3306/my_database","root","password");

Step 4 : Create Statement


stmt = conn.createStatement();

Step 5 : Execute Query


String sql = "SELECT Roll,StudName FROM my_table";
ResultSet rs = stmt.executeQuery(sql);

Step 6 : Display the result

Example 3.14.1 Explain the JDBC URL with appropriate examples.

Solution : JDBC URL with examples : The databases are referenced by Java runtime
engine using JDBC URL. The syntax of these URLs depends on the database driver you
are using.
The list of common drivers along with JDBC URL is,
1. ODBC Driver
Syntax :
jdbc:odbc:<data source name>
Example :
jdbc:odbc:MyDataSource

2. MYSQL
Syntax :
jdbc:mysql://[host][:port]/[database]
Example :
jdbc:mysql://localhost:3306/Mydatabase

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 60 Java Servlets and XML

3. ORACLE
Syntax :
jdbc:oracle:<drivertype>:<user>/<password>@<database>
Example :
jdbc:oracle:thin:myuser/mypassword@localhost:mydatabse

3.14.4 Implementation

Prerequisite : We need following things for connecting to database using JDBC


1. MySQl is already installed and required database is created.
2. JDK is installed.
3. A database connector mysql-connector-java-X.X.XX-bin must be downloaded
and present at the path
C:\your_tomcat_directory\common\lib
4. Tomcat is running.
For connecting java application with the mysql database, following steps are needed to
follow -
1. Driver class : The driver class for the mysql database is com.mysql.jdbc.Driver.
Here we can instantiate the object for JDBC driver by using following statement.
Class.forName("com.mysql.jdbc.Driver");
2. Connection URL : The connection URL for the mysql is
databases jdbc:mysql://localhost:3306/my_database
Where
jdbc is the API,
mysql is the database,
localhost is the server name on which mysql is running, we may also use IP address,
3306 is the port number
my_database is the database name. (We may use any database, in such case, you need
to replace the my_database with your database name.)

Username : The default username for the mysql database is root. If you haven't set any
user name it could be blank.

Password : Password is given by the user at the time of installing the mysql database.
 The connection URL can be obtained using the method getConnection. This
method is defined in class named DriverManager. Note that this DriverManager
class is defined in java.sql.* package. We can obtain the instance for connection
using following statement,

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 61 Java Servlets and XML

conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/my_database","","");
Let us understand this with the help of examples.
Example 3.14.2 Write a Servlet program to connect to a MySQL database. Create a student
database named StudentDB.

Solution :
1. Create a StudentDB in MySQL using following query
create database StudentDB;
2. The Servlet program can be written as follows
import java.io.*;
import java.sql.Connection;
import java.sql.DriverManager;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class ServletDemo extends HttpServlet {


public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html");
PrintWriter out = response.getWriter();
try {
Class.forName("com.mysql.jdbc.Driver");
Connection con =
DriverManager.getConnection("jdbc:mysql://localhost:3306/StudentDB","","");
Statement stmt = con.createStatement();
out.print("You are successfully Connected to Database...");
}
catch (SQLException e) {
throw new ServletException("Could not display records.", e);
}
catch (ClassNotFoundException e) {
throw new ServletException("JDBC Driver not found.", e);
}
out.close();
}
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 62 Java Servlets and XML

Example 3.14.3 Create a students database in any relational database package. The table which
you create in this database must have following fields - Roll_No, name, address and phone.
The Roll_No must be a primary key. You have to create a servlet at the fornt end which will
perform following operations - 1. Insertion of record 2. Deletion of the record using the
primary key 3. Updation on any one field of the record. 4. Display of all the records from
the database.

Solution : We will perform following steps -

Step 1 : First of all we will create a database named students and then create a table
named students_table in this database in MYSQL. This can be down using following SQL
commands -
mysql>CREATE DATABASE students;
mysql>use students;
mysql>create table students_table(Roll_no INT(4) NOT NULL AUTO_INCREMENT,name
VARCHAR(50) NOT NULL,address VARCHAR(30) NOT NULL,phone VARCHAR(11) NOT
NULL,PRIMARY KEY(Roll_no));
Now we have simply created a table without any content within it. Our intention is to
insert the records in this table using the front end - servlet program.

Step 2 : The first page of this application will be Databasedemo.html. The code for this
html document will be as given below -

DatabaseDemo.html
<html>
<head>
<title>Database Connectivity using JDBC</title>
</head>
<frameset rows="100,*">
<framesrc="http://www.localhost.com:4040/servlets-examples/Head.html"
name="top_frame">
<frameset cols="200,*">
<framesrc="http://www.localhost.com:4040/servlets-examples/Menu.html"
name="left_frame">
<framesrc="http://www.localhost.com:4040/servlets-examples/display.html"
name="right_frame">
</frameset>
</frameset>
</html>
The Databasedemo.html will simply provide the initial interface for this application.
This HTML document consists of three frames. The top frame will simply display the
name of the application. The left frame consists of another html page in which the four

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 63 Java Servlets and XML

links for each operation are specified. Each link will be a separate servlet program
communication with the database. The right frame will display the results of each
operation.
The output will be as follows -

Step 1 : Open the DatabaseDemo.html web page by giving the path for this html file on
the address bar of Internet explorer -

Head.html

Menu.html
display.html

Head.html
<html>
<head>
<title>Database Connectivity</title>
</head>
<body>
<center><h1>Operations on Student Database</h1></center>
</body>
</html>
Menu.html
<html>
<body>
<h2> Main Menu</h2>
<h3>
<a href="http://www.localhost.com:4040/servlets-examples/servlet/Insert_Query"
target="right_frame">Insert Record</a>
<br/>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 64 Java Servlets and XML

<a href="http://www.localhost.com:4040/servlets-examples/servlet/Delete_Query"
target="right_frame">Delete Record</a>
<br/>
<a href="http://www.localhost.com:4040/servlets-examples/servlet/Update_Query"
target="right_frame">Update Record</a>
<br/>
<a href="http://www.localhost.com:4040/servlets-examples/servlet/ServletDBDemo"
target="right_frame">Display Records</a>
</h3>
</body>
</html>
display.html
<html>
<body>
<p> This is a demo application for database connectivity</p>
<p>This connectivity is between Servlet and MYSQL</p>
<p>Just click the links given in left frame and the corresponding form will
appear in the right frame for inputting the values to perform the desired operation
</p>
</body>
</html>

Step 3 : The top frame simply displays the name of the application the left frame displays
the various operations that can be performed on the database. There are four sample
operations like insertion, deletion, updation and displaying of data from the database.
Just click on corresponding links to get the desired operation done. For instance I have
clicked on Insert Record hyperlink and in the right frame a form appears. Fill up this
form and then click the Submit button.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 65 Java Servlets and XML

A servlet named Insert_Query.java is for inserting a record in the database. It is as


follows -
Insert_Query.java
import java.io.*;
import java.util.*;
import javax.sql.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class Insert_Query extends HttpServlet


{
public void service(HttpServletRequest request,HttpServletResponse response)
throws IOException, ServletException
{
response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.println("<html>");
out.println("<head><title>Servlet Database Connectivity</title></head>");
out.println("<body>");
out.println("</body></html>");
// connecting to database
Connection con = null;
Statement stmt = null;
ResultSet rs = null;
try
{

Class.forName("com.mysql.jdbc.Driver");
con=DriverManager.getConnection("jdbc:mysql://localhost:3306/students","root", "system");
stmt = con.createStatement();

out.println("\n\n");
String Studname=request.getParameter("Sname");
String Studaddress=request.getParameter("Sadd");
String Studphone=request.getParameter("Sph");
if(Studname!=null&&Studaddress!=null&Studphone!=null)
if(Studname.length()>0)
stmt.executeUpdate("insert into students_table(name,address,phone)
values('"+Studname+"','"+Studaddress+"','"+Studphone+"')");

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 66 Java Servlets and XML

rs=stmt.executeQuery("select * from students_table");


out.println("<html>");
out.println("<body>");
out.println("<form action='Insert_Query' method='post'>");
out.println("<strong>Name: </strong><input name='Sname' type='text'>");
out.println("<br/>");
out.println("<strong>Address: </strong><input name='Sadd' type='text'>");
out.println("<br/>");
out.println("<strong>Phone: </strong><input name='Sph' type='text'>");
out.println("<br/><br/>");
out.println("<input type='submit' value='Submit'>");
out.println("</form>");
out.println("</body>");
out.println("</html>");

}catch (SQLException e)
{
throw new ServletException("Servlet Could not display records.", e);
}
catch (ClassNotFoundException e)
{
throw new ServletException("JDBC Driver not found.", e);

}
finally
{
try
{
if(rs != null)
{
rs.close();
rs = null;
}
if(stmt != null)
{
stmt.close();
stmt = null;
}
if(con != null)
{
con.close();
con = null;
}
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 67 Java Servlets and XML

catch (SQLException e) {}
}//end of finally
out.close();
}//end of service function
} //end of class
Now save this program at the path
C://your_tomcat_directory/webapps/servlets-examples/WEB-INF/classes
Then compile the above code using following command at this path -
javac Insert_Query.java
If the code is error free then a class file named Insert_Query.class gets generated at the
above mentioned path.
Now edit the web.xml file present in the ../servlets-examples/WEB-INF directory as
follows [Note that at two fragments of code must be added in the web.xml file which are
given below]
<servlet>
<servlet-name>Insert_Query</servlet-name>
<servlet-class>Insert_Query</servlet-class>
</servlet>



<servlet-mapping>
<servlet-name>Insert_Query</servlet-name>
<url-pattern>/servlet/Insert_Query</url-pattern>
</servlet-mapping>
Save and close this web.xml file.
The other operations can be performed using following servlet programs. What you
need to do is create the following files in Notepad, execute them individually using javac
command and then edit the web.xml file by specifying the name of corresponding servlet.
Delete_Query.java
import java.io.*;
import java.lang.*;
import java.util.*;
import javax.sql.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 68 Java Servlets and XML

public class Delete_Query extends HttpServlet


{
public void service(HttpServletRequest request,HttpServletResponse response)
throws IOException, ServletException,NumberFormatException
{
response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.println("<html>");
out.println("<head><title>Servlet Database Connectivity</title></head>");
out.println("<body>");
out.println("</body></html>");
// connecting to database
Connection con = null;
Statement stmt = null;
ResultSet rs = null;
try
{
Class.forName("com.mysql.jdbc.Driver");
con = DriverManager.getConnection ("jdbc:mysql://localhost:3306/students","root",
"system");
stmt = con.createStatement();
out.println("\n\n");
String Studroll=request.getParameter("SRoll");
if(Studroll==null)//this parsing is done to
Studroll="0";//avaiod NumberFormatException
int n=Integer.parseInt(Studroll);//converting text to int
stmt.executeUpdate("delete from students_table where Roll_no="+n);
rs=stmt.executeQuery("select * from students_table");
out.println("<html>");
out.println("<body>");
out.println("<form action='Delete_Query' method='post'>");
out.println("<strong>Enter Roll Number for deletion : </strong>");
out.print("<br/>");
out.print("<input name='SRoll' type='text'>");
out.println("<br/><br/>");
out.println("<input type='submit' value='Submit'>");
out.println("</form>");
out.println("</body>");
out.println("</html>");

}catch (SQLException e)
{
throw new ServletException("Servlet Could not display records.", e);

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 69 Java Servlets and XML

}
catch (ClassNotFoundException e)
{
throw new ServletException("JDBC Driver not found.", e);
}

finally
{
try
{
if(rs != null)
{
rs.close();
rs = null;
}
if(stmt != null)
{
stmt.close();
stmt = null;
}
if(con != null)
{
con.close();
con = null;
}
}
catch (SQLException e) {}
}//end of finally
out.close();
}//end of service function
} //end of class
Update_Query.java
import java.io.*;
import java.lang.*;
import java.util.*;
import javax.sql.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 70 Java Servlets and XML

public class Update_Query extends HttpServlet


{
public void service(HttpServletRequest request,HttpServletResponse response)
throws IOException, ServletException,NumberFormatException
{
response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.println("<html>");
out.println("<head><title>Servlet Database Connectivity</title></head>");
out.println("<body>");
out.println("</body></html>");
// connecting to database
Connection con = null;
Statement stmt = null;
ResultSet rs = null;
try
{
Class.forName("com.mysql.jdbc.Driver");
con=DriverManager.getConnection("jdbc:mysql://localhost:3306/students","root", "system");
stmt = con.createStatement();
out.println("\n\n");
String Studroll=request.getParameter("SRoll");
String Studadd=request.getParameter("Sadd");
if(Studroll==null)//this parsing is done to
Studroll="0";//avoid NumberFormatException
int n=Integer.parseInt(Studroll);//converting text to int
stmt.executeUpdate("update students_table set address='"+Studadd+"' where Roll_no=" n;
rs=stmt.executeQuery("select * from students_table");
out.println("<html>");
out.println("<body>");
out.println("<form action='Update_Query' method='post'>");
out.println("<strong>Enter Roll Number for updation : </strong>");
out.print("<br/>");
out.print("<input name='SRoll' type='text'>");
out.print("<br/>");
out.println("<strong>Enter new address : </strong>");
out.print("<br/>");
out.print("<input name='Sadd' type='text'>");

out.println("<br/><br/>");
out.println("<input type='submit' value='Submit'>");
out.println("</form>");
out.println("</body>");

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 71 Java Servlets and XML

out.println("</html>");

}catch (SQLException e)
{
throw new ServletException("Servlet Could not display records.", e);
}
catch (ClassNotFoundException e)
{
throw new ServletException("JDBC Driver not found.", e);
}

finally
{
try
{
if(rs != null)
{
rs.close();
rs = null;
}
if(stmt != null)
{
stmt.close();
stmt = null;
}
if(con != null)
{
con.close();
con = null;
}
}
catch (SQLException e) {}
}//end of finally
out.close();
}//end of service function
} //end of class
ServletDBDemo.java
import java.io.*;
import java.util.*;
import javax.sql.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.sql.Connection;
import java.sql.DriverManager;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 72 Java Servlets and XML

import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class ServletDBDemo extends HttpServlet {


public void service(HttpServletRequest request,HttpServletResponse response)
throws IOException, ServletException{
response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.println("<html>");
out.println("<head><title>Servlet Database Connectivity</title></head>");
out.println("<body>");
out.println("</body></html>");
// connecting to database
Connection con = null;
Statement stmt = null;
ResultSet rs = null;
try {
Class.forName("com.mysql.jdbc.Driver");
con =DriverManager.getConnection ("jdbc:mysql://localhost:3306/students","root", "system");
stmt = con.createStatement();
out.println("Connected to Database...");
out.println("\n\n");
rs = stmt.executeQuery("SELECT * FROM students_table");
// displaying records
out.print("<center>");
out.print("<h2>Students Database</h2>");
out.print("<table border=3>");
out.print("<th>Roll</th>");
out.print("<th>Name</th>");
out.print("<th>Address</th>");
out.print("<th>Phone</th>");
while(rs.next())
{
out.print("<tr>");
out.print("<td>");
out.print(rs.getObject(1).toString());
out.print("</td>");
out.print("<td>");
out.print(rs.getObject(2).toString());
out.print("</td>");
out.print("<td>");
out.print(rs.getObject(3).toString());
out.print("</td>");

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 73 Java Servlets and XML

out.print("<td>");
out.print(rs.getObject(4).toString());
out.print("</td>");
out.print("</tr>");
}
out.print("</table>");
out.print("</center>");
}catch (SQLException e) {
throw new ServletException("Servlet Could not display records.", e);
} catch (ClassNotFoundException e) {
throw new ServletException("JDBC Driver not found.", e);
} finally {
try {
if(rs != null) {
rs.close();
rs = null;
}
if(stmt != null) {
stmt.close();
stmt = null;
}
if(con != null) {
con.close();
con = null;
}
} catch (SQLException e) {}
}
out.close();
}
}
Key Point All the above servlet code must be compiled in order to generate the class file. Note
that all these class files must be present in the folder

C:\your_tomcat_directory\webapps\servlets-examples\WEB-INF\classes

And the web.xml file must be edited by specifying the class file of each of these
servlets.

Step 3 : Click on the hyperlink Display Records present in the left frame. The contents
from the database will be displayed in the right frame. The sample output is -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 74 Java Servlets and XML

Step 4 : We can insert as many records as we want by clicking the Insert Record and
filling up the form.

Step 5 : If we want to delete particular record then using the primary key Roll_No the
corresponding record can be deleted. Just click on the Delete Record link present in the
left frame and enter the roll number for the record to be deleted. And then click the
Submit button. The sample output is follows -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 75 Java Servlets and XML

Step 6 : For updating of record click the link Update Record present in the left frame. This
application allows to update the address using the Roll number. The sample output will
be as follows -

Step 7 : You can each time click on the Display Records link to see the effects of these
operations. The sample output will be -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 76 Java Servlets and XML

Record with Roll 3 gets


The Roll 4 gets updated
deleted

Example 3.14.4 Consider a database table with the following schema.(PNR No,status). Write a
servlet program to display the status, given the PNR number.

Solution : Java Program[PNRDemo.java]


import java.io.*;
import java.util.*;
import javax.sql.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class PNRDemo extends HttpServlet


{
public void service(HttpServletRequest request,HttpServletResponse response)
throws IOException, ServletException
{
// connecting to database
Connection con = null;
Statement stmt = null;
ResultSet rs = null;
PrintWriter out = response.getWriter();

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 77 Java Servlets and XML

try
{
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
con =DriverManager.getConnection ("jdbc:odbc:PNRDemo","","");
}catch(ClassNotFoundException e){e.printStackTrace();}
catch(SQLException e){e.printStackTrace();}
catch(Exception e){e.printStackTrace();}
try
{
stmt = con.createStatement();
rs = stmt.executeQuery("SELECT * FROM PNR_table");
// displaying records
response.setContentType("text/html");
out.println("<html>");
out.println("<head><title>PNR Status Display</title></head>");
out.println("<body>");
out.print("<center>");
out.print("<h2>PNR Details </h2>");
out.print("<table border=3>");
out.print("<th>PNR No.</th>");
out.print("<th>Status</th>");
while(rs.next())
{
out.print("<tr>");
out.print("<td>");
out.print(rs.getObject(1).toString());
out.print("</td>");
out.print("<td>");
out.print(rs.getObject(2).toString());
out.print("</td>");
out.print("</tr>");
}
out.print("</table>");
out.print("</center>");
out.println("</body></html>");
}catch (SQLException e) { }
finally {
try {
if(rs != null) {
rs.close();
rs = null;
}
if(stmt != null) {
stmt.close();
stmt = null;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 78 Java Servlets and XML

}
if(con != null) {
con.close();
con = null;
}
} catch (SQLException e) {}
}
out.close();
}//end of service function
} //end of class
Output

Example 3.14.5 Assume that a database has a table Employee with two columns EmployeeID
and Name. Assume that the administrator user id and password to access the database table
are, scott and tiger. Write a JDBC program that can query and print all the entries in the
table Employee. Make the database connection using a type2 driver database.driver and
connection string jdbc:db:oci

Solution : The JDBC code for displaying the employees in Employee table is as follows -

DisplayEmp.java
import java.io.*;
import java.util.*;
import javax.sql.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.sql.*;

public class DisplayEmp extends HttpServlet

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 79 Java Servlets and XML

{
public void service(HttpServletRequest request,HttpServletResponse response)
throws IOException, ServletException
{
response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.println("<html>");
out.println("<head><title>Servlet Database Connectivity</title></head>");
out.println("<body>");
// connecting to database
Connection con = null;
Statement stmt = null;
ResultSet rs=null;
try
{

Class.forName("oracle.jdbc.OracleDriver");
String dbURL = "jdbc:oracle:oci:@my_database";
Properties properties = new Properties();
properties.put("user", "scott");
properties.put("password", "tiger");
properties.put("defaultRowPrefetch", "20");
con =DriverManager.getConnection (dbURL,properties);
stmt = con.createStatement();
rs=stmt.executeQuery("select * from Employee");
out.print("<table border=1>");
out.print("<tr><td>EmployeeID</td><td>Name</td></tr>");
while(rs.next())
{
//Retrieve by column name
int id = rs.getInt("ID");
String name = rs.getString("Name");
out.print("<tr><td>"+id+"</td><td>"+name);
out.print("</td></tr>");
}
out.println("</table></body></html>");
}catch (SQLException e)
{
throw new ServletException("Servlet Could not display records.", e);
}
catch (ClassNotFoundException e)
{
throw new ServletException("JDBC Driver not found.", e);
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 80 Java Servlets and XML

finally
{
try
{
if(rs != null)
{
rs.close();
rs = null;
}
if(stmt != null)
{
stmt.close();
stmt = null;
}
if(con != null)
{
con.close();
con = null;
}
}
catch (SQLException e) {}
}//end of finally
out.close();
}//end of service function
} //end of class
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 81 Java Servlets and XML

Part II : XML

3.15 XML Documents and Vocabularies SPPU : Dec.-18, 19, May-19, Marks 5

 XML stands for eXtensible Markup Language.


 This scripting language is similar to HTML. That means, this scripting language
contains various tags. But these tags are not predefined tags, in-fact user can define his
own tags.
 Thus HTML is designed for representation of data on the web page whereas the XML
is designed for transport or to store data.

Uses of XML
1. XML is used to display the meta contents i.e. XML describes the content of the
document.
2. XML is useful in exchanging data between the applications.
3. The data can be extracted from database and can be used in more than one
application. Different applications can perform different tasks on this data.

Advantages of XML
1. XML document is human readable and we can edit any XML document in
simple text editors.
2. The XML document is language neutral. That means a Java program can
generate an XML document and this document can be parsed by Perl.
3. Every XML document has a tree structure. Hence complex data can be arranged
systematically and can be understood in simple manner.
4. XML files are independent of an operating system.

Goals of XML
Following are the goals of XML -
1. User must be able to define and use his own tag. This allows us to restrict the use
of the set of tags defined by proprietary vendors.
2. Allow user to build his own tag library based on his web requirement.
3. Allow user to define the formatting rules for the user defined tags.
4. XML must support for storage or transport of data.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 82 Java Servlets and XML

Features of XML
Following are some features which are most suitable for creating web related
applications.
 XML is EXtesible Markup Language intended for transport or storage of the data.
 The most important feature of XML is that user is able to define and use his own tag.
 XML contains only data and does not contain any formatting information. Hence
document developers can decide how to display the data.
 XML permits the document writer to create the tags for any type of information. Due to
this virtually any kind of information can be such as mathematical formulae, chemical
structures, or some other kind of data can be described using XML.
 Searching sorting, rendering or manipulating the XML document is possible using
Extended Stylesheet Language (XSL).
 The XML document can be validated using some external tools.
 Some commonly used web browsers like Internet Explorer and Firefox Mozilla provide
support to the tags in XML. Hence XML is not at all vendor specific or browser specific.

Difference between XML and HTML


Sr. No. HTML XML

1. HTML stands for Hypertext Markup XML stands for eXtensible Markup
Language. Language.
2. HTML is designed to display data with the XML is used to transport and store data, with
focus on look and feel of data. focus on what data is.
3. HTML is case insensitive. XML is case sensitive.

4. HTML has predefined tags. XML has custom tags can be defined and the
tags are invented by the author of the XML
document.
5. As HTML is for displaying the data it is As XML is for carrying the data it is dynamic.
static.
6. It can not preserve white space. It can preserve the white space.

Strengths and Limitations

Strengths :
1. XML document is human readable and we can edit any XML document in
simple text editors.
2. The XML document is language neutral. That means a Java program can
generate an XML document and this document can be parsed by Perl.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 83 Java Servlets and XML

3. Every XML document has a tree structure. Hence complex data can be arranged
systematically and can be understood in simple manner.
4. XML files are independent of an operating system.

Limitations :
1. XML syntax is verbose and redundant as compared to other text based data
transmission formats.
2. Redundancy in syntax of XML causes higher storage and transportation cost
when there is large volume of data.
3. XML does not support array.
4. XML document is less readable.
5. Due to verbose nature of XML syntax the XML file size is usually very large.

Review Questions

1. What are the strengths of XML technology ? Also list the limitations of using XML.
SPPU : Dec.-18, Marks 5
2. What are the strengths of XML technology ? Explain the need for XML.
SPPU : May-19, Marks 5
3. Describe the following web technology : XML. SPPU : Dec.-19, Marks 2

3.16 XML Declaration


Elements and Attributes
 Various building blocks of XML are -
1. Elements
 The basic entity is element. The elements are used for defining the tags. The
elements typically consist of opening and closing tag. Mostly only one element is
used to define a single tag.
2. Attribute
 The attributes are generally used to specify the values of the element. These are
specified within the double quotes.
For example -
<flag type=”True”>
 The type attribute of the element flag is having the value True.

3. CDATA
CDATA stands for Character Data. This character data will be parsed by the parser.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 84 Java Servlets and XML

4. PCDATA
It stands for Parsed Character Data (i.e. text).

3.16.1 Declaring Elements


 The element type data can be declared using the ELEMENT.
 The syntax for defining the ELEMENT is,
<!ELEMENTelt_name (elt1,elt2,..)>

XML Document [Internal_Elt.xml]


<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE student [
<!ELEMENT student (name,address,std,br,marks)>
<!ELEMENT name (#PCDATA)>
<!ELEMENT address (#PCDATA)> Here we are defining
<!ELEMENTstd (#PCDATA)> the DTD internally
<!ELEMENTbr EMPTY>
<!ELEMENT marks (#PCDATA)>
]>
<student>
<name>Anand</name>
<address>Pune</address>
<std>Second</std>
<br />
<marks>70 percent</marks>
</student>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 85 Java Servlets and XML

 The ELEMENT must be defined in the beginning of the XML file. It must be enclosed
within <!DOCTYPEroot_element ….>
 There are various ways by which the actual element can be defined. It is enlisted in the
following table -
Category Syntax Description

Empty <!ELEMENT elt_nameEMPTY> Empty elements can be


declared.

Character data <!ELEMENT elt_name (#PCDATA)> Character data can be


declared.

Any content <!ELEMENT elt_nameANY> Any combination of data can


be declared.

Sequence <!ELEMENTelt_name(elt1,elt2,…)> Sequence of elements that


must appear in specific order.

 Sometimes we can define the ELEMENT along with the iterator characters. The iterator
characters are the special character which are associated with some meaning.
 Some commonly used iterator characters are as given below -
Iterator Meaning Example
character

? The preceding choice appears zero or <!ELEMENT(marks?)>


once. The child element marks can
appear for zero or one time.
* The preceding choice appears for any <!ELEMENT (person*)>
number of time(zero or more times). The person can appear for any
number of times.
+ The preceding choice appears for at <!ELEMENT (person+)>
least once (one or more times). The person can appear for at least
once.

3.16.2 Declaring Attributes


 The attribute type declaration is done using the string ATTLIST.
 The attribute type specifies the type of data which can be used for specifying the
attribute. The syntax for specifying the attribute declaration is as follows -
<!ATTLISTelement_nameattribute_nameattribute_typedefault_value>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 86 Java Servlets and XML

 For example

 The XML document containing attributes is as given below -

XML Document [Internal_Attr.xml]


<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE student [
<!ELEMENT student (name,address,std,marks)>
<!ELEMENT name (#PCDATA)>
<!ELEMENT address (#PCDATA)>
<!ELEMENTstd (#PCDATA)>
<!ELEMENT marks (#PCDATA)>
Using ATTLIST the
<!ATTLIST address phone CDATA #REQUIRED> attribute can be defined.

]>
<student>
<name>Anand</name>
<address phone="9898123123">Pune</address>
<std>Tenth</std>
<br />
<marks>70 percent</marks>
</student>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 87 Java Servlets and XML

 Following are some attribute type -


Attribute_Type Syntax Description

Character data CDATA Attribute value is character data.

Enumerated (str1|str2|…) Attribute value must be one from an enumerated


list.

Identifier ID Attribute value is a unique id.

Identifier IDREF Attribute value is the id of another element.


reference

Identifier IDREFS Attribute value is a list of other ids.


reference list

Name token NMTOKEN Attribute value is a valid XML name.

Name token list NMTOKENS Attribute value is a list of valid XML names.

The default_values are -


Default_Value Meaning

Value Default value can be defined. For example -


<!ATTLIST Index flag=”0”>
In XML document
<Index flag=”1” />
If the flag is not assigned with any value then by default it will be 0.

#REQUIRED Required attribute forces the attribute to be present even if there is no


default value.

#IMPLIED The default value is not provided and attribute can be optionally used.

#FIXED value The attribute value is fixed and cannot be changed.

3.16.3 Declaring Entities


 The attribute type declaration is done using the string ENTITY.
 Inside the XML file at the beginning the entity can be defined using the
<!DOCTYPE …> and with the help of string ENTITY. Following XML document
demonstrates it -

XML Document [EntityDemo.xml]


<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE Book[
<!ENTITY writer "Puntambekar">
<!ENTITYnbsp "&#160;">
<!ENTITY title "Web Technologies">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 88 Java Servlets and XML

]>
<Book>&writer;&nbsp;&title;</Book>
Output

 Note that we can define the predefined entities &nbsp along with the other entity
declaration.
 The entity can be used using following syntax.
&name_of_entity;
 In above script we have used two entities namely writer and title. For displaying
the space within these two entities we have used an entity nbsp and for defining it
we have used #160.

3.17 Rules
 Rules that must be followed while writing XML -
Here are some rules that must be followed while writing the XML programs -
1. XML is a case sensitive. For example -
<hobby>I like drawing</Hobby>or
<Hobby>I like drawing</hobby>
is not allowed because the words hobby and Hobby are treated differently.
2. In XML each start tag must have matching end tag. For example -
<staring> XML is funny to write
<simple> It is simple to implement </simple>
That means a closing tag is a must.
3. The elements in XML must be properly nested. For example-
<one><two>Hello how are you?</one></two> is wrong but
<one><two>Hello how are you?</two></one> is correct

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 89 Java Servlets and XML

3.18 XML Namespaces


 Sometimes we need to create two different elements by the same name. The xml
document allows us to create different elements which are having the common name.
This technique is known as namespace.
 In some web documents it becomes necessary to have the same name for two different
elements. Here different elements mean the elements which are intended for different
purposes. In such a case support for namespace technique is very much helpful.
 For example : Consider the following xml document -
namespacedemo.xml
<File-Description>
<text fname="input.txt">
<describe>It is a text file</describe>
</text>
<text fname="flower.jpg">
<describe>It is an image file</describe>
</text>
</File-Description>
The above document does not produce any error although the element text is used for
two different attribute values. The output will be,

3.19 Document Type Definition (DTD) SPPU : May-18, Marks 5

 The document type definition is used to define the basic building block of any xml
document.
 Using DTD we can specify the various elements types, attributes and their relationship
with one another.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 90 Java Servlets and XML

 Basically DTD is used to specify the set of rules for structuring data in any XML file.
 For example : If we want to put some information about some students in XML file
then, generally we use tag student followed by his/her name, address, standard and
marks. That means we are actually specifying the manner by which the information
should be arranged in the XML file. And for this purpose the document type definition
is used.
 Various building blocks of XML are -
1. Elements
The basic entity is element. The elements are used for defining the tags. The elements
typically consist of opening and closing tag. Mostly only one element is used to
define a single tag.
2. Attribute
The attributes are generally used to specify the values of the element. These are
specified within the double quotes.
For example -
<flag type="True">
The type attribute of the element flag is having the value True.
3. CDATA
CDATA stands for character data. This character data will be parsed by the parser.
4. PCDATA
It stands for Parsed Character Data (i.e. text). Any parsable character data should
not contain the markup characters. The markup characters are < or > or &. If we
want to use less than, greater than or ampersand characters then make use of &lt; ,
&gt; or &amp;
 There are two ways by which DTD can be defined.
Internal DTD
Consider following xml document -
XML Document [DTDDemo1.xml]
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE student [
<!ELEMENT student (name,address,std,marks)>
<!ELEMENT name (#PCDATA)> Here we are defining the
<!ELEMENT address (#PCDATA)> DTD internally
<!ELEMENT std (#PCDATA)>
<!ELEMENT marks (#PCDATA)>
]>
<student>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 91 Java Servlets and XML

<name>Anand</name>
<address>Pune</address>
<std>Second</std>
<marks>70 percent</marks>
</student>
Output

External DTD
In this type, an external DTD file is created and its name must be specified in the
corresponding XML file. Following XML document illustrates the use of external DTD.

Step 1 : Creation of DTD file [student.dtd]


Open some suitable text editor or a notepad. Type following code into it -
<!ELEMENT student (name,address,std,marks)>
<!ELEMENT name (#PCDATA)>
<!ELEMENT address (#PCDATA)>
<!ELEMENT std (#PCDATA)>
<!ELEMENT marks (#PCDATA)>
Now save this file as student.dtd

Step 2 : Creation of XML document -

XML Document [DTDDemo.xml]


Now create a XML document as follows -
<?xml version="1.0"?>
<!DOCTYPE student SYSTEM "student.dtd"> The external DTD file is
<student>
created
<name>Anand</name>
<address>Pune</address>
<std>Second</std>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 92 Java Servlets and XML

<marks>70 percent</marks>
</student>

Step 3 : Using some web browser open the XML document.


Output

Example 3.19.1 Create a DTD for a catalog of four stroke motorbikes, where each motor bike has
the following child elements -make, model, year, colo, engine, chasis number and accessories.
The engine element has the child elements engine number, number of cylinders, type of fuel.
The accessories element has the attributes like disc brake,auto-start and radio, each of which
is required and has the possible values yes and no.

Solution :

automobile.dtd
<!ELEMENT Catalog (MotorBike)*>
<!ELEMENT MotorBike (make, model, year,color, engine,chasis-num,accessories ) >
<!ELEMENT make (#PCDATA)>
<!ELEMENT model (#PCDATA)>
<!ELEMENT year (#PCDATA)>
<!ELEMENT color (#PCDATA)>
<!ELEMENT engine (engin-num,cylinders-num,fuel-type)>
<!ELEMENT chasis-num (#PCDATA)>
<!ELEMENT accessories (#PCDATA)>
<!ATTLIST accessories disc-brake (yes|no) #REQUIRED
auto-start (yes|no) #REQUIRED
radio (yes|no) #REQUIRED>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 93 Java Servlets and XML

Example 3.19.2 Consider a hospital management system. Write a DTD program to consolidate
and show the bill to be paid by the inpatients (Assume your own data).

Solution : Patients.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE Patients [
<!ELEMENT Patients (Patient)*>
<!ELEMENT Patient (Name, Address,Test,Date,Doctor,Bill)>
<!ELEMENT Name (#PCDATA)>
<!ELEMENT Address (#PCDATA)>
<!ELEMENT Test (#PCDATA)>
<!ELEMENT Date (#PCDATA)>
<!ELEMENT Doctor (#PCDATA)>
<!ELEMENT Bill (#PCDATA)>
]>
<Patients>
<Patient>
<Name>Anuradha</Name>
<Address>Pune</Address>
<Test>ECG</Test>
<Date>1-1-2010</Date>
<Doctor>Mr.XYZ</Doctor>
<Bill>Rs.500</Bill>
</Patient>
<Patient>
<Name>Archana</Name>
<Address>Mumbai</Address>
<Test>Blood Test</Test>
<Date>10-3-2010</Date>
<Doctor>Mr.PQR</Doctor>
<Bill>Rs.100</Bill>
</Patient>
</Patients>

Merits of DTD
1. DTDs are used to define the structural components of XML document
2. These are relatively simple and compact.
3. DTDs can be defined inline and hence can be embedded directly in the XML
document.
Demerits of DTD
1. The DTDs are very basic and hence cannot be much specific for complex
documents.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 94 Java Servlets and XML

2. The language that DTD uses is not an XML document. Hence various
frameworks used by XML cannot be supported by the DTDs.
3. The DTD cannot define the type of data contained within the XML document.
Hence using DTD we cannot specify whether the element is numeric, or string or
of date type.
4. There are some XML processor which do not understand DTDs.
5. The DTDs are not aware of namespace concept.

Review Question

1. Explain the differences between external and internal DTD. SPPU : May-18, Marks 5

3.20 Schema SPPU : May-18, Marks 5

 The XML schemas are used to represent the structure of XML document.
 The goal or purpose of XML schema is to define the building blocks of an XML
document. These can be used as an alternative to XML DTD.
 The XML schema language is called as XML Schema Definition (XSD) language.
 XML schema defines elements, attributes, elements having child elements, order of
child elements. It also defines fixed and default values of elements and attributes.
 XML schema also allows the developer to use data types.
How to write a simple schema ?

Step 1 : We will first write a simple xsd file in which the desired structure of the XML
document is defined. I have named it as StudentSchema.xsd
This file contains the complex type with four child simple type elements.
XML Schema [StudentSchema.xsd]
<?xml version="1.0"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:element name="Student">
<xs:complexType>
<xs:sequence>
<xs:element name="name" type="xs:string"/>
<xs:element name="address" type="xs:string"/>
<xs:element name="std" type="xs:string"/>
<xs:element name="marks" type="xs:string"/>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 95 Java Servlets and XML

Script Explanation :
1. The xs is qualifier used to identify the schema elements and types.
2. The document element of schema is xs:schema. The xs:schema is the root
element. It takes the attribute xmlns:xs which has the value
http://www.w3.org/2001/XMLSchema. This declaration indicates that document
should follow the rules of XML schema. The XML schema rules are defined by
the W3 recommendation in year 2001.
3. Then comes xs:element which is used to define the xml element. In above case
the element Student is of complex type who have four child elements : name,
address, std and marks. All these elements are of simple type string.

Step 2 : Now develop XML document in which the desired values to the XML elements
can be given. I have named this file as MySchema.xml

XML Document [MySchema.xml]


<?xml version="1.0" encoding="UTF-8"?>
<Student xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="StudentSchema.xsd">
<name>Anand</name>
<address>Pune</address>
<std>Second</std>
<marks>70 percent</marks>
</Student>

Program Explanation :

1. In above XML document, the first line is typical in which the version and encoding
is specified.
2. There is xmlns:xsi attribute of document which indicates that XML document is an
instance of XML schema. And it has come from the namespace
“http://www.w3.org/2001/XMLSchema-instance.”
3. To tie this XML document with the some Schema definition we use the attribute
xsi:noNamespace SchemaLocation. The value that can be passed to this attribute is
the name of xsd file “StudentSchema.xsd”.
4. After this we can define the child elements.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 96 Java Servlets and XML

Step 3 : See the output in the browser window as follows -

3.20.1 Data Types


Various data types that can be used to specify the data types of an element are :
 String
 Date
 Numeric
 Boolean.
Let us discuss each of these data types with the help of examples -
1. String data type
The string data type is used to define the element containing characters, lines, tabs or
white spaces. Following schema definition illustrates this data type.
We can write a schema definition in which the data type of element Student_Name is
declared as of string type.

XML Schema [stringType.xsd]


<?xml version="1.0" encoding="UTF-8"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" >
<xs:element name="Student_Name" type="xs:string" />
</xs:schema>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 97 Java Servlets and XML

2. Date data type


For specifying the date we use date data type. The format of this date is yyyy-mm-dd
where yyyy denotes the year, mm denotes the month and dd specifies the day. While
specifying the date if any entry is single digit then it must be with leading zero. All the
entries (i.e. yyyy,mm and dd ) must be present.
Here is an illustration.

XML Schema [dateType.dtd]


<?xml version="1.0" encoding="UTF-8"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:element name="Date_of_Birth" type="xs:date"/>
</xs:schema>

XML Document [dateTypeDemo.xml]


<?xml version="1.0" encoding="UTF-8"?>
<Date_of_Birth xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="dateType.xsd">
2009-09-01
</Date_of_Birth>
We can also specify the time by specifying the time as follows -

XML Document
<?xml version="1.0" encoding="UTF-8"?>
<Date_of_Birth xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="dateType.xsd">
2009-09-01-01:57
</Date_of_Birth>

3. Numeric
If we want to use numeric value for some element then we can use the data types as
either decimal or integer.

XML Schema [decimal Type.xsd ]


<?xml version="1.0" encoding="UTF-8"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:element name="My_Marks" type="xs:decimal"/>
</xs:schema>

XML Document [decimal Type Demo.xml]


<?xml version="1.0" encoding="UTF-8"?>
<My_Marks xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="decimalDemo.xsd">
99.99
</My_Marks>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 98 Java Servlets and XML

Using decimal data type we can specify the value that may contain some decimal
point. We can have another data type called integer which is used to specify the numeric
values that are without any decimal point.

XML Schema [integer Type.xsd]


<?xml version="1.0" encoding="UTF-8"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:element name="My_Number" type="xs:integer"/>
</xs:schema>

4. Boolean
For specifying the true or false values we must use the boolean data type.

XML Schema [booleantype.xsd]


<?xml version="1.0" encoding="UTF-8"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:element name="Flag" type="xs:boolean"/>
</xs:schema>

3.20.2 Advantages and Disadvantages of Schema

Advantages of schema

1. The schemas are more specific.


2. The schema provide the support for data types.
3. The schema is aware of namespaces.
4. The XML schema is written in XML itself and has a large number of built in and
derived types.
5. The XML schema is the W3C recommendation. Hence it is supported by various
XML validator and XML processors.

Disadvantages of schema

1. The XML schema is complex to design and hard to learn.


2. The XML document cannot be if the corresponding schema file is absent.
3. Maintaining the schema for large and complex operations sometimes slows down
the processing of XML document.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 99 Java Servlets and XML

Advantages of schema over DTD


1. Both the schemas and DTDs are useful for defining structural components of XML.
But the DTDs are basic and cannot be much specific for complex operations. On the
other hand schemas are more specific.
2. The schemas provide support for defining the type of data. The DTDs do not have
this ability. Hence content definition is possible using schema.
3. The schemas are namespace aware and DTDs are not.
4. The XML schema is written in XML itself and has a large number of built in and
derived types.
5. The schema is the W3C recommendation. Hence it is supported by various XML
validator and XML processors but there are some XML processors which do not
support DTD.
6. Large number of web applications can be built using XML schema. On the other
hand relatively simple and compact operations can be built using DTD.

Review Question

1. What are XML schemas ? How are they better than DTDs ? SPPU : May-18, Marks 5

3.21 DOM based XML Processing

What is DOM ?

Document Object Model (DOM) is a set of platform independent and language neutral
Application Programming Interface (API) which describes how to access and manipulate
the information stored in XML or in HTML documents.
Thus XML DOM is for
 Loading the XML document.
 Accessing the elements of XML document.
 Deleting the elements of XML document.
 Changing the elements of XML document.

1. Loading an XML file


We will write a simple script by which any desired XML file can be loaded. Note that
these scripts are dependant upon the browser in which these are getting opened. We will
write the following script which can be opened in any browser like internet explorer or
Mozilla Firefox.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 100 Java Servlets and XML

Step 1 : Open some simple text editor like Notepad and type the following script. I have
named it as first.html
<html>
<!--Simple DOM example for loading some xml file -->
<body>
<script type="text/javascript">
try
{
xmlDocument=new ActiveXObject("Microsoft.XMLDOM");
}
catch(e)
{
try
{
xmlDocument=document.implementation.createDocument("","",null);
}
catch(e) {alert(e.message)}
}
try
{
xmlDocument.async=false;
xmlDocument.load("student.xml");
document.write("XML Document student.xml is loaded");
}
catch(e) {alert(e.message)}
</script>
</body>
</html>

The load function is used to load the desired XML file. Note that when we specify
some xml file for loading then it must be present at the current path. As an illustration the
student.xml file is given as below -

XML Document [student.xml]


<?xml version="1.0" ?>
<student>
<Roll_No>10</Roll_No>
<Personal_Info>
<Name>Parth</Name>
<Address>Pune</Address>
<Phone>1234567890</Phone>
</Personal_Info>
<class>Second</class>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 101 Java Servlets and XML

<Subject>Mathematics</Subject>
<Marks>100</Marks>
</student>

Step 2 : Then open some web browser like Firefox or Internet explorer and the output for
the above script can be seen as follows -

Script Explanation

There is an XML parser which reads any XML file. All the modern web browsers like
Internet explorer have built in XML parser. The parser converts the XML into javascript
accessible object. Hence we have mentioned the script type as -

<script type="text/javascript">

The parser reads the XML file, stores it into a memory and converts it into the XML
DOM object. These objects can be accessible by the JavaScript.

Internet Explorer 5 and above have the built in XML parser. Hence in above given
script we have written -

xmlDocument=new ActiveXObject("Microsoft.XMLDOM");

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 102 Java Servlets and XML

This statement means create an empty XML document object. We have taken this
object in the variable xmlDocument.

After getting the document loaded fully in the memory the parser will continue for
execution of the script, hence we must set -

xmlDocument.async=false;

Then we should specify the name of the xml file which we want to get loaded.

xmlDocument.load("student.xml");

Then by using the document.write we can display the desired message on the web
browser to indicate that the XML file is loaded. Hence we have written
document.write("XML Document student.xml is loaded");

2. Use of Properties and Methods


Before understanding the properties and methods it is necessary to understand the
concept of node tree. In DOM everything from XML is treated as a node. Consider a
simple XML document,
<?xml version="1.0" ?>
<student>
<Roll_No>10</Roll_No>
<Personal_Info>
<Name>Parth</Name>
<Address>Pune</Address>
<Phone>1234567890</Phone>
</Personal_Info>
<class>Second</class>
<Subject>Mathematics</Subject>
<Marks>100</Marks>
</student>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 103 Java Servlets and XML

We can draw a node tree for this document as follows -

Fig. 3.21.1 Node-tree for student.XML

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 104 Java Servlets and XML

Various properties are,

Property Meaning
nodeName Finding the name of the node.

nodeValue Obtaining the value of a node.

parentNode Getting the parent element.

childNodes Obtaining the child nodes.

attributes For getting the attributes values.


Various methods are,

Method Meaning
getElementsByTagName(name) This method is used to access all the elements
that are specified with the tag name.

appendChild(node) This method is used for inserting a child node.

removeChild(node) This method is used for removing the child


nodes.

Let us understand the use of properties and methods with the help of following
example -
<html>
<!-- loading and accessing the contents of xml file -->
<head>
<script type="text/javascript" src="my_function_file.js"></script>
</head>
<body>
<script type="text/javascript">
xmlDocument=My_Function("student.xml");
document.write("xml File loaded and following are the contents of this file -");
document.write("</br>");
document.write("Roll_No :
"+xmlDocument.getElementsByTagName("Roll_No")[0].childNodes[0].nodeValue);
document.write("</br>");
document.write("Name :
"+xmlDocument.getElementsByTagName("Name")[0].childNodes[0].nodeValue);
document.write("</br>");
document.write("Address :
"+xmlDocument.getElementsByTagName("Address")[0].childNodes[0].nodeValue);
document.write("</br>");
document.write("Phone :
"+xmlDocument.getElementsByTagName("Phone")[0].childNodes[0].nodeValue);
document.write("</br>");

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 105 Java Servlets and XML

document.write("class :
"+xmlDocument.getElementsByTagName("class")[0].childNodes[0].nodeValue);
document.write("</br>");
document.write("Subject :
"+xmlDocument.getElementsByTagName("Subject")[0].childNodes[0].nodeValue);
document.write("</br>");
document.write("Marks :
"+xmlDocument.getElementsByTagName("Marks")[0].childNodes[0].nodeValue);
document.write("</br>");
</script>
</body>
</html>
Output

Script Explanation

In above given script, we have specified an external file my_function_file.js in the


head section. This is a file in which the function My_Function is defined. This function
performs the task of loading an XML document student.xml

We will first obtain a document object using the statement,


xmlDocument=My_Function("student.xml");

Note that xmlDocument is a document object referring the document student.xml.


Using this object we can use the properties and methods. The method
getElementsByTagName is used and to this method the parameter will be a tag names
such as “Roll_No”, “Name” “class” and so on.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 106 Java Servlets and XML

xmlDocument.getElementsByTagName("Roll_No")[0].childNodes[0].nodeValue);

This method is used for Tag name The first The value of
accessing the element by from child of the node Roll_No
specifying the tag name student.xml <Roll_No> (i.e. text)

Hence as an output we can see the value of every element. That means the contents of
student.xml file will be displayed.

3.22 Transforming XML Documents SPPU : May-19, March-20, Marks 5

 The XSLT stands for XSL Transformations and XSL stands for eXtensible
Stylesheet Language.
 An XSLT is a W3C recommendation.
 The XSLT is used for defining the XML document transformations and
presentations. Hence XSL decides how an XML document should look on the web
browser.
 XSL consists of three parts :
1. XSLT is a language for transforming XML documents.
2. XPath is a language for navigating in XML documents. In other words we can
reach to any node of XML document using XPath.
3. XSL-FO is a language for formatting XML documents for displaying it in desired
manner.

3.22.1 Transforming XML into XSLT


 Using XSLT we can decide the way by which we want the element to get displayed.
 XSLT uses XPath to find information in an XML document. XPath is used to navigate
through elements and attributes in XML documents. We can sort these elements, hide
or display particular element and can apply some decision making logic on these
elements.
 XSLT processors take two input documents one is XML document and another is
XSLT document. The XSLT document is nothing but a program and XML document is
nothing but the input data, thus this program works on the XML input data. Then
some or whole part of the XML document is selected, modified and merged with XSLT
program document in order to produce another document.
 This newly produced document is provided as input to the XSLT processor which in
turn produce another document called the XSL document.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 107 Java Servlets and XML

 The XSL document is used along with the application so that particular application can
be displayed on the web browser in some desired manner.

Fig. 3.22.1 Processing of XSLT document

 The XSLT document makes use of templates using which particular code can be
described in XML document.
 XML document and then particular code in XSLT is executed when the match is found.
 XSLT processor processes the XML document sequentially by reading each line one by
one.
 The XSLT model can be described as template driven or data driven model.

3.22.2 XSL Elements

1. The <xsl:template>
 The <xsl:template> is for building the templates.
 The match attribute is associated with the template element. The match attribute can
also be used to define a template for the entire XML document. The match="/" defines
the whole document.
 In the following example we store the XML elements in the tabular form using the
<xsl:template> and <match>

Step 1 : Write a simple XML document. One sample example is as below –


Open Notepad and write the following code. Save it by the name SimpleXml.xml

XML Document[SimpleXml.xml]
<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" href="SimpleXml.xsl"?>
<Student>
We have defined this
<Person-Details>
<name>Anand</name>
file in step 2
<address>Pune</address>
<std>Second</std>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 108 Java Servlets and XML

<marks>70 percent</marks>
</Person-Details>
<Person-Details>
<name>Anuradha</name>
<address>Chennai</address>
<std>Second</std>
<marks>90 percent</marks>
</Person-Details>
<Person-Details>
<name>Archana</name>
<address>Mumbai</address>
<std>Forth</std>
<marks>80 percent</marks>
</Person-Details>
<Person-Details>
<name>Monika</name>
<address>Delhi</address>
<std>Tenth</std>
<marks>77 percent</marks>
</Person-Details>
</Student>

Step 2 : Now create a XSL stylesheet. Note that this document must have file name
extension as .xsl. Open notepad and save following code in it.

XSLT Document [SimpleXml.xsl]


<?xml version="1.0" encoding="ISO-8859-1"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">
<html>
<body>
<h2>Students Database</h2>
<table border="1">
<trbgcolor="gray">
<th>Name</th>
<th>Address</th>
<th>Standard</th>
<th>Marks</th>
</tr>
<trbgcolor="pink">
<td>**</td>
<td>**</td>
<td>**</td>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 109 Java Servlets and XML

<td>**</td>
</tr>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>

Step 3 : Open the web browser and the output will be as follows -

2. The <xsl:value-of>
The value-of is used to extract the value of xml element and add it to output stream of
the XSL transformation. Following example illustrates this :

Step 1 : Keep the same xml[SimpleXml.xml] file which you have created in
section 3.22.2 (1) Step 1.

Step 2 : Create the xsl file as follows -


<?xml version="1.0" encoding="ISO-8859-1"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">
<html>
<body>
<h2>Students Database</h2>
<table border="1">
<trbgcolor="gray">
<th>Name</th>
<th>Address</th>
<th>Standard</th>
<th>Marks</th>
</tr>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 110 Java Servlets and XML

<trbgcolor="pink">
<td><xsl:value-of select="Student/Person-Details/name"/></td>
<td><xsl:value-of select="Student/Person-Details/address"/></td>
<td><xsl:value-of select="Student/Person-Details/std"/></td>
<td><xsl:value-of select="Student/Person-Details/marks"/></td>
</tr>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>

Step 3 : Open the web browser and the output will be as follows -

3. The <xsl:for-each>
The for-each element allows to traverse through each element of the node

Step 1 : Keep the same xml[SimpleXml.xml] file which you have created in
section 3.22.2(1) Step 1.

Step 2 : Now create .xsl document illustrating <xsl:for-each>. It is as follows -


<?xml version="1.0" encoding="ISO-8859-1"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">
<html>
<body>
<h2>Students Database</h2>
<table border="1">
<trbgcolor="gray">
<th>Name</th>
<th>Address</th>
<th>Standard</th>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 111 Java Servlets and XML

<th>Marks</th>
</tr>
<xsl:for-each select="Student/Person-Details" >
<trbgcolor="pink">
<td><xsl:value-of select="name"/></td>
<td><xsl:value-of select="address"/></td>
<td><xsl:value-of select="std"/></td>
<td><xsl:value-of select="marks"/></td>
</tr>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>

Step 3 : Open the web browser and the output will be as follows -

4. The <xsl:sort>
We can also display the sorted data using <xsl:sort>.
Step 1 : Keep the same xml[SimpleXml.xml] file which you have created in
section 3.22.2 (1) Step 1.

Step 2 : Create the .xsl file as follows -

SimpleXml.xsl
<?xml version="1.0" encoding="ISO-8859-1"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 112 Java Servlets and XML

<html>
<body>
<h2>Students Database</h2>
<table border="1">
<trbgcolor="gray">
<th>Name</th>
<th>Address</th>
<th>Standard</th>
<th>Marks</th>
</tr>
<xsl:for-each select="Student/Person-Details">
<xsl:sort select="marks"/>
<trbgcolor="pink">
<td><xsl:value-of select="name"/></td>
<td><xsl:value-of select="address"/></td>
<td><xsl:value-of select="std"/></td>
<td><xsl:value-of select="marks"/></td>
</tr>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 113 Java Servlets and XML

5. The <xsl:if>
For selection specific record based on some condition the <xsl:if> is used.

Step 1 : Keep the same xml[SimpleXml.xml] file which you have created in
section 3.22.2(1) Step 1.

Step 2 : Create the .xsl file as follows -


<?xml version="1.0" encoding="ISO-8859-1"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">
<html>
<body>
<h2>Students Database</h2>
<table border="1">
<trbgcolor="gray">
<th>Name</th>
<th>Address</th>
<th>Standard</th>
<th>Marks</th>
</tr>
<xsl:for-each select="Student/Person-Details" >
<xsl:if test="marks>77">
<trbgcolor="pink">
<td><xsl:value-of select="name"/></td>
<td><xsl:value-of select="address"/></td>
<td><xsl:value-of select="std"/></td>
<td><xsl:value-of select="marks"/></td>
</tr>
</xsl:if>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 114 Java Servlets and XML

6. The <xsl:choose>
The <xsl:choose> element is used along with <xsl:when> and <xsl:otherwise> to express
multiple conditional tests.

Step 1 : Keep the same xml[SimpleXml.xml] file which you have created in
section 3.22.2 (1) Step 1.

Step 2 : Create the .xsl file as follows -


<?xml version="1.0" encoding="ISO-8859-1"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">
<html>
<body>
<h2>Students Database</h2>
<table border="1">
<trbgcolor="gray">
<th>Name</th>
<th>Marks</th>
</tr>
<xsl:for-each select="Student/Person-Details">
<tr>
<td><xsl:value-of select="name"/></td>
<xsl:choose>
<xsl:when test="marks &lt; 77">
<td bgcolor="pink">
<xsl:value-of select="marks"/></td>
</xsl:when>
<xsl:otherwise>
<td><xsl:value-of select="marks"/></td>
</xsl:otherwise>
</xsl:choose>
</tr>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 115 Java Servlets and XML

3.22.3 Difference between XML and XSLT


Sr.No. XML XSLT

1. XML stands for extensible markup XSLT stands for extensible stylesheet language
language. transformations.

2. XML is used to store data in XSLT is used for transforming and formatting
structured format. the XML file.

3. XML does not perform XSLT can transform one XML format into
transformations. another XML format or into HTML or into
plain text.

4. XML contains the user defined tags. XSLT contains special XSL tags and
programming constructs.

5. XML uses the user defined raw data XSLT uses XPath for transformation and
for storage. formatting of XML file.

Review Questions

1. Discuss the XSLT technology with an example SPPU : May-19, Marks 5


2. Write at least any five differences between XML and XSLT. SPPU : March-20, Marks 5

Part III : AJAX

3.23 Introduction
 AJAX is a Asynchronous Java Script and XML
 Here
o Asynchronous means, the execution of script does not disturb the user’s work.
o JavaScript because, it makes use of Javascripting to do the actual work.
o XML because along with JavaScript the XML is also supported to perform the given
task in AJAX.
 It is not a new programming language but it is a kind of web document which adopts
certain standards.
 AJAX allows the developer to exchange the data with the server and updates the part
of web document without reloading the web page.

3.24 Working of AJAX


 When user makes a request, the browser creates a object for the HttpRequest and a
request is made to the server over an internet.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 116 Java Servlets and XML

 The server processes this request and sends the required data to the browser.
 At the browser side the returned data is processed using JavaScript and the web
document gets updated accordingly by sending the appropriate response.
Following Fig. 3.24.1 illustrates this working.

Fig. 3.24.1 Working of AJAX

Similarities and Differences

Sr.No. Traditional Web Application Ajax Based Web Application Architecture


Architecture

1. The web applications architectures are based on HTTP request response protocol.

2. At the client side the browser client has At the client side the browser client has user
only one component and that is – user interface and AJAX Engine due to which the
interface. client gets quick response from the server.

3. The architecture is based on client server communication.

4. It makes use of synchronous By adding a new layer of AJAX Engine at the


communication. The client has to wait client side, it eliminates the start-stop-start-
to get the response from the server stop nature of communication and makes the
then only client can make the request communication asynchronous.
to the server. It is start-stop-start-stop
kind of communication.

5. With traditional web application With AJAX architecture user gets rich user
architecture user cannot get rich user interface experience.
interface experience.

6. It is less responsive. It is more responsive.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 117 Java Servlets and XML

7. Building web application is simple. The development time is more while


designing the Ajax based web application.

Extensive use of JavaScript, CSS and XML -


8. Limited use of JavaScript, CSS and
XML technologies. In fact - Most user i) standards-based presentation using XHTML
actions in the interface trigger an HTTP and CSS;
request back to a web server. ii) Dynamic display and interaction using the
Document Object Model(DOM);
iii) Data interchange and manipulation using
XML and XSLT;
iv) Asynchronous data retrieval using
XMLHttpRequest;
v) JavaScript binding everything together

Fig. 3.24.2 Traditional web application architecture

Fig. 3.24.3 AJAX web application architecture

Merits of AJAX
1. Response time is faster, hence increases performance and speed.
2. XMLHttpRequest object call as a asynchronous HTTP request to the Server for
transferring data both side. It's used for making requests to the non-Ajax pages.
3. It is used in form validation.
4. It performs fetching of data from database and storing of data into database
without reloading page.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 118 Java Servlets and XML

Demerits of AJAX

1. It has browsing compatibility issues.


2. It is impossible to bookmark AJAX updated page contents.
3. Search engine would not crawl AJAX generated content. Hence, Search Engines
like Google cannot index AJAX pages.

3.25 XMLHttpRequest Object


 XMLHttpRequest object is an important element in AJAX.
 XMLHttpRequest is an API which is used by JavaScript, VBScript and some other
scripting languages.
 The methods of XMLHttpRequest are used in transferring data between a Web
browser and a web server.
 It is because of XMLHttpRequest object, to update parts of web page without reloading
the whole page.

Syntax
Variable = new XMLHttpRequest();

Various Methods of XMLHttpRequest object


Method Purpose

new XMLHttpRequest() Creates new XMLHttpRequest object.

Open(method, URL, async,user,pwd ) To make request this method is used.

method: The request can be GET or POST

URL: The location of file

async: true(for asynchronous) and false(synchronous)

user: user name(optional)


pwd:password(optional)

send() sends the request to the server.

send(string) sends the request to the server.

setRequestHeader() Adds the label- value pair to the header.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 119 Java Servlets and XML

Various Properties of XMLHttpRequest object

Property Description

readyState Specifies the ready state of XMLHttpRequest

0: request not initialized

1: server connection established

2: request received

3: processing request

4: request finished and response is ready

onreadystatechange When readystate property changes the onreadystatechange event listener will
be automatically invoked

responseText Returns the response data as a string

status Returns the status number. Following is the meaning of various numbers
returned by the status property

200: “OK”

403: “Forbidden”

404: ”Not Found”

statusText Returns the status text as “OK”, or “Forbidden”

Example 3.25.1 Create an XMLHttpRequest to retrieve data from an XML file and display the
data in an HTML table. The data to be retrieved is a collection of stationary items stored in
an XML file.

Solution : Step 1 : Create an xml file storing the stationary items. The code is as follows -
/ELEMENTS>
<STATIONARY>
<ITEM>Notebook</ITEM>
<PRICE>40</PRICE>
</STATIONARY>
<STATIONARY>
<ITEM>Punching Machine</ITEM>
<PRICE>60</PRICE>
</STATIONARY>
<STATIONARY>
<ITEM>Pencil Box</ITEM>
<PRICE>40</PRICE>
</STATIONARY>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 120 Java Servlets and XML

<STATIONARY>
<ITEM>Eraser</ITEM>
<PRICE>5</PRICE>
</STATIONARY>
</ELEMENTS>

Step 2 : The XML file displaying the stationary items in a tabular form is as given below -
test.html
<!DOCTYPE html>
<html>
<body>
<button type="button" onclick="loadXMLDoc()">Display Stationary Items</button>
<br><br>
<table id="demo" border="1"></table>
<script>
function loadXMLDoc()
{
if(window.XMLHttpRequest)
{
xmlhttp = new XMLHttpRequest();
}
else
{
xmlhttp = new ActiveXObject("Microsoft.req");//to execute on Inter. Explorer
}
xmlhttp.onreadystatechange = function()
{
if (this.readyState == 4 && this.status == 200) {
myFunction(this);
}
};
xmlhttp.open("GET","stationary.xml",true);
xmlhttp.send();
}
function myFunction(xml)
{
var i;
var xmlDoc = xml.responseXML;
var table="<tr><th>Item</th><th>Price(Rs.)</th></tr>";
var x = xmlDoc.getElementsByTagName("STATIONARY");
for (i = 0; i <x.length; i++)
{
table += "<tr><td>" +
x[i].getElementsByTagName("ITEM")[0].childNodes[0].nodeValue +

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 121 Java Servlets and XML

"</td><td>" +
x[i].getElementsByTagName("PRICE")[0].childNodes[0].nodeValue +
"</td></tr>";
}
document.getElementById("demo").innerHTML = table;
}
</script>
</body>
</html>
Output

3.26 Coding AJAX Script SPPU : Dec.-18, 19, May-18, 19, Marks 8

Let understand how AJAX works with the help of programming example
<html>
<head>
<script type="text/javascript">
function MyFun()
{
if (window.XMLHttpRequest)
{
req=new XMLHttpRequest(); 2
}
else
{
req=new ActiveXObject("Microsoft.req");
}
req.onreadystatechange=function()
{
if (req.readyState==4 && req.status==200) 3
{

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 122 Java Servlets and XML

document.getElementById("myID").innerHTML=req.responseText;
}
}
req.open("GET","newdata.txt",true); 4
req.send();
5
}
</script>
</head>
<body>
<div id="myID">This text can be changed</div>

1
<button type="button" onclick="MyFun()">Change</button>
</body>
</html>

Script Explanation (Above numbered steps are explained here)


In above script, we have written some text which can be replaced by some another text
on button click.
1. On button click a function MyFun is invoked. Thus client triggers the event.
2. XMLHttpRequest object is used to exchange data with a server. This object
allows the user to change/update the parts of the web page without reloading it
fully. The modern web browsers such as IE7+, FireFox,Chrome have built in
XMLHttpRequest but old web browsers make use of ActiveXObject.
3. When a request to a server is sent, then onreadystatechange event is triggered.
The readyState property holds the status of the XMLHttpRequest. The readystate=4
means request is finished and response is ready. The status = 200 means “OK”
The DOM is modified and response is modified using the statement
document.getElementById("myID").innerHTML=req.responseText;

4. The request can be sent to the server by using two functions open() and send().
req.open("GET","newdata.txt",true);

GET or POST Location of file on true: means asynchronous


method server false : means asynchronous

Asynchronous communication allows fast processing of the data.


The newdata.txt file contains some updating text using which our web page can be
updated.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 123 Java Servlets and XML

newdata.txt

5. The send() method sends the request to the server.


Output

Example 3.26.1 Write AJAX script to obtain the student information stored in XML document.
The information should be displayed on clicking the button. It should be displayed in tabular
form.

Solution :

Step 1 : Create an XML file for storing the student information. The XML file is as follows

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 124 Java Servlets and XML

Student.xml
<Student>
<student_data>
<Name>AAA</Name>
<Marks>45</Marks>
</student_data>
<student_data>
<Name>BBB</Name>
<Marks>55</Marks>
</student_data>
<student_data>
<Name>CCC</Name>
<Marks>67</Marks>
</student_data>
<student_data>
<Name>DDD</Name>
<Marks>84</Marks>
</student_data>
</Student>

Step 2 : Create a AJAX script as follows -

AjaxXMLDemo.html
<!DOCTYPE html>
<html>
<body>
<h1>STUDENT INFORMATION</h1>
<button type="button" onclick="MyFun()">Click</button>
<br><br>
<table border="1" id="demo"></table>
<script>
function MyFun()
{
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function()
{
if (this.readyState == 4 && this.status == 200)
{

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 125 Java Servlets and XML

Load_XML_File(this);
}
};
xhttp.open("GET", "Student.xml", true);
xhttp.send();
}
function Load_XML_File(xml)
{
var i;
var xmlDoc = xml.responseXML;
var table="<tr><th>Name</th><th>Marks</th></tr>";
var x = xmlDoc.getElementsByTagName("student_data");
for (i = 0; i <x.length; i++)
{
table += "<tr><td>" +
x[i].getElementsByTagName("Name")[0].childNodes[0].nodeValue +
"</td><td>" +
x[i].getElementsByTagName("Marks")[0].childNodes[0].nodeValue +
"</td></tr>";
}
document.getElementById("demo").innerHTML = table;
}
</script>
</body>
</html>
Step 3 : Open the web browser and the output will be as follows -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 126 Java Servlets and XML

On clicking the button we will get

Example 3.26.2 List and explain different values of ready state and status property of the
HTTPRequestObject.
SPPU : Dec.-18, Marks 6
Solution :

readyState Holds the status of the XMLHttpRequest.

0: request not initialized

1: server connection established

2: request received

3: processing request

4: request finished and response is ready

status 200: "OK"

400:“Bad Request”

403: "Forbidden"

404: "Page not found"

500: “Internal Server Error”

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 127 Java Servlets and XML

Review Questions

1. Draw and explain how AJAX works with the help of suitable example.
SPPU : May-18, Marks 6
2. What is use of XMLHttpRequest object ? Explain its use with the help of simple JavaScript
document. SPPU : May-18, Marks 6
3. Write different applications without AJAX and with AJAX. SPPU : May-18, Marks 4
4. Explain with simple example the XMLHttp request object. List and explain different values of
readystate and status property of the HTTP request object. SPPU : May-19, Marks 5
5. What is the purpose of AJAX ? Explain with relevant example. SPPU : Dec.-19, Marks 8

3.27 Multiple Choice Questions


Q.1 The Java ____ specification defines an application programming interface for
communication between the web server and the application program.
a servlet b server
c program d none of these
Q.2 Servlet runs each request in _____.
a JVM b JRE
c servlet container d none of these
Q.3 What is bytecode ?
a Machine - specific code b Java code
c Machine - independent code d None of these
Q.4 What are the functions of Servlet container ?
a Lifecycle management b Communication support
c Multithreading support d All of the above
Q.5 Which of the following package contains servlet classes ?
a javax.servlet b javax.servlet.http
c both a and b d none of these
Q.6 Which method is used to specify before any lines that uses the PrintWriter ?
a setPageType() b setContentType()
c setResponseType() d setContextType()
Q.7 What is the lifecycle of a servlet ?
a Servlet class is loaded b Servlet instance is created
c init, Service, destroy method is invoked
d All of the above

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 128 Java Servlets and XML

Q.8 What type of servlets use these methods doGet(), doPost(),doHead, doDelete(),
doTrace() ?
a Genereic Servlets b HttpServlets
c All of the above d None of the above
Q.9 Which of the following code is used to get cookies in servlet ?
a response.getCookies() b request.getCookies()
c Cookies.getCookies() d None of the above.
Q.10 If the client has disabled cookie in the browser which session management mechanism
could the web container employ ?
a Session management using URL rewriting
b Session management using Cookies
c Either Cookies or URL rewriting
d Cookies and URL rewriting must be used together
Q.11 Servlet is initialized by calling the following method :
a service() b destroy()
c init() d none
Q.12 Common gateway interface is used to :
a generate executable files from web content by web server
b generate web pages
c stream video
d none
Q.13 The Java _________ specification defines an application programming interface for
communication between the web server and the application program.
a Servlet b Server
c Program d Randomize
Q.14 Which JDBC driver type(s) can be used in either applet or servlet code.
a Both type 1 and type 2 b Both type 1 and type 3
c Both type 3 and type 4 d Type 4 only
Q.15 XML stands for _____ .
a Extensible Markup Language b Extended Markup Language
c XYZ Markup Language d Exclusive Markup Language

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 129 Java Servlets and XML

Q.16 Correct version of the declaration which defines the XML version _____ .
a <?xml version ="1.0"/> b ?xml version="1.0"?>
c <xml version="1.0"> d none of these
Q.17 XML is _____ .
a platform independent b language independent
c both a and b d none of these
Q.18 Which language is case sensitive ?
a HTML b XML
c Both a and b d None of these
Q.19 DTD stands for _____ .
a Document Trial Data b Document Trial Definition
c Data Type Definition d Document Type Definition
Q.20 XML DOM is a standard for performing the following operation on XML elements ____.
a change b add
c delete d all the above
Q.21 DOM parser is used on _____ .
a client side b server side
c both a and b d none
Q.22 Which are techniques for defining the structure of a specific type of XML documents ?
a Schema b DTD
c Both a and b d none of the above
Q.23 Which statement is true ?
a All the statements are true
b All XML elements must have a closing tag
c All XML elements must be lower case
d All XML documents must have a DTD
Q.24 DTD includes the specifications about the markup that can be used within the
document, the specifications consists of all EXCEPT _____.
a the browser name b the size of element name
c entity declarations d element declarations

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 3 - 130 Java Servlets and XML

Q.25 Parameter entities can appear in _____.


a xml file b dtd file
c xsl file d both 1 and 2
Q.26 Which characters are illegal in XML elements ?
a > b &
c Both a and b d None of these
Q.27 The syntax for parameter entity is _____ .
a <! ENTITY % NAME DEFINITION>
b < ENTITY % NAME DEFINITION>
c <! ENTITY $ NAME DEFINITION>
d < ENTITY $ NAME DEFINITION>
Q.28 The XML DOM object is _____ .
a entity b entity reference
c comment reference d comment data
Q.29 Which of the following is not a XML storage option ?
a Native storage as XML data type
b Mapping between XML and relational storage
c Small object storage
d None of the mentioned
Q.30 Which of the following part of the XML data stored in an XML column is very important
for locking ?
a Granularity b Degree of structure
c Hierarchy d None

Answer Keys for Multiple Choice Questions :

Q.1 a Q.2 c Q.3 c Q.4 d Q.5 c


Q.6 b Q.7 d Q.8 b Q.9 b Q.10 a
Q.11 c Q.12 a Q.13 a Q.14 c Q.15 a
Q.16 b Q.17 c Q.18 b Q.19 c Q.20 d
Q.21 c Q.22 c Q.23 b Q.24 a Q.25 b
Q.26 c Q.27 a Q.28 b Q.29 c Q.30 a



TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


UNIT - IV

4 JSP and Web Services

Syllabus
JSP : Introduction to Java Server Pages, JSP and Servlets, running JSP applications, Basic JSP,
JavaBeans classes and JSP, Support for the Model-View-Controller paradigm, JSP related
technologies. Web Services : Web Service concepts, Writing a Java Web Service, Writing a Java web
service client, Describing Web Services : WSDL, Communicating Object data: SOAP. Struts :
Overview, architecture, configuration, actions, interceptors, result types, validations, localization,
exception handling, annotations.

Contents
4.1 Introduction to Java Server Pages
4.2 JSP and Servlets ............................................... April-18, .............................. Marks 5
4.3 Basics of JSP ............................................... April-18, May-18, 19,
............................................... Dec.-18, 19,........................... Marks 5
4.4 Implicit Objects ............................................... May-18, 19, Dec.-18, ............ Marks 5

4.5 JavaBeans Classes and JSP ...................................... May-18, ................................. Marks 5

4.6 Support for the Model-View-Controller Paradigm ........ Dec.-18,................................. Marks 6


4.7 Web Services Concepts .............................................. May-18,19, Dec.-18, ............. Marks 8

4.8 Writing a Java Web Service

4.9 Describing Web Services : WSDL

4.10 Communicating Object Data : SOAP


4.11 Overview ............................................... Dec.-18,................................ Marks 4

4.12 Architecture ............................................... May-18, 19 ............................ Marks 6

4.13 Execution of First Struts Applications


4.14 Configuration ............................................... Dec.-18,19,............................ Marks 6

4.15 Actions ............................................... Dec.-18, May-19, .................. Marks 6

(4 - 1)
Web Technology 4-2 JSP and Web Services

4.16 Interceptors ............................................... May-18, ................................. Marks 6

4.17 Result Types

4.18 Validations
4.19 Localization

4.20 Exception Handling

4.21 Annotations
4.22 Multiple Choice Questions

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4-3 JSP and Web Services

Part I : JSP

4.1 Introduction to Java Server Pages


 JSP stands for Java Server Pages.
 It is an alternative way than the servlet to build the dynamic web pages. It is built
on top of the servlet.
4.2 JSP and Servlets SPPU : April-18, Marks 5

 Following are some advantages of Java Server pages -


1. JSP is useful for server side programming.
2. JSP can be used along with servlets. Hence business logic for any application
can be developed using JSP.
3. Dynamic contents can be handled using JSP because JSP allows scripting and
element based programming.
4. JSP allows creating and using our own custom tag libraries. Hence any
application specific requirements can be satisfied using custom tag libraries. This
helps the developer to develop any kind of application.
5. JSP is a specification and not a product. Hence developers can develop variety
of applications and add up to performance and quality of software products.
Due to this many companies are ready to invest in JSP technology.
6. JSP is an essential component of J2EE. Hence using JSP it is possible to develop
simple as well as complex applications.
Difference between Servlet and JSP

Sr. JSP Servlet


No.
1. JSP is a scripting language that generates Servlets are the Java programs that can be
dynamic content. compiled to generate dynamic content.

2. JSP runs slower than servlet. Servlet runs faster than JSP.

3. In Model View Controller JSP acts as In Model View Controller servlet acts as
view. controller.

4. JSP can build custom tags. There is no facility of creating custom tags.

5. JSP can directly call Java beans. Servlets have no facility of calling Java bean.

6. It is easier to code in JSP. The servlets are basically complex Java


programs.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4-4 JSP and Web Services

Review Question

1. Write advantages of JSP over servlets. Also explain the life cycle of JSP.
SPPU : April-18, Marks 5

4.3 Basics of JSP SPPU : April-18, May-18, 19, Dec.-18, 19, Marks 5

4.3.1 JSP Document Structure


Every JSP document contains four elements -
1. Template text : The XML of HTML code can be directly used in JSP document.
This is called the static or fixed part of the document. This markup is called
template text. This part is not modified by JSP container.
2. Action elements : The action elements are used to create the documents
dynamically. The action elements is written in the form
i) Opening tag ii) Action body iii) Closing tag.

For example

<jsp:include> This tag works as a subroutine. It includes the response from servlet or
JSP when request is being processed.

<jsp:forward> This tag helps in forwarding the current request to servlet or to JSP page.

<jsp:element> This tag generated the XML elements dynamically.

<jsp:text> This tag is used to handle template text. When JSP pages are written as
XML documents then this tag is used.

3. Directives : JSP directives control the processing of entire JSP Page. It gives
direction to the server regarding the processing of a page. The directive elements
are enclosed within the <%@ …. %> delimiters. For example -
<%@page import="java.io.*” %>
<%@page language="java” %>
<%@page contentType="text/html” %>

4. Scriptlets : Scriptlets are nothing but java code enclosed within <% and %> tags.
For example we can write following statement in JSP document
<p>
<% out.print("JSP is eqaul to HTML and JAVA "); %> //Scriptlet
</p>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4-5 JSP and Web Services

Example of JSP document


<%@ page language="java" contentType="text/html" %>
<html> Directive
<head>
<title>Demo for Template Text</title>
</head>
<body bgcolor="gray">
Template text
<h1>Twinkle Twinkle little stars</h1>
<h2>How I wonder what you are!!!</h2>
<li>like a diamond in the sky</li>
<p>
<% out.print("JSP is eqaul to HTML and JAVA "); %>
</p>
</body>
Scriptlets
</html>

4.3.2 JSP Processing


 JSP pages can be processed using JSP container only. Following are the steps that
need to be followed while processing the request for JSP page -
1. Client makes a request for required JSP page to the server. The server must have
JSP container so that JSP request can be processed. For instance : Let the client
makes a request for xyz.jsp page.
2. On receiving this request the JSP container searches and then reads the desired
JSP page. Then this JSP page is straightaway converted to corresponding servlet.
Basically any JSP page is a combination of template text and JSP element. Every
template text is translated into corresponding println statement.
For instance :

Fig. 4.3.1
Every JSP element is converted into corresponding Java code. This phase is
called translation phase. The output of translation phase is a servlet. For
instance : our xyz.jsp gets converted to xyzServlet.java.
3. This servlet is then compiled to generate the servlet class file. Using this class the
response can be generated. This phase is called request processing phase.
4. The JSP container thus executes the servlet class file.
5. A requested page is then returned to the client as a response. Refer Fig. 4.3.2.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4-6 JSP and Web Services

Fig. 4.3.2 JSP processing

4.3.3 Running JSP Applications


For execution of JSP pages following installations are needed.
1. Java Development Kit : Download and install the latest version of JDK.
2. Tomcat WebServer : The Tomcat is a web container provided by Apache Web
server. Now a days XAMPP software package is installed for running JSP, Servlets
and PHP programs.
Note that before running any JSP page it is essential to start the tomcat by double
clicking the startup.bat file present in the tomcat directory.

Example 4.3.1 Write a simple JSP page for displaying the message “This is my first JSP
page!!!”
SPPU : May-18, Marks 5

Solution : We follow these steps to get the JSP page displayed -


Step 1 : First of all open some text editor like Notepad and type the following code.

hello.jsp
<%@ page language="java" contentType="text/html" %>
<%@ page import ="java.util.*" %>
<html>
<!-- This is basic JSP page -->
<title>JSP Demo </title>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4-7 JSP and Web Services

<body>
<%-- Displaying the message on the browser --%>
<% out.println("This my first JSP page!!!"); %>
</body>
</html>
Step 2 : Copy this file to webapps directory of your tomcat folder.
Step 3 : Start the Tomcat Web server.
Step 4 : Open some suitable web browser like Firefox or Internet Explorer. Type the path
for the JSP document and the output will be as follows -

Script explanation
The first line is the page directive statement
<%@ page language="java" contentType="text/html" %>
using this line we are specifying that the language used in this script is Java and the
contentType specifies the MIME type which is text/html.
Then on the next line we have imported the Java library package java.util using
import statement -
<%@ page import ="java.util.*" %>
We can specify the JSP comments in two ways
<!—HTML style comment statement -->
<%-- JSP comment statement --%>
As JSP is commonly used along with HTML, it also supports the HTML comments.
For displaying the message on the web browser we have written the message using
the Java statement
out.println("This my first JSP page!!!");
Normally any Java code must be written within <% and %>.
Then all the corresponding tags are closed.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4-8 JSP and Web Services

4.3.4 Directives
JSP directives control the processing of entire JSP Page. It gives direction to the server
regarding the processing of a page.

Syntax
<%@ directive name [attribute name=“value” attribute name=“value” ........]%>

1. Page directive :
The page directive is used to provide the information about the page. Various
attributes of page directive are -
i) import ii) language iii) ContentType
iv) extends v) session vi) buffer
vii) autoFlush viii) isThreadSafe ix) info
x) errorPage xi) IsErrorPage
For example -
<%@page import="java.io.*” %>
<%@page language="java” %>
<%@page contentType="text/html” %>

2. Include directive :

Include directive is used to copy the content of one JSP page to another. It’s like
including the code of one file into another.
For example
<% @include file=calculate.jsp %>

3. Taglib directive :
This directive basically allows user to use custom tags in JSP. The custom tags are
those which are created by user.
For example -
<%@ taglib uri="mytaglib" prefix="sampletag" %>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4-9 JSP and Web Services

Example 4.3.2 Write a JSP program to display current date and time.

Solution : DateDemo.jsp
<%@ page language="java" contentType="text/html" %>
<%@ page import ="java.util.*" %>
<html>
<body>Today's Date is:
<%= new Date().toString() %>
</body>
</html>
Output

4.3.5 Comments
We can specify the JSP comments in two ways
<!—HTML style comment statement -->
<%-- JSP comment statement --%>
As JSP is commonly used along with HTML, it also supports the HTML comments.

4.3.6 Scripting Elements


There three types of scripting elements in JSP.
1. Expression 2. Scriptlet 3.Declaration

1. Expression
The expression tag is used to represent the expression in JSP page. The syntax of
writing expression is -
<%= Java Expression %>
For example -
<html>
<head>
<title>JSP Expression Demo</title>
</head>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 10 JSP and Web Services

<body>
Value of Expression is :
<%= (10*20) %>
</body>
</html>
Output

2. Scriptlet
 The code that appears between the <% and %> delimiters is called a scriptlet.
Scriptlets are nothing but java code enclosed within <% and %> tags.
 The everything other than a JSP statement in the JSP is called template text. For
example.

Templatetext.jsp
<%@ page language="java" contentType="text/html" %>
<html>
<head>
<title>Demo for Tempplate Text</title>
</head>
<body bgcolor="gray">
<h1>Twinkle Twinkle little stars</h1>
<h2>How I wonder what you are!!!</h2>
<li>like a diamond in the sky</li>
<p>
<% out.print("JSP is eqaul to HTML and JAVA "); %>
</p>
</body>
</html>
In the above code the boldfaced code is a template text. The output for the above code
will be

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 11 JSP and Web Services

Output

3. Declaration
We can declare a variable or method in JSP inside declaration tag. We can declare
static member, instance variable and methods inside declaration tag. Syntax of
declaration tag -
<%! Declaration code %>
For example -
<html>
<head>
<title>JSP Declaration Demo</title>
</head>
Output
<%!
String msg = "Hello";
%>
<body>
Message is:
<% out.println(msg); %>
</body>
</html>
The above JSP code contains the declaration within <%! %> tag.
Example 4.3.3 Develop a simple JSP application that accepts user’s age and displays a message
according to the following rules :
i) Age<15 : Message : You are a kid!
ii) Age between 16 and 40 : You are young!
iii) Age above 40 : You are old!

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 12 JSP and Web Services

Solution : For developing this application we will create an HTML form for inputting the
age value and then invoke the JSP page on which the appropriate messages are given
based on the age.

Step 1 :

InputAge.html
<html>
<head>
</head>
<body>
<form method="get" action="AgeMessage.jsp">
<strong>Enter Age:</strong>
<br/>
<input type="text" name="Age">
<br/>
<input type="submit" value="Enter">
</form>
</body>
</html>
Step 2 : The JSP code is as follows -

AgeMessage.jsp
<html>
<body>
<%@ page language="java" contentType="text/html" %>
<%@page import="java.io.*" %>
<%
String msg="";
String age;
int age_val;
age=request.getParameter("Age");
age_val=Integer.parseInt(age);
if(age_val<15)
msg+="You are a kid!";
if((age_val>16)&&(age_val<40))
msg+="You are young!";
if(age_val>40)
msg+="You are old!";
out.println("<h3>"+msg+"</h3>");
%>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 13 JSP and Web Services

Step 3 : The output will be as follows -

Example 4.3.4 Write a JSP scriptlet for displaying even numbers between 1 to 50.

SPPU : April-18, In Sem, Marks 5

Solution :
<html>
<body>
<%@ page language="java" contentType="text/html"%>
<%@ page import="java.io.*"%>
<%
for(int i=1;i<=50;i++)
{
if(i%2==0)
out.println("<p>"+i+"</p>");
}
%>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 14 JSP and Web Services

4.3.7 Actions and Templates


 The standard actions are those actions that can be defined by the JSP specification
itself.
 Following is a list of standard actions.
Action Element Description

<jsp:useBean> This tag is used to instantiate the object of java bean.

<jsp:setProperty> This tag is used to set the property value for the java bean.

<jsp:getProperty> This tag is used to get the property value from the java bean.

<jsp:include> This tag works as a subroutine. It includes the response from servlet or
JSP when request is being processed.

<jsp:param> For adding the specific parameter to the request this tag is used. Normally
this tag is used inside <jsp:include> or <jsp:forward>

<jsp:forward> This tag helps in forwarding the current request to servlet or to JSP page.

<jsp:plugin> This tag is used to generate HTML code and to embed the applet into it.

<jsp:attribute> This tag sets the value of the action attribute

<jsp:element> This tag generated the XML elements dynamically.

<jsp:text> This tag is used to handle template text. When JSP pages are written as
XML documents then this tag is used.

<jsp:body> This tag is used to set the body element.

Let us now discuss the standard actions by creating appropriate JSP pages.
Include action
Using the <jsp:include> action we can include different files in current jsp pages.
For example -
Include_action.jsp
<html>
<head>
<title> Include action Demo </title>
</head>
<body>
<h1>This page contains include action</h1>
<jsp:include page="test_include.html" />
<jsp:include page="test_jsp.jsp" />
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 15 JSP and Web Services

Now the static html page can be

test_include.html
<html>
<body>
Hello How are you?
</body>
</html>
Now the JSP page for displaying dynamic content is

test_jsp.jsp
<html>
<body>
<br>Time is <%= new java.util.Date().getHours()%>
: <%= new java.util.Date().getMinutes()%>
</body>
</html>

For getting the output, open the web browser and open our main JSP page
Include_action.jsp, it is as follows-

Forward action
 Using forward action we can forward the current request to corresponding
JSP page or servlet.
 Here is a simple demonstration in which we have created two web pages
the first one is a main JSP page named as first.jsp in which we are using JSP
action forward. And forwarding the current request to an HTML page
which is named as Second.html.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 16 JSP and Web Services

first.jsp
<html>
<head>
<title> Forward action Demo </title>
</head>
<body>
<h1>This page contains forward action</h1>
<jsp:forward page="Second.html" />
</body>
</html>

Second.html
<html>
<body>
<strong>You are forwarded to Second page!!</strong>
</body>
</html>
For getting the output open the web page and open the main JSP page that is first.jsp
and you will get the following output -
Output

useBean action
 Java beans are reusable components. We can use simple Java bean in the JSP.
 Beans are used in the JSP pages as the instance of class. We must specify the scope
of the bean in the JSP page. Here scope of the bean means the range time span of the
bean for its existence in JSP.
 Bean is basically a Java class with get and set methods.
 Let us understand the useBean action with illustrative example.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 17 JSP and Web Services

Example 4.3.5 Write a JSP document to display number of times user is visiting particular
page.

Solution :
Step 1 : Create a simple bean in which a variable count is maintained. This count can be
incremented using the JSP page.

CounterDemo.java
public class CounterDemo
{
public int count;
public CounterDemo()
{
count=0;
}
public int getCount()
{
return count;
}
public void setCount(int count)
{
this.count=count;
}
}
Step 2 : Now create a JSP page which make use of the bean created in step 1 in the
session scope.

beanJsp1.jsp
<html>
<head>
<title> Use of Bean with session scope </title>
</head>
<body>
<jsp:useBean id="bean_id" class="CounterDemo" scope="session" />
<%
bean_id.setCount(bean_id.getCount()+1);
%>
Your count is now <%= bean_id.getCount() %>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 18 JSP and Web Services

Step 3 : Open two different web browsers Mozilla Firefox and Internet Explorer and
open the same JSP page in both the browsers, repeatedly refresh the JSP page in
both the browsers and observe it.

Example 4.3.6 Write the differences between include action and include directive in JSP.
SPPU : Dec.-18, May-19, End Sem, Marks 5

Solution : The difference is as follows -


1) Include directive includes the file at translation time - that is when the JSP gets
converted into the equivalent servlet whereas the include action includes the file at
runtime.
2) If the included file is changed but not the JSP which is including it then the changes
will reflect only when we use include action tag. The changes will not reflect if you
are using include directive as the JSP is not changed so it will not be translated for
request processing and hence the changes will not reflect.
3) Syntax difference : Include directive : <%@ include file="file_name" %> whereas
include action has like this <jsp:include page="file_name" />
4) When using include action tag we can also pass the parameters to the included page
by using param action tag but in case of include directive it's not possible.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 19 JSP and Web Services

Review Questions

1. What are the usage of JSP directives and JSP actions.


SPPU : April-18, Marks 5
2. Write JSP program to demonstrate use of page directive, scriptlet and expression tag.
SPPU : Dec.-19, Marks 5

4.4 Implicit Objects SPPU : May-18, 19, Dec.-18, Marks 5

 The implicit objects are predefined variables used to access request and application
data. These objects are used by the scripting elements. Following is a list of implicit
objects.
Variable Class/Interface name Meaning Sample methods
name

application javax.servlet.ServletContext This object log()


provides the
getServerinfo()
resources
shared within a
web
application.

config javax.servlet.ServletConfig It helps in getInitParameter()


passing the
getServletName()
information to
servlet or JSP
page during
initialization.

request javax.servlet.http.HttpServletRequest It provides the getContentLength()


methods for
getLocalAddr()
accessing the
information getServerName()
made by
current request.

response javax.servlet.http.HttpServletResponse It provides the addCookie()


methods
addHeader()
related to
adding cookies, flushBuffer()
sessions or
setting header. getContentType()

setContentType()

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 20 JSP and Web Services

out javax.servlet.jsp.JspWriter It provides the clear()


methods
newLine()
related to I/O

page java.lang.Object This variable is


assigned to
instance of JSP
implementation
class. It is
rarely used
variable.

pageContext javax.servlet.jsp.PageContext It provides getPage()


access to
getRequest()
several JSP
page attributes getResponse()

getSession()

Review Questions

1. Create a simple JSP pages which will demonstrates use of implicit session objects in JSP.
SPPU : May-18, Dec.-18, Marks 5
2. List and elaborate any five JSP implicit objects.
SPPU : May-19, Marks 5

4.5 JavaBeans Classes and JSP SPPU : May-18, Marks 5

 Java beans are reusable components. We can use simple Java bean in the JSP.
 Beans are used in the JSP pages as the instance of class. We must specify the scope
of the bean in the JSP page. Here scope of the bean means the range time span of the
bean for its existence in JSP.
 Bean is basically Java class with getXX and setXX methods.

Characteristics for JavaBean Class


1) Java Bean class contains a default no argument constructor. This constructor
must have the access specifier as public.
2) It should be serializable and should implement serializable interface.
3) It can have any number of properties which can be read or written. For these
properties we write getter and setter methods.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 21 JSP and Web Services

JavaBean Properties

 A JavaBean Property is a named attribute that can be accessed using the object.
 The JavaBean properties can be accessed through two methods namely
1) getPropertyName() : This method is called accessor method. It returns the
property value. This method is written in some special way. For example - If the
property is rollNo then the method name for rollNo is getRollNo()
2) setPropertyName() : This is called mutator method. This method is generally
used to assign the value to the properties. This method is written in some special
way. For example - If the property is rollNo then method name will be
setRollNo()
The read-only attribute is for getPropertyName() method and write-only attribute is
for setPropertyName() method.
Example : Bean program using JSP for Employee Information.
Step 1 : Create a Bean program in some package. I have created a folder(as a package)
named BeanProg. The code for JavaBean class is written as follows -
Employee.java
package BeanProg;
public class Employee implements java.io.Serializable {
private String empName=null;
private int empNo=0;
public Employee() { //no argument constructor
}
public String getEmpName() {
return empName;
}
public int getEmpNo() {
return empNo;
}
public void setEmpName(String empName) {
this.empName=empName;
}
public void setEmpNo(int empNo) {
this.empNo=empNo;
}
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 22 JSP and Web Services

Step 2 : The JSP code can be written as follows -


EmpBeanDemo.jsp
<html>
<head>
<title> JSP BEAN DEMO </title>
</head>
<body>
<jsp:useBean id="empID" class="BeanProg.Employee">
<jsp:setProperty name = "empID" property = "empName" value = "AAA"/>
<jsp:setProperty name = "empID" property = "empNo" value = '10'/>
</jsp:useBean>
<p>Employee Name:
<jsp:getProperty name = "empID" property = "empName"/>
</p>
<p>Employee Number:
<jsp:getProperty name = "empID" property = "empNo"/>
</p>
</body>
</html>
Step 3 : Start tomcat and open the JSP page in Web browser you will get the output as
follows -
Output

Example 4.5.1 Write a client server JSP program to find the simple interest and display the
result in the client.

Solution : This program is created using following steps.


Step 1 : Create an simple HTML form for inputting the values of P, N and R. The
HTML document for this is as given below.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 23 JSP and Web Services

Input.html
<html>
<head><title>Input Form</title></head>
<body>
Enter following values:<br/>
<form method="post" action="interest.jsp">
Amount:<input type="text" name="amount" value="" size="10"/>
Period:<input type="text" name="period" value="" size="3"/>
Rate of Interest:<input type="text" name="rate" value="" size="3"/>
<input type="submit" value="Submit"/>
</form>
</body>
</html>
Step 2 : Create JSP page which acts as a client to receive the values for P,N and R.
These values will be sent to the server Java program for calculating the simple interest.
The calculated interest value is displayed by this same JSP page. The code for this is as
follows -
Interest.jsp
<html>
<head>
<title> Simple Interest Calculation Demo </title>
</head>
<body>
<jsp:useBean id="bean_id" class="interestcalcDemo.InterestDemo" scope="session" />
<% String s_p=request.getParameter("amount");
int p=Integer.parseInt(s_p);
bean_id.setP(p);
Calling server Java program for
String s_n=request.getParameter("period"); computing the simple interest.
int n=Integer.parseInt(s_n);
bean_id.setN(n);
Collecting values from input.html
String s_r=request.getParameter("rate");
created in Step 1 and sending them to
int r=Integer.parseInt(s_r);
bean_id.setR(r); sever program using method set
%>
</form>
Obtaining interest
Amount = <%= p%><br/>
Period = <%= n%><br/> value from server
Rate = <%= r%><br/>
<strong>Interest is now <%= bean_id.getI() %><br/></strong>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 24 JSP and Web Services

Step 3 : Following is a Java bean program which acts as a Server. It calculated the simple
interest using the formula (p*n*r)/100. This value is then returned to the client JSP
program created in Step 2. The code for server java program is as follows -
InterestDemo.java
package interestcalcDemo;
public class InterestDemo Output
{
public int p,n,r;
public InterestDemo()
{
p=0;n=0;r=0;
}
public int getI()
{
int i=(p*n*r)/100;
return i;
}
public void setP(int p)
{
this.p=p;
}
public int getP()
{
return p;
}
public void setN(int n)
{
this.n=n;
}
public int getN()
{
return n;
}
public void setR(int r)
{
this.r=r;
}
public int getR()
{
return r;
}
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 25 JSP and Web Services

Review Question

1. What is the JSP action tags ? Discuss in details jsp:useBean action tag.
SPPU : May-18, Marks 5

4.6 Support for the Model-View-Controller Paradigm


SPPU : Dec.-18, Marks 6
 The design model of JSP application is called MVC model. The MVC stands for
Model-View-Controller. The basic idea in MVC design model is to separate out
design logic into three parts - modelling, viewing and controlling.
 Any server application is classified in three parts such as business logic,
presentation and request processing.
 The business logic means the coding logic applied for manipulation of application
data. The presentation refers to the code written for look and feel of the web page.
For example: background color, font style, font size, placing of controls such as text
boxes, command buttons and so on. The request processing is nothing but a
combination of business logic and presentation. The request processing is always
done in order to generate the response.

Fig. 4.6.1 Model View Controller (MVC)

 According to the MVC design model, the model corresponds to business logic, view
corresponds to presentation and controller corresponds to request processing.
Advantages of using MVC design model
 The use of MVC architecture allows the developer to keep the separation between
business logic, presentation and request processing.
 Due to this separation it becomes easy to make changes in presentation without
disturbing the business logic. The changes in presentation are often required for
accommodating the new presentation interfaces.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 26 JSP and Web Services

Review Question

1. What is MVC ? Draw and explain MVC architecture for developing web applications.
SPPU : Dec.-18, Marks 6

Part II : Web Services

4.7 Web Services Concepts SPPU : May-18,19, Dec.-18, Marks 8

Definition : The Web Services are the software systems that are displayed by the
web browser using the web protocol. These software systems are used by the some
software applications rather than by end-users directly.

 Web service is a software system designed which is independent of specific


hardware or software on which it is running.
 Examples of a web service are -
1. Credit card validation system - For using this service the client simply enters the
ID and password for the credit card and web service reports the validity of it.
2. Whether forecast system - The clients submits the location and the web service
returns the information about current whether as well as it may report some
predictions.
3. Currency converter - The client enter the source and destination currency along
with the amount and appropriate converted information will be displyed.

Fig. 4.7.1 Basic web service model

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 27 JSP and Web Services

Following are the steps that a web service model follows -


Step 1 : In the first step, a service provider publishes a web service in the web service
registry.
Step 2 : A web client who demands for some web service searches in the registry. After
finding a match for the desired web service in the registry. After finding a match for the
desired web service in the registry, the client chooses it.
Step 3 : The client binds to the corresponding web service provider and invokes for the
service.

4.7.1 Components of Web Services


The role of various components such as XML, SOAP, WSDL, UDDI in web service
building is as shown below -

Fig. 4.7.2 Web service elements

 At the lowest level of web services there are simply XML files that are for data level
description.
 SOAP - Simple Object Access Protocol is a simple XML based protocol which
allows exchange of messaging over HTTP.
 Typically web services make use of this protocol for exchange of information .
o The SOAP makes use of JAX-RPC component. These are JAVA API for XML
that makes use of Remote Procedure Calls.
o Basically SOAP defines message structure, encoding rules and conventions for
exchange of information in RPC programming model.
o The following table describes core JAX-RPC interfaces and classes.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 28 JSP and Web Services

Interface / Class Description

Service Main client interface. Used for both static and dynamic
invocations.

Service Factory This is a factory class which is used to create services

Stub It is used by client for invoking the web services.

Call For invoking the web services the call is used.

JAXRPCException This exception is thrown when an error occurs while invoking


web service.

 At the higher level very important element of web service lies i.e. WSDL. The Web
Service Description Language is used for abstract description of web services. This
description is provided in XML document. When the client wants to make use of
web service, the users of the client make read this description file and understand
what input data is needed to perform the web service. Such a special file is called
WSDL i.e. Web Services Description Language.
 UDDI i.e. Universal Description and Discovery Integration, provides a directory of
web services, so that client can easily discover the services of their choices. The
UDDI maintains a registry in which the web services are registered.
 In this chapter we will learn how to develop a simple web service using JAX-RPC.
Further we will learn how to build a web client for using this service.

Review Questions

1. Identify and justify benefits of using web services ?


SPPU : May-18, Marks 6
2. What are web services ? List and discuss components of web services.
SPPU : Dec.-18, Marks 6
3. What are the web services ? List and explain layers in protocol stack of web service
architecture.
SPPU : May-19, Marks 8

4.8 Writing a Java Web Service


In this section, we will create two Web Projects – one for Server and other for Client.
The Server defines the web service and client invokes this web service
We can develop a web service using Apache Axis2 and Eclipse.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 29 JSP and Web Services

Prerequisite :
1) JDK must be installed.
2) Eclipse must be installed
3) Apache Server, Tomcat must be installed. Install the software package XAMPP
for this purpose.
Configuring Tomcat to Eclipse
Step A : To integrate Tomcat Server with your Eclipse, Select File->New->Other… from
Eclipse main menu.
Step B : Select Server->Server and click Next

Step (3) Select Tomcat Version XX and click Next.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 30 JSP and Web Services

Step C : Browse to the folder of Tomcat. If XAMP is installed then it is


c:\XAMPP\tomcat
Step D : Click Finish
4) Install Axis2.
Installation of Axis 2 :
Step 1 : Open the web browser and get the axis2 package using following URL
http://axis.apache.org/axis2/java/core/download.html
Step 2 : Click on Binary Distribution Link and download axis2-1.7.9-bin.zip. Also
download axis2-1.7.9-war.zip
Step 3 : Unzip both the folders and copy these folders at your c:\tompcat-
directory\webapps folder. Following screenshot helps in understanding the location

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 31 JSP and Web Services

Configuring Axis2 in Eclipse


Step 1 : Open the Eclipse.
Step 2 : Click on Window -> Preferences.
Step 3 : Locate Web Services. Click Axis2 Preferences.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 32 JSP and Web Services

Step 4 : Set the location of Axis2 folder with the help of Browse.. button. It is your
Webapps folder in Tomcat directory. On successful deploying of Axis2, we get “Axis2
runtime loaded successfully” message. Click Apply and then Ok button.
Following screenshot illustrates it.

Let us now discuss step by step - how to create a simple Web Service.

Example 4.8.1 Create a web service in java environment to return the sum of two integers with
necessary deployment procedures.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 33 JSP and Web Services

Solution :

Stage I : Creating Server

Step 1 : Click on Eclipse icon. Click on File->New->Dynamic Web Project. Give the
suitable name to the project. I have given the project name as WebService. Set the Tomcat
Web Server and appropriate version number. Following screenshot illustrates this.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 34 JSP and Web Services

Click Finish button.


Step 2 : Locate src folder under the project in WebService project. The snapshot of Project
Explorer is as shown below

Right click on src folder Select New-> Class

A New Class Window opens up. Give suitable Package name, Class name and
uncheck the check box for void main function. Then click Finish button. It is illustrated
by following screenshot.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 35 JSP and Web Services

Step 3 : Now write the following code for MyServer.java .


package com.mypackage;

public class MyServer {


public int add(int a,int b){

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 36 JSP and Web Services

return a+b;
}
}
Save the above code.
Step 4 : Now right click on src folder. Click New->other->Web Services->Web Service.
Then click Next button.

The Web Services window will appear. Write the name of service implementation and
click on Web service runtime:Apache Axis. Following screenshot shows this -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 37 JSP and Web Services

Click on Apache Axis2 and then click Ok button. Refer following screenshot.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 38 JSP and Web Services

Then click on Finish button. You will get the progress window as,

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 39 JSP and Web Services

This will generate the WSDL file for your application.


Step 5 : To view the generated WSDL file we need to open up the Web Browser in
Eclipse. For that
1. Open Web Browser present on the Toolbar

2. Type the URL as follows -

3. Now click on Services. Your Web Service name MyServer can be located on the
page.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 40 JSP and Web Services

4. Just click on MyServer link another web page will be opened up in the browser.
This is actually your WSDL file. Copy the full URL for WSDL file marked in screenshot
given below. Save this URL in some Notepad file. Note that: We need this URL during the
creation of Client.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 41 JSP and Web Services

Stage II : Creating Client for Web Service

Step 6 : Now go to File->New->Dynamic Web Project. Give suitable name for your
application. Here we are creating a client for the Web service created in above steps.
Hence I have given the name WebServiceClient. Then click Finish button.
Step 7 : Now under WebServiceClient, right click on src folder. Click on New->Other->
Web Services->Web Service Client

Click the Next button. Now on Web Services window. Copy the URL of WSDL which
you have copied in Step 5(4).

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 42 JSP and Web Services

Then Select Web Service runtime:Apache Axis. Set it to Apache Axis2 click OK
button. Then Click on Finish button. You will get Progress Information and then two files
will get generated. These are as shown in following screenshot.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 43 JSP and Web Services

Step 8 : Now right click on src folder of WebServiceClient. Click on New->Class. The
New Java Class window will appear. Set appropriate package name, class name and
Check for void main method. Here is the screenshot.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 44 JSP and Web Services

Click on Finish button. You can now write the Java Client code for web service. The
code is as follows,
MyClient.java
package com.mypackage;
import com.mypackage.MyServerStub.Add;
import com.mypackage.MyServerStub.AddResponse;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 45 JSP and Web Services

public class MyClient {


/**
* @param args
*/
public static void main(String[] args) throws Exception{
// TODO Auto-generated method stub
MyServerStub stub=new MyServerStub();
Add p=new Add();
p.setA(11);
p.setB(22);
AddResponse res=stub.add(p);
int c=res.get_return();
System.out.println("Addition: "+c);
}
}

Step 8 : Right click on MyClient.java file in Project Explorer. Click on Run As -> Java
Application

You will get the output at the Console window as follows,

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 46 JSP and Web Services

Troubleshooting :
We may get following error on running the above client
Exception in thread "main" org.apache.axis2.AxisFault:…


To overcome through this Exception, we need to make some changes in services.xml
file. It can be located in the Web Services folder. To locate this xml file, follow the path as
Web Content-> WEB-INF-> Services->MyServer->META-INF. Locate services.xml
Change following lines
<messageReceivermep=http://www.w3.org/2004/08/wsdl/in-only
class="org.apache.axis2.rpc.receivers.RPCInOnlyMessageReceiver" />
<messageReceivermep=http://www.w3.org/2004/08/wsdl/in-out
class="org.apache.axis2.rpc.receivers.RPCMessageReceiver"/>

To
<messageReceivermep=http://www.w3.org/ns/wsdl/in-only
class="org.apache.axis2.rpc.receivers.RPCInOnlyMessageReceiver"/>
<messageReceivermep=http://www.w3.org/ns/wsdl/in-out
class="org.apache.axis2.rpc.receivers.RPCMessageReceiver"/>

Stop the Apache Tomcat Server and start it again. Now Run your MyClient.java file as
Java Application and you will get the required output.

4.9 Describing Web Services : WSDL


 The WSDL is a Web Service Descriptor Language which is based on XML.
 The purpose of this file is to describe the web service and the method of accessing it.
 WSDL is a W3C recommendation.
 It contain various definitions. Following elements are described in WSDL file.

Elements Description

types It specifies the data types of the symbols used by the web service.

messages It specifies the messages used by the web service.

portType It specifies the name of the operation (function) defined by the web service

binding It specifies the name of the protocol of the web service, typically it is SOAP.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 47 JSP and Web Services

1) Types
If we declare and use some variable in the web service then their data types can be
specified.
For example -
<?xml version="1.0" encoding="UTF-8"?>
<definitions name="SimpleCalculator" targetNamespace="http://tempuri.org/wsdl" >
<types>
<schema targetNamespace="http://tempuri.org/types">
<import namespace="http://schemas.xmlsoap.org/soap/encoding/"/>
<complexType name="CalciClass">
<sequence>
<element name="operator1" type="double"/>
<element name="operator2" type="double"/>
<element name="operation" type="String"/>
</sequence>
</complexType>
</schema>
</types>
2) Messages
The messages define the part of the element along with the data types. The message
name specified the name of the function.
In following example the HelloFun is a name of the function which is declared in the
interface named MyInterface. The return parameter is specified by
name="MyInterface_HelloFunResponse".
For example -
<?xml version="1.0" encoding="UTF-8"?>
<definitions name="SimpleHelloMessage" targetNamespace="http://tempuri.org/wsdl" >
<types/>
<message name="MyInterface_HelloFun">
<part name="String_1" type="xsd:string"/>
</message>
<message name="MyInterface_HelloFunResponse">
<part name="result" type="xsd:string"/>
</message>
3) PortTypes
This is an important element of the WSDL file. It defined various operations that can
be performed by the web service.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 48 JSP and Web Services

Various operation types are -


Elements Description

one-way This operation will send the message but it will not get any response.

request-response This operation will send a message and will receive a response.

Solicit-response This operation will send a message and will wait for a response.

Notification This operation will send a message and will not wait for a response.

The messages in portTypes define the name of the operation along with the prefix tns
where tns stands for TypeNamespace.
4) Binding
The binding defines the message format and details of the protocol.
<?xml version="1.0" encoding="UTF-8"?>
<definitions name="SimpleHelloMessage" targetNamespace="http://tempuri.org/wsdl" >
<types/>

<binding name="MyInterfaceBinding" type="tns:MyInterface">


<soap:binding transport="http://schemas.xmlsoap.org/soap/http" style="rpc"/>
<operation name="HelloFun">



There are three main elements -
binding
The binding defines name which defines the name of the binding and type attributes
specifies the port which is typically the name of the interface file.
soap:binding
The soap:binding defines transport and style attributes. The style is remote procedure
call which allows the distributed clients to access the web service.
operation
The operations defines the port operations. Each operation contains the
soap:operation, input and output elements. The soap:body element provides the
communication details such as whether or not the associated message is encoded and if it
is encoded then the encodingStyle is specified.
5) Service
The service element specifies the name for overall web service.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 49 JSP and Web Services

<?xml version="1.0" encoding="UTF-8"?>


<definitions name="SimpleHelloMessage" targetNamespace="http://tempuri.org/wsdl" >
<types/>


….
<service name="SimpleHelloMessage">
<port name="MyInterfacePort" binding="tns:MyInterfaceBinding">
<soap:address location="REPLACE_WITH_ACTUAL_URL"/>
</port>
</service>
</definitions>

4.10 Communicating Object Data : SOAP


 Simple Object Access Protocol (SOAP) is a protocol based on XML. It is used by the
web services for exchange of information. It is a W3C recommendation.
 This exchange of information is done over HTTP. This is a platform and language
independent protocol.
 The client-server communication is based on RPC. The HTTP does not designed to
handle the distributed objects that are required by the RPC. Hence another
application protocol is build over HTTP which popularly known as SOAP. SOAP
allows to talk different applications that are running in two different operating
systems.

4.10.1 Structure of SOAP


 The structure of the SOAP is defined by four building blocks.

Fig. 4.10.1 SOAP building blocks


1) Envelop
The Envelop is the root of any SOAP document. It identifies that the XML document as
a SOAP message. It defines two things - Namespace and encodingStyle. The Namespace
value can be given as -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 50 JSP and Web Services

xmlns:soap="http://www.w3.org/2001/12/soap-envelope".
The encoding style is useful to define the data types used in the document. For
example the value of encoding can be given as -
soap:encodingStyle=“http://www.w3.org/2001/12/soap-encoding”
2) Header
The SOAP header field is optional. It contains the header information. The header
contains three attributes such as mustUnderstand, actor and encodingStyle
The mustUnderstand attribute specifies 0 or 1. If the value is 1 then it means that the
receiver should process the header.
Normally the SOAP message travels over a message path having the endpoints at the
two ends. The SOAP actor is used to specify the URI for this endpoint.
The encodingStyle is useful to define the data types used in the document
The SOAP header defines how the recipient should process the SOAP message.
3) Body
The required SOAP Body element contains the actual SOAP message intended for the
ultimate endpoint of the message.
4) Fault
This is optional element of the SOAP message. It is used to represent the error code. It
consists of elements such as faultcode which is a code for fault. The faultstring message
gives the details about the fault.

4.10.2 SOAP and HTTP


HTTP communicates over TCP/IP. HTTP is based on Request-Response mechanism.
SOAP is a HTTP Request-Response protocol. SOAP is a combination of HTTP and XML.
The SOAP request can be HTTP GET or HTTP POST request. Each request consists of
two HTTP headers : content-type and content-length. The content-type specifies the
MIME type and the content-length specifies the size of the message in bytes. After this
header the body part begins which defines SOAP Envelop, Header, Body and Fault.
Example
The SOAP request can be
POST /mycreation HTTP/1.0
Host: www.mywebsite.com
Content-Type: text/xml; charset=utf-8
Content-Length: 500
<?xml version="1.0"?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV="http://www.w3.org/2001/12/soap-envelope"

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 51 JSP and Web Services

SOAP-ENV:encodingStyle="http://www.w3.org/2001/12/soap-encoding">
<SOAP-ENV:Body xmlns:m="http://www.mywebsite.com/mycreation">
<m:GetDetails>
<m:Name>ABCD</m:Name>
</m:GetDetails>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
The SOAP response can be
HTTP/1.0 200 OK
Content-Type: text/xml; charset=utf-8
Content-Length: 500
<?xml version="1.0"?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV="http://www.w3.org/2001/12/soap-envelope"
SOAP-ENV:encodingStyle="http://www.w3.org/2001/12/soap-encoding">
<SOAP-ENV:Body xmlns:m="http://www.mywebsite.com/mycreation">
<m:GetDetailsResponse>
<m:ItemDetails>This is a my new creation</m:ItemDetails>
</m:GetDetailResponse>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>

4.10.3 SOAP Encoding


SOAP makes use of XML Schema to encode the programming constructs. Following
are examples of SOAP encoding.
1. Encoding of Struct Data
Following is a code fragment which can be encoded as follows -
<xs:element name="Student">
<xs:complexType>
<xs:sequence>
<xs:element name="Name" type="xs:string"/>
<xs:element name="RollNo" type="xs:integer"/>
<xs:element name="address" type="tns:Address"/>
</xs:sequence>
<xs:element name="Address">
<xs:complexType>
< xs:sequence>
< xs:element name="street" type="xsd:string"/>
< xs:element name="city" type="xsd:string"/>
< xs:element name="country" type="xsd:string"/>
</ xs:sequence>
</xs:complexType>
</e:element>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 52 JSP and Web Services

The following is an example of how the preceding schema definition could be


subsequently used in a SOAP encoding.
<e:Student>
<Name>AAA</Name>
<RollNo>11</RollNo>
<address>
<street>XYZ Road</street>
<city>PQR City</city>
<country>India</country>
</address>
</e:Student>
2. Encoding of Arrays
An array in SOAP is of type SOAP-ENC:Array
<element name="myArray"
type="SOAP-ENC:Array"/>
The preceding schema can be represented in SOAP encoding as follows -
<myArray SOAP-ENC:arrayType="xsd:int[3]">
<number>1</number>
<number>2</number>
<number>3</number>
</myArray>
The above encoding shows that there is an array of three integers. All these members
of array are called number.

4.10.4 RPC Representation


 The RPC (Remote Procedure Call) is a mechanism used when the client makes a call
to a method that resides on another machine. The SOAP has a support for RPC
representation.
 The style attribute of soap:binding element in the WSDL document makes use of
string “rpc” to denote that the communication with the client is in RPC style.
<soap:binding transport=”http://schemas.xmlsoap.org/soap/http”
style=”rpc”/>
 The soap:body element indicated using an encoding specified by SOAP 1.1 to
represent RPC.
 In SOAP specified representation of RPC calls, the call is modeled as struct.
 The specified structure used in SOAP representation of RPC call has a name for the
remote procedure call and has one accessor for each parameter that is to be passed
to the procedure. This struct us then encoded as XML markup. This markup is then
made a child of SOAP body element.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 53 JSP and Web Services

For example - Following is a soap document sent by the client to display message web
service.
<?xml version=”1.0” encoding =”UTF-8”?>
<env:Envelop
xmlns:env=”http://schemas.xmlsoap.org/soap/envelop/”
xmlns:xsd=”http://www.w3.org/2001/XMLSchema”
xmlns:xsi=”http://www.w3.org/2001/XMLSchema-instance”
xmlns:enc=”http:// schemas.xmlsoap.org/soap/encoding/”
xmlns:ns0=”http://tempuri.org/wsdl”
xmlns:ns1=”http://tempuri.org/types”
env:encodingStyle=”http:// schemas.xmlsoap.org/soap/encoding/”>
<env:Body>
<ns0:HelloMsg>  Call to procedure which is RPC
<msg_1 xsi: type=:xsd:string”>Welcome</msg_1>
</ns0:HelloMsg>
</env:Body>
</env:Envelop>

Part III : Struts

4.11 Overview SPPU : Dec.-18, Marks 4

 Struts is a framework software used for developing the Java Web Applications.
 The struts framework was initially created by Craig McClanahan and donated to
Apache Software Foundation.
 It is an open source product.
 The latest commonly used release is struts 2.
Features
1. It is based on Model view Controller (MVC) architecture.
2. The action class is POJO (Plain Old Java Object) that means it is a simple Java
class.
3. Struts2 provides the support to AJAX technology. That means only required field
can be sent to the server and no need to send entire page. Due to this feature the
execution is fast.
4. The struts2 framework can be integrated with other applications like Hibernate,
Spring and so on.
5. Struts2 provides tag support such as UI tags, Data tags, control tags etc.
6. It provides support for views and templates.
7. Struts2 support multiple views for the same application.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 54 JSP and Web Services

Advantages of Struts
1. The complex web applications can be built using simple Model, View and
Controller components.
2. The designs made using struts are simpler, consistent and easy to maintain.

Review Question

1. Write various features of struts framework.


SPPU : Dec.-18, Marks 4

4.12 Architecture SPPU : May-18,19, Marks 6

 The struts framework is based on Model, View and Controller architecture (MVC).
I. Normally when client wants any web page he demands it using get or post
request or by clicking Submit button, then a controller is invoked.
II. A Controller is nothing but a Java class in which business logic is written. The
job of Controller is to take user input and pass it to the Model. The controller in
turn invokes the Model.
III. Model stores the user's data may be in databases or so, and returns some result
to the Controller.
IV. Using this result, the Controller figures out user requirements and accordingly
forwards the result to the View page.
V. Finally required view can be obtained as a response (i.e. a display of required
web page is obtained) on the web browser. This can be diagrammatically shown
as below -

Fig. 4.12.1

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 55 JSP and Web Services

In struts,
o Model components provide a model for "business logic" and data behind struts
program.
o View components in struts are those components that present the information
to the user or accept the user input. Typically these components are JSP or
HTML pages. View components are responsible for providing the display of
required information. Struts provide large number of JSP custom tags or struts
tags to simplify the development of view components.
o Controllers are the Java classes which allow developers to remove error
handling activities from JSP pages. These classes are typically referred as action
classes.

Review Question

1. Draw and explain neat diagram which depicts MVC to the struts architecture.
SPPU : May-18,19, Marks 6

4.13 Execution of First Struts Applications


Environment : Before execution of any struts programs following software must be
installed.
1) JDK 2) Apache Tomcat 3) Eclipse IDE
4) Struts 2 library : For installing struts 2 libraries get them downloaded from
https ://struts.apache.org/download.cgi
I have downloaded struts-2.2.34-all.zip and on unzipping it will give directory
structure c:\struts-2.2.34
Step 1 : Start Eclipse. From File Menu select File -> New->Dynamic Web Project.
Type the name of the project. In my case I have created the project by the name
FirstStrutsDemo. The screen-shot will be Just click next button with default options and
check the Generate Web.xml deployment descriptor option. This will create a dynamic
web project in Eclipse.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 56 JSP and Web Services

Step 2 : Now copy the Jar files present in the c:\struts-2.2.34\lib folder to our
project's WEB-INF\lib folder. Following files need to be copied
commons-fileupload-1.3.2
commons-io-2.2
commons-lang-2.4
commons-lang3-3.2
commons-logging-1.1.3

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 57 JSP and Web Services

freemarker-2.3.22
javassist-3.11.0.GA
ognl-3.0.21
struts2-core-2.3.34
xwork-core-2.3.34
Step 3 : Now create an action class which is a Java class. It should be created under
Java-Resourcs->src folder. Under src folder create a package with suitable
name. I have created package named myPkg and Java source class as
MyBigHello.java. The code for this is as follows -

MyBigHello.java
package myPkg;
public class MyBigHello {
private String name;
public String execute() throws Exception {
return "success";
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
The action class gets executed when user clicks the URL. Based on it, the JSP page will
be displayed.
Step 4 : Now we will create a view page. I have named it as MyHello.jsp. in the
WebContent folder in your eclipse project. To do this, right click on the
WebContent folder in the project explorer and select New >JSP File.

MyHello.jsp
<%@ page contentType = "text/html; charset = UTF-8" %>
<%@ taglib prefix = "s" uri = "/struts-tags" %>
<html>
<head>
<title>My First Struts Demo Application</title>
</head>
<body>
<h3>Welcome my friend, <s:property value = "name"/></h3>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 58 JSP and Web Services

In above code, the taglib directive tells us the Servlet container that this page is using
Struts 2 tag and the tags will be preceded by s.
The name property define in MyBigHello.java class will be returned by the function
getName() of MyBigHello class.
Step 5 : Now we will create the main page. In struts 2 the main page is denoted by
index.jsp in the WebContent folder. This file serves as the initial action
URL and calls the method defined in MyBigHello class, accordingly the
display of MyHello.jsp page will be updated.

index.jsp
<%@ page language = "java" contentType = "text/html; charset = ISO-8859-1"
pageEncoding = "ISO-8859-1"%>
<%@ taglib prefix = "s" uri = "/struts-tags"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>My First Struts Demo Application</title>
</head>
<body>
<h2>My Struts2 Application</h2>
<form action = "hello">
<label for = "name">Enter your name</label><br/>
<input type = "text" name = "name"/>
<input type = "submit" value = "Submit"/>
</form>
</body>
</html>
The hello action defined in the above view file will be mapped to the MyBigHello
class and its execute method using struts.xml file. When a user clicks on the Submit
button it will cause the Struts 2 framework to run the execute method defined in the
MyBigHello class and based on the returned value of the method, an appropriate view
will be selected and rendered as a response.
Step 6 : There is a file that ties MyBigHello class(model) with MyHello(view). This
file is struts.xml. This file must be present in the classes folder. Hence
under WebContent/WEB-INF, create a folder named classes and add new
file named struts.xml. The code for this file is

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 59 JSP and Web Services

struts.xml
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<constant name = "struts.devMode" value = "true" />
<package name="default" extends="struts-default">
<action name = "hello"
class = "myPkg.MyBigHello"
method = "execute">
<result name = "success">/MyHello.jsp</result>
</action>
</package>
</struts>
Step 7 : Now create web.xml i.e. deployment descriptor file. This file acts as an
entry point for the request made by struts 2. The entry point will be filer
defined. Hence, we will define an entry of
org.apache.struts2.dispatcher.FilterDispatcher class in web.xml. The
web.xml file needs to be created under the WEB-INF folder under
WebContent. The web.xml generated by Eclipse can be modified as -
web.xml
<?xml version = "1.0" encoding = "UTF-8"?>
<web-app xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xmlns = "http://java.sun.com/xml/ns/javaee"
xmlns:web = "http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
id = "WebApp_ID" version = "3.0">
<display-name>Struts 2</display-name>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>

<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.FilterDispatcher
</filter-class>
</filter>

<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 60 JSP and Web Services

Following screen-shot of Project-Explorer represents the location of above created files.

Step 8 : Execution of application :


i) For executing the application right click on the project name and click
Export > WAR File to create a War file. Then deploy this WAR in the Tomcat's
webapps directory. For a destination click the Browse button and select the path
c:/your_tomcat_directory/webapps folder by accepting the default name of the
war file. Normally "your_project_name.war" file gets generated. Here we get
FirstStrutsDemo.war in the c:/tomcat_directory/webapps.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 61 JSP and Web Services

ii) Now run the Tomcat Web server. By selecting the Run configurations… from
the Menu bar of Eclipse. Select the Apache, under which select the Tomcat server
which is same as the Tomcat server which you have already installed on your
computer. I have selected Tomcat v7.0 as the version of my already installed
Tomcat. Then as a destination select the path of your tomcat directory. After
finishing this the Tomcat web server gets started.
The output can be displayed on the web browser as

Click Submit button and we will get

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 62 JSP and Web Services

4.14 Configuration SPPU : Dec.-18,19, Marks 6

There are two main configuration files used in struts and those are struts.xml and
web.xml.
There is struts.properties file is used to override the default values of default.xml file
provided by struts framework. So it is not mandatory.

struts.xml
The struts.xml file is used to initialize the resources such as inceptors, Actions classes.
This file is present inside the WEB-INF/classes folder.
The structure of this file is
<?xml version = "1.0" Encoding = "UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<constant name = "struts.devMode" value = "true" />
<package name = "FirstStrutDemo" extends = "struts-default">

<action name = "demo"


class = "myPkg.TestAction"
method = "execute">
<result name = "success">/MyHello.jsp</result>
</action>

<-- more actions can be listed here -->

</package>
<-- more packages can be listed here -->

</struts>

1) Package Element
The package element specifies module or your project name.
It has following attributes -
i) name : The name must define the package
ii) namespace : This is optional attribute. If namespace is not present, / is assumed
as the default namespace.
iii) extends : The package element mostly extends the struts-default package where
interceptors and result types are defined.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 63 JSP and Web Services

2) Action Element
 This element represents action. Various attributes of this element are -
i) name : This is any name with which the action is associated.
ii) class : The name of the action class is specified. This name must be accompanied
with the package name inside which the action class is defined.
iii) method : This is optional field. By default the execute method is associated with
this attribute.
iv) result name : The result name can be success, error and so on. In struts, on result
element the page to be displayed on success or error is specified.
web.xml
The web.xml is a configuration file which determines how elements of the HTTP
request are processed by the servlet container. It is not strictly a Struts2 configuration file,
but it is a file that needs to be configured for Struts2 to work.
The web.xml file needs to be created under the folder WebContent/WEB-INF.
This file contains the <welcome-file-list> tag using which the first file to be loaded on
execution of struts project is specified. For example
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
The simple meaning of above code is that as soon as you execute your struts
application, load the index.jsp file.
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
The above code indicates that <url-pattern> is /* means that all urls will be parsed by
the struts filter.

Review Question

1. What are the different configuration files are require to develop any struts application ?
Explain each configuration file.
SPPU : Dec.-18, 19, Marks 6

4.15 Actions SPPU : Dec.-18, May-19, Marks 6

 Actions are important element of struts application. The actions are basically the
Java programs that contain the processing logic and satisfy the requests made by
the user.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 64 JSP and Web Services

 Each URL is mapped to these actions.


 Action performs two tasks -
o Action plays an important role from request to view. This view is written in JSP.
o Action directs the framework to display particular view as an response to the
request.
 Action class is a POJO (Plain Old Java Object) class which has attributes and
methods. There must be one method that should always be present in action class
and that is - execute() method.
 By default execute() method is called when client request goes to action class.
 This class is bean class. That means it is a Java class containing getXX and setXX
methods.
 To understand the getXX and setXX methods - consider that there is a Java class
named Test inside which there are two attributes namely -name and roll. Then in
this case getName(), setName , getRoll() and setRoll() methods will be created and
defined. The sample code for such Test bean class would be
Public class Test
{
private String name;
private int roll;
public String getName() {
return name; Note that the attribute name must
} appear after get or set and the first
public void setName(String name) { letter of the method name must be
this.name = name; capital
public String getRoll() {
return roll;
}
public void setRoll(int roll) {
this.roll = roll;
}
We can write simple Java class as action class or extend that class for ActionSupport
class. This ActionSupport class implements an important interface named Action. The
Action interface is as follows -
public interface Action {
public static final String SUCCESS = "success";
public static final String NONE = "none";
public static final String ERROR = "error";
public static final String INPUT = "input";
public static final String LOGIN = "login";

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 65 JSP and Web Services

public String execute() throws Exception;


}

How to implement Action class Using struts ?


Step 1 : Start Eclipse. From File Menu select File -> New->Dynamic Web Project.
Type the name of the project.
Just click next button with default options and check the Generate Web.xml
deployment descriptor option. This will create a dynamic web project in
Eclipse
Step 2 : Now copy the required Jar files present in the c:\struts-2.2.34\lib folder to
our project's WEB-INF\lib folder.
Before actually building the struts application just refer following figure. Because in
this application, we are going to create multiple files. The relationship and purpose of
these files is depicted by following figure
-

Step 3 : Now create an action class which is a Java class. It should be created under
Java-Resourcs->src folder. Under src folder create a package with suitable
name. I have created package named myPkg and Java source class as
MyBigHello.java. The code for this is as follows -

MyBigHello.java
package myPkg;
public class MyBigHello {
private String name;
public String execute() throws Exception {
return "success";
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 66 JSP and Web Services

public String getName() {


return name;
}
public void setName(String name) {
this.name = name;
}
}
The action class gets executed when user clicks the URL. Based on it, the JSP page will
be displayed.
Step 4 : Now we will create the main page. In struts 2 the main page is denoted by
index.jsp in the WebContent folder. This file serves as the initial action URL
and calls the method defined in MyBigHello class(We have defined this
class in pervious step)

index.jsp
<%@ page language = "java" contentType = "text/html; charset = ISO-8859-1"
pageEncoding = "ISO-8859-1"%>
<%@ taglib prefix = "s" uri = "/struts-tags"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>My First Struts Demo Application</title>
</head>
<body>
<h2>My Struts2 Application</h2>
<form action = "hello">
<label for = "name">Enter your name</label><br/>
<input type = "text" name = "name"/>
<input type = "submit" value = "Submit"/>
</form>
</body>
</html>
The hello action defined in the above view file will be mapped to the MyBigHello
class and it executes method using struts.xml file. When a user clicks on the Submit
button it will cause the Struts 2 framework to run the execute method defined in the
MyBigHello class and based on the returned value of the method, an appropriate view
will be selected and rendered as a response.
Step 5 : Create a file named struts.xml. This file must be present in the classes
folder. Hence under WebContent/WEB-INF, create a folder named classes
and add new file named struts.xml. The code for this file is

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 67 JSP and Web Services

struts.xml
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<constant name = "struts.devMode" value = "false" />
<package name="default" extends="struts-default">
<action name = "hello"
class = "myPkg.MyBigHello"
method = "execute">
<result name = "success">/MyHello.jsp</result>
<result name = "error">/AccessDenied.jsp</result>
</action>
</package>
</struts>
The struts.xml is a file that ties MyBigHello class(model) with MyHello(view). This
MyHello.jsp file is basically a view file. It is created in next step.
Step 6 : We will create a view page. I have named it as MyHello.jsp. in the
WebContent folder in your eclipse project. To do this, right click on the
WebContent folder in the project explorer and select New >JSP File.

MyHello.jsp
<%@ page contentType = "text/html; charset = UTF-8" %>
<%@ taglib prefix = "s" uri = "/struts-tags" %>
<html>
<head>
<title>My First Struts Demo Application</title>
</head>
<body>
<h3>Welcome my friend, <s:property value = "name"/></h3>
</body>
</html>
The name property define in MyBigHello.java class will be returned by the function
getName() of MyBigHello class.
Step 7 : If we do not enter the name as "Admin" then the error page will be displayed as

AccessDenied.jsp
<%@ page contentType = "text/html; charset = UTF-8" %>
<%@ taglib prefix = "s" uri = "/struts-tags" %>
<html>
<head>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 68 JSP and Web Services

<title>Access Denied</title>
</head>
<body>
Error!!!You are not allowed to view this page
</body>
</html>
Step 8 : Now create web.xml i.e. deployment descriptor file. This file acts as an entry
point for the request made by struts 2. The entry point will be filer defined.
Hence, we will define an entry of
org.apache.struts2.dispatcher.FilterDispatcher class in web.xml. The
web.xml file needs to be created under the WEB-INF folder under
WebContent. The web.xml generated by Eclipse can be modified as -

web.xml
<?xml version = "1.0" encoding = "UTF-8"?>
<web-app xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xmlns = "http://java.sun.com/xml/ns/javaee"
xmlns:web = "http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
id = "WebApp_ID" version = "3.0">
<display-name>Struts 2</display-name>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>

<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.FilterDispatcher
</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
For understanding the location of above files I am giving the following screen-shot.
Note that these files must be created in respective folders only -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 69 JSP and Web Services

Step 9 : Now execute the application.


The output will be

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 70 JSP and Web Services

If we enter other than Admin, here I have given the name as 'Parth' and then -

Review Question

1. Identify and explain data tags from struts2 which are used to manipulate data displayed on any
web application page.
SPPU : Dec.-18, May-19, Marks 6

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 71 JSP and Web Services

4.16 Interceptors SPPU : May-18, Marks 6

 Interceptor is an object which intercepts an action dynamically. It executed before


and after the action execution.
 In Struts 2, interceptor is used to perform operations such as validation, exception
handling, internationalization, displaying intermediate result etc.
 Following is a list of Inceptors that are preconfigured and can be ready to use.
1) alias : It converts similar parameters that have different names between requests.
2) chain : If it is used with chain result type, it makes the properties of previous
action available in the current action.
3) checkbox : It is used to handle the check boxes in the form. By this, we can detect
the unchecked checkboxes.
4) cookie : It adds a cookie to the current action.
5) conversionError : It adds conversion errors to the action's field errors.
6) createSession : It creates and HttpSession object if it doesn't exists.
7) clearSession : It unbinds the HttpSession object.
8) debugging : It provides support of debugging.
9) execAndWait : It sends an intermediate waiting page for the result.
10) exception : It maps exception to a result.
11) fileUpload : It provides support to file upload in struts 2.
12) i18n : It provides support to internationalization and localization.
13) store : It stores and retrieves action messages, action errors or field errors for
action that implements ValidationAware interface.
14) params : It populates the action properties with the request parameters.
15) scope : It is used to store the action state in the session or application scope.
16) timer : It outputs the time needed to execute an action.
17) validation : It provides support to input validation.
 We can create our own Inceptor object. This custom based inceptor can be plugged
in struts.
 Framework creates an object of ActionInvocation that encapsulates the action and
all the interceptors configured for that action.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 72 JSP and Web Services

 Each interceptors are called before the action gets called.


 Once the action is called and result is generated, each interceptors are again called
in reverse order to perform post processing work.
 Interceptors can alter the workflow of action. It may prevent the execution of action.

Advantages of Interceptors

1. If we want pre-processing services and post-processing services for an Action


then these services can be provided by interceptor.
2. It provides pluggable functionalities for validation, exception handling and
logging. We do not need to redeploy the application.
3. Interceptors can be coupled with request and response cycle.

How to Create Custom Intercept ?

 For creating the custom intercept we need


interface Interceptor This interface contains
a method intercept() which ultimately calls
the invoke() method.
 The interceptor can be executed before
calling the action, during execution of action and after execution of action.
 Let us create an interceptor in struts framework.
Step 1 : Start Eclipse. From File Menu select File -> New->Dynamic Web Project.
Type the name of the project.
Just click next button with default options and check the Generate Web.xml
deployment descriptor option. This will create a dynamic web project in
Eclipse
Step 2 : Now copy the required Jar files present in the c:\struts-2.2.34\lib folder to

our project's WEB-INF\lib folder

Step 3 : Inside the Java Resources-> src folder create a package(I have created

myPkg package). Inside that package create a Java class for inceptor named
MyInterceptor as follows -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 73 JSP and Web Services

MyInterceptor.java
package myPkg;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
public class MyInterceptor extends AbstractInterceptor{
public String intercept(ActionInvocation invocation)throws Exception {
System.out.println("Before Execution");
String result = invocation.invoke(); Remember these interceptors will
System.out.println("After Execution");
shows the result in the console
return result;
} automatically
}
Step 4 : Now create the Java class as action class in which execute() method is
defined. Again this class is created inside the user defined package of src
folder. The code for this is as follows -

Test.java
package myPkg;
import com.opensymphony.xwork2.ActionSupport;
public class Test extends ActionSupport{
private String name;
public String execute() throws Exception {
System.out.println("Inside execute() method!!!");
return "success";
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}

}
Step 5 : Now we will create a view page. I have named it as MyHello.jsp in the
WebContent folder in your eclipse project. To do this, right click on the
WebContent folder in the project explorer and select New >JSP File.

MyHello.jsp
<%@ page contentType = "text/html; charset = UTF-8" %>
<%@ taglib prefix = "s" uri = "/struts-tags" %>
<html>
<head>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 74 JSP and Web Services

<title>My Interceptor Demo Application</title>


</head>
<body>
<h3>Welcome my friend, <s:property value = "name"/></h3>
</body>
</html>
Step 6 : Now create the main page as index.jsp in the WebContent folder.

index.jsp
<%@ page language = "java" contentType = "text/html; charset = ISO-8859-1"
pageEncoding = "ISO-8859-1"%>
<%@ taglib prefix = "s" uri = "/struts-tags"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>Struts Inceptor Demo Application</title>
</head>
<body>
<h2>My Struts2 Application</h2>
<form action = "hello">
<label for = "name">Enter your name</label><br/>
<input type = "text" name = "name"/>
<input type = "submit" value = "Submit"/>
</form>
</body>
</html>
Step 7 : Create the configuration file struts.xml as follows-

struts.xml
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<constant name = "struts.devMode" value = "true" />
<package name="default" extends="struts-default">
<interceptors>
<interceptor name = "myinterceptor"

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 75 JSP and Web Services

class = "myPkg.MyInterceptor" />


</interceptors>
<action name = "hello"
class = "myPkg.Test"
method = "execute">
<interceptor-ref name = "params"/>
<interceptor-ref name = "myinterceptor" />
<result name = "success">/MyHello.jsp</result>
</action>
</package>
</struts>

Step 8 : The configuration file web.xml will invoke the index.jsp file. It is present
inside WEB-INF folder. Just modify the web.xml file as follows -

web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
<display-name>InceptorDemo</display-name>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.FilterDispatcher
</filter-class>
</filter>

<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>

While creating this application in struts 2, please refer the following screen-shot of
Project Explorer to know the location of the above created files.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 76 JSP and Web Services

Step 9 : Export the WAR file and start Tomcat server. Run the program on Tomcat
server. The output will be obtained as follows -
Enter some name inside the text box and click the Submit button. You will
get the execution of interceptor as follows :

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 77 JSP and Web Services

Review Question

1. How to use interceptors in Struts 2 ? List and describe important interceptors provided by
Struts 2 framework.
SPPU : May-18, Marks 6

4.17 Result Types


 The result type is used to change the behaviour of view page to render the contents
of action class.
 After executing the Action class, the target view page will be executed based on
configuration in struts.xml.
 The Struts2 framework provides set of Result types like; chaining, dispatcher,
redirect action, velocity and freemarket etc., that has to be configure in struts.xml
for different kind of result.
 The <result> tag is used in struts.xml to render the view page. This result tag is
provided with predefined result types such as dispatcher, redirect and so on. For
example
<result name = "success" type="redirect">

 The dispatcher result type is the default type, and is used if no other result type is
specified. It's used to forward to a servlet, JSP, HTML page, and so on, on the
server. It can be written as
<result name="success" type="dispatcher">
<param name="location">/Success.jsp</param>
</result>
Let us understand how to use result type with demonstration.

How to use result type ?


In this application we will use result type for redirecting the view page to a new JSP
page. Just follow the simple steps given below -
Step 1 : Create the files MyBigHello.java, index.jsp, MyHello.jsp and web.xml as it is
discussed in section 4.16.
Step 2 : The struts.xml file is little bit changed. It contains the <result … type>
parameter. Following file tells us that on success redirect to a new page. This
new page is NewLocation.jsp

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 78 JSP and Web Services

struts.xml
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>
<constant name = "struts.devMode" value = "false" />

<package name="default" extends="struts-default">


<action name = "hello"
class = "myPkg.MyBigHello"
method = "execute">
<result name = "success" type="redirect">
<param name="location">
/NewLocation.jsp
</param>
</result>
</action>
<action name = "index">
<result >/index.jsp</result>
</action>
</package>
</struts>
Step 3 : The NewLocation.jsp file will be

NewLocation.jsp
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>My Result Type Struts Demo Application</title>
</head>
<body>
<h3>Ooops!! you are redirected to new page...</h3>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 79 JSP and Web Services

Step 4 : Now execute the above application and the output can be obtained as follows -

Click the submit button, and you will be redirected to a new page

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 80 JSP and Web Services

4.18 Validations
 In struts, validation framework help to perform validation before the action method
is executed.
 You can validate data in action class also through validate() method.
 In the validate() method we can validate the user name, password,age,email, phone
number and so on. If the validation fails an error is added using the addFieldError()
method.

How to use Validations in Struts ?


In this application we will use validation for the name field. The text-box for entering
the name is given, if user leave this text box empty then the message entering the valid
name is given. This is how the simple validation can be performed in following
application.
Step 1 : Start Eclipse. Create a Dynamic Web Project. Copy the required Jar files to
WEB-INF/lib folder. Now create a Login Page using JSP. This file is created
in WebContent . In this page one textfields is created to enter valid user
name. The code for this JSP script is as follows-

LoginPg.jsp
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<%@taglib uri="/struts-tags" prefix="s" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Login Page Demo</title>
<s:head />
</head>
<body>
<s:form action="Login">
<s:textfield name="userName" label="User Name" />
<s:submit value="Submit" />
</s:form>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 81 JSP and Web Services

Step 2 : Create one more JSP document under WebContent folder named
Welcome.jsp . This JSP file is for displaying welcome message for authentic
user. The code is

Welcome.jsp
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<%@taglib uri="/struts-tags" prefix="s"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>login Page Demo</title>
</head>
<body>
<h1>Welcome, User <s:property value="userName"/> is authentic user!!!</h1>
</body>
</html>
Step 3 : Now we will write the Java File for validating the user name. Two
validations are used -
i) the user name must not be blank and ii) the user name must be root. For
validation purpose we will write one function named validate() in this Java
program. This method is written in action class, hence this program will be
created within package name myPkg under the src directory.

LoginProg.java
package myPkg;
import com.opensymphony.xwork2.ActionSupport;
public class LoginProg extends ActionSupport {
private String userName;

public String execute() {


return SUCCESS;
}
public String getUserName() {
return userName;
}

public void setUserName(String userName) {

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 82 JSP and Web Services

this.userName = userName;
}
public void validate() {
if (getUserName().length() == 0) {
addFieldError("userName", "UserName.required");
} else if (!getUserName().equals("root")) {
addFieldError("userName", "Invalid User");
}
}
}
Step 4 : Now we will write the configuration files. The struts.xml file under the
WEB-INF/classes folder will be -

struts.xml
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<constant name="struts.custom.i18n.resources" value="LoginProg" />
<package name="default" extends="struts-default" namespace="/">
<action name = "Login"
class = "myPkg.LoginProg"
method = "execute">
<result name = "success">/Welcome.jsp</result>
<result name = "input">/LoginPg.jsp</result>
</action>
</package>
</struts>
Step 5 : The web.xmlfile present inside the WEB-INF folder is modified as -

web.xml
<?xml version = "1.0" encoding = "UTF-8"?>
<web-app xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xmlns = "http://java.sun.com/xml/ns/javaee"
xmlns:web = "http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
id = "WebApp_ID" version = "3.0">
<display-name>Struts 2</display-name>
<welcome-file-list>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 83 JSP and Web Services

<welcome-file>LoginPg.jsp</welcome-file>
</welcome-file-list>
<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
The above file specifies the entry point for the project. It says that the first page to be
displayed is LoginPg.jsp.
Step 6 : Now deploy the WAR file to tomcat's webapps directory and run the above
application on Apache Tomcat server. The output will be

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 84 JSP and Web Services

If we enter the user name as 'root' then we get Welcome message.

4.19 Localization
 Internationalization is a process of translation or localization.
 Internationalization is abbreviated i18n because the word starts with the letter "i"
and ends with "n", and there are 18 characters between the first i and the last n.
 Internationalization (i18n) is the process of planning and implementing products
and services so that they can easily be adapted to specific local languages and
cultures, a process called localization.
 The i18n interceptor provides multi-lingual support for your application.
 It handles setting locale for the action. It can be used if user wants to set his/her
locale and get data according to the locale provided.
 A locale is an identifier and represents the local details of the user to the application.
The locale can be created by java.util.Locale class. When a user session begins, the
Locale object is sent in the HTTP request as parameter.

Concept of Resource Bundle


Struts2 makes use of resource bundle to provide multiple languages and locale options
to the users. The resource bundle is a resource file in which key-value pairs are stored.
The name to these resource files is given in following naming format
Bundlename_language_country.properties

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 85 JSP and Web Services

The language_country represents the country locale. For example English United
States is represented as en_US, For Spanish it will be _es and so on. These properties file
can be named as
global.properties : This is a default file for the English language.
global_fr.properites : This file specifies the French locale.
global_cn.properties : It specifies the code in Chinese.
global_hi.properties : It specifies the code in Hindi

How to create application to support Localization ?


Step 1 : Create a Dynamic project. Copy all the necessary .jar files to WEB-INF/lib folder.
Create initial JSP page inside the WebContent folder, name it as index.jsp. The code
for it will be as follows -

index.jsp
<%@ page language = "java" contentType = "text/html; charset = ISO-8859-1"
pageEncoding = "ISO-8859-1"%>
<%@ taglib prefix = "s" uri = "/struts-tags"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>Student Form with Multilingual Support</title>
</head>
<body>
<h1><s:text name = "global.heading"/></h1>

<s:url id = "indexEN" namespace="/" action = "locale" >


<s:param name = "request_locale" >en</s:param>
</s:url>

<s:url id = "indexDE" namespace="/" action = "locale" >


<s:param name = "request_locale" >de</s:param>
</s:url>
<s:url id = "indexHI" namespace="/" action = "locale" >
<s:param name = "request_locale" >hi</s:param>
</s:url>

<s:a href="%{indexEN}" >English</s:a>


<s:a href="%{indexDE}" >German</s:a>
<s:a href="%{indexHI}" >Hindi</s:a>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 86 JSP and Web Services

<s:form action = "studentinfo" method = "post" namespace = "/">


<s:textfield name = "name" key = "global.name" size = "20" />
<s:submit name = "submit" key = "global.submit" />
</s:form>
</body>
</html>
Step 2 : Now create another JSP page to handle the successful submission of data.
This page will display the message that you are authenticated user. The JSP
file is created inside the WebContent folder.
The code is very simple and it is

Welcome.jsp
<%@ page language = "java" contentType = "text/html; charset = ISO-8859-1"
pageEncoding = "ISO-8859-1"%>
<%@ taglib prefix = "s" uri = "/struts-tags"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>Success</title>
</head>
<body>
<s:property value = "getText('global.success')" />
</body>
</html>
In above code have used getText method to access the messages. To display i18n text,
use a call to getText in the property tag.
Step 3 : Now create the Java Class files inside the src folder. First create the package
with some suitable name under Java Resources/src. Here we will create two
Java Class files - first Java class file will take care of Locale and display the
index.jsp with different languages and second Java class file will handle the
form submission in which execute, getXX and setXX methods are defined.
The code for these Java files is as follows

StudLocale.java
package myPkg;
import com.opensymphony.xwork2.ActionSupport;
public class StudLocale extends ActionSupport {
public String execute() {
return SUCCESS;
}
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 87 JSP and Web Services

TestAction.java
package myPkg;
import com.opensymphony.xwork2.ActionSupport;
public class TestAction extends ActionSupport {
private String name;
public String execute() {
return SUCCESS;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
Step 4 : Now we can create global.properties files. These files can be created for
different languages so that the web page can be displayed in those
corresponding languages. Here I will write the global file for displaying the
message English only. This file is created inside WEB-INF folder inside
which the classes folder is created. Save global.properties file inside this
classes folder.
global.properties
global.name = Name
global.submit = Submit
global.heading = Select desired Locale
global.success = You are authenticated user!!!
In this file,we will display the name of the fields and their corresponding values. For
instance for global.success the message "You are authenticated user!!!" message must be
displayed. For global.heading the "Select desired Locale" must be displayed.
Step 5 : Now create the configuration files. First create the struts.xml file inside
WEB-INF\classes folder. The code for this file would be as follows -

struts.xml
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<constant name = "struts.devMode" value = "false" />
<constant name = "struts.custom.i18n.resources" value = "global" />
<package name = "localizationdemo" extends = "struts-default" namespace="/">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 88 JSP and Web Services

<action name = "studentinfo"


class = "myPkg.TestAction"
method = "execute">
<result name = "input">/index.jsp</result>
<result name = "success">/Welcome.jsp</result>
</action>
<action name = "locale"
class = "myPkg.StudLocale"
method = "execute">
<result name = "success">/index.jsp</result>
</action>
</package>
</struts>
Step 6 : Modify the web.xml file present in WEB-INF folder. The code is as follows -

web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
<display-name>LocalizationDemo</display-name>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.FilterDispatcher
</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
Here is the screen-shot for Project Explorer to understand the parent folders of above
created files -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 89 JSP and Web Services

Step 7 : Then right click on the project name and click Export-> WAR file for
exporting the war file in Tomcat directory. Then execute the above
application on Tomcat web server. The output will be

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 90 JSP and Web Services

Click Submit button and you will get

4.20 Exception Handling


When a program crashes due to some run time error, then this is an undesirable
situation. This situation is called exception. Struts provide an efficient way to handle
uncaught exception. When such situation occurs, struts redirect to error message display
page elegantly.
Following demonstrative application illustrates the exception handling mechanism. In
this program we have created error causing statement purposely so that this exception
can cause crash of the program. Then this situation is handled using exception handling
mechanism.
Step 1 : Create a Dynamic Web project. Copy all the necessary .jar files to
WEB-INF/lib folder.
Create initial JSP page inside the WebContent folder, name it as index.jsp. The
code for it will be as follows -

index.jsp
<%@ page language = "java" contentType = "text/html; charset = ISO-8859-1"
pageEncoding = "ISO-8859-1"%>
<%@ taglib prefix = "s" uri = "/struts-tags"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 91 JSP and Web Services

<html>
<head>
<title>My First Struts Demo Application</title>
</head>
<body>
<h2>My Struts2 Application</h2>
<form action = "hello">
<label for = "name">Enter your name</label><br/>
<input type = "text" name = "name"/>
<input type = "submit" value = "Submit"/>
</form>
</body>
</html>
Step 2 : Now create another JSP page to handle the successful submission of data.
This page will display the welcome message by user name. The JSP file is
created inside the WebContent folder. The code is very simple and it is -

MyHello.jsp
<%@ page contentType = "text/html; charset = UTF-8" %>
<%@ taglib prefix = "s" uri = "/struts-tags" %>

<html>
<head>
<title>Exception Demo Application</title>
</head>

<body>
<h3>Welcome my friend, <s:property value = "name"/></h3>
</body>
</html>
Step 3 : Now create the Java Class files inside the src folder. First create the package
with some suitable name under Java Resources/src. This Java class file will
handle the form submission in which execute, getXX and setXX methods are
defined. Note that purpose, inside the execute method I have created a null
string in variable str. Then trying to find the Uppercase string of this null
string. This action will cause the NullPointerAssignment problem. The code
for this Java file is as follows -

MyBigHello.java
package myPkg;
import com.opensymphony.xwork2.ActionSupport;
public class MyBigHello extends ActionSupport{

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 92 JSP and Web Services

private String name;

public String execute() {


String str=null;
str=str.toUpperCase(); These statements are causing Null Pointer
return SUCCESS; A i
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
Step 4 : Now create the configuration files. First create the struts.xml file inside
WEB-INF\classes folder. The code for this file would be as follows -

struts.xml
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<constant name = "struts.devMode" value = "false" />
<package name="default" extends="struts-default">
<action name = "hello"
class = "myPkg.MyBigHello"
method = "execute">
<result name = "success">/MyHello.jsp</result>
</action>
</package>
</struts>
Step 5 : Another configuration file web.xml is modified which is present inside the
WEB-INF folder.

web.xml
<?xml version = "1.0" encoding = "UTF-8"?>
<web-app xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xmlns = "http://java.sun.com/xml/ns/javaee"
xmlns:web = "http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
id = "WebApp_ID" version = "3.0">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 93 JSP and Web Services

<display-name>Struts 2</display-name>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.FilterDispatcher
</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
Step 6 : Then right click on the project name and click Export-> WAR file for
exporting the war file in Tomcat directory. Then execute the above
application on Tomcat web server. The output will be

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 94 JSP and Web Services

Click Submit button and following exception will be raised -

Step 7 : To overcome this problem we will create a dedicated JSP page to handle
exception. I have created a JSP page named ErrorHandle.jsp page as
follows -
ErrorHandle.jsp
<%@ page language = "java" contentType = "text/html; charset = ISO-8859-1"
pageEncoding = "ISO-8859-1"%>
<%@ taglib prefix = "s" uri = "/struts-tags"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title></title>
</head>
<body>
<h3>Some Error has occurred in your page!!!</h3>
</body>
</html>
Step 8 : Now in order to display the above created JSP page on exception we need to
modify our struts.xml file. The code will be

struts.xml
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 95 JSP and Web Services

<constant name = "struts.devMode" value = "false" />


<package name="default" extends="struts-default">
<action name = "hello"
class = "myPkg.MyBigHello"
method = "execute">
<exception-mapping exception = "java.lang.NullPointerException"
result = "error" />
<result name = "success">/MyHello.jsp</result>
<result name = "error">/ErrorHandle.jsp</result>
</action>
</package>
</struts>
In above code, in order to handle the exception the <exception-mapping> tag is used.
This tag is assigned with the value by the Java exception name NullPointerException.
Since exceptions in Java are defined in package java.lang we denote it as
"java.lang.NullPointerException"
Step 9 : Now run the above code by exporting WAR file and then on Tomcat server,
and following output can be obtained when we enter some user name and
click the Submit button.

4.21 Annotations
 Java annotation is a tag used to represent the metadata. The metadata is a data
about classes, methods or fields.
 Annotations in Java are used to provide some addition information. For instance - If
user is entering his age in the text field, then that age must not be negative or it
should not be blank - Such type of information can be provided to the user using
annotations.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 96 JSP and Web Services

 A Java annotation in its shortest form looks like this :


@Entity
 The @ character signals to the compiler that this is an annotation. The name
following the @ character is the name of the annotation.
 Struts provides two forms of configuration.
o The traditional way is to use the struts.xml file for all the configurations.
o The other way of configuring Struts is by using the Java 5 Annotations feature.
 Using annotation we do not need struts.xml for configuration. Thus we can achieve
zero configuration using annotation.
 Commonly, we can use 3 annotations :
1) @Action annotation is used to mark the action class.
2) @Results annotation is used to define multiple results for one action.
3) @Result annotation is used to display single result.
 To support the annotations we require following files in the Java program to be
imported as -
import org.apache.struts2.convention.annotation.Action;
import org.apache.struts2.convention.annotation.Result;
import org.apache.struts2.convention.annotation.Results;
import com.opensymphony.xwork2.validator.annotations.*;

How to use Annotations in Struts Application ?


Step 1 : Create a project as Dynamic Web Project. Copy following Jar files in the
WEB-INF\lib folder.
struts2-convention-plugin-x.y.z.jar
asm-x.y.jar
antlr-x.y.z.jar
commons-fileupload-x.y.z.jar
commons-io-x.y.z.jar
commons-lang-x.y.jar
commons-logging-x.y.z.jar
commons-logging-api-x.y.jar
freemarker-x.y.z.jar
javassist-.xy.z.GA
ognl-x.y.z.jar
struts2-core-x.y.z.jar
xwork-core.x.y.z.jar

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 97 JSP and Web Services

Step 2 : Create the same project as discussed in section 4.18 for validation. The
LoginPg.jsp, Welcome.jsp will be as it is. The only change will be in the Java
file. In the Java file we introduce annotations. The code will be as follows -
LoginProg.java
package myPkg;
import com.opensymphony.xwork2.ActionSupport;
import org.apache.struts2.convention.annotation.Action;
import org.apache.struts2.convention.annotation.Result;
import org.apache.struts2.convention.annotation.Results;
import com.opensymphony.xwork2.validator.annotations.*;
@Results({
@Result(name = "success", location = "/Welcome.jsp"),
@Result(name = "input", location = "/LoginPg.jsp")
})
public class LoginProg extends ActionSupport {
private String userName;
@Action(value = "/Login")
public String execute() {
return SUCCESS;
}
@RequiredFieldValidator( message = "The user Name is required" )
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
}

Step 3 : Now we just do not require struts.xml file. The web.xml is the only configuration
file required. It will be as follow -
web.xml
<?xml version = "1.0" encoding = "UTF-8"?>
<web-app xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xmlns = "http://java.sun.com/xml/ns/javaee"
xmlns:web = "http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
id = "WebApp_ID" version = "3.0">

<display-name>Struts 2</display-name>

<welcome-file-list>
<welcome-file>LoginPg.jsp</welcome-file>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 98 JSP and Web Services

</welcome-file-list>
<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
</filter-class>
<init-param>
<param-name>struts.devMode</param-name>
<param-value>true</param-value>
</init-param>
</filter>

<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
Step 4 : Now Export-War file and execute the above application. If the name field is
kept empty and Submit button is clicked then "The user Name is required"
message will be displayed.

4.22 Multiple Choice Questions


Q.1 JSP is transformed into ________.
a HTML b PHP
c Byte Code d Java Servlet
Q.2 Which programming language does JSP support ?
a JavaScript only b VB Script only
c Java Only d All of the above
Q.3 Which of the scripting of JSP not putting content into service method of the converted
servlet ?
a Declarations b Scriptlets
c Expressions d None of these
Q.4 The difference between Servlets and JSP is the ________.
a translation b compilation
c syntax d both a and b
Q.5 Which is not a directive ?
a Include b Page
c Export d UseBean

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 99 JSP and Web Services

Q.6 Which of the following are the valid scopes in JSP ?


a request, page, session, application
b request, page, session, global c response, page, session, application
d request, page, context, application
Q.7 “request” is an instance of which one of the following classes :
a Request b HttpRequest
c HttpServletRequest d ServletRequest
Q.8 Which http method send by browser that asks the server to get data ______.
a get b post
c option d put
Q.9 Which attribute specifies a JSP page that should process any exceptions thrown but not
caught in the current page ?
a ErrorPage attribute b IsErrorPage attribute
c thisErrorPage attribute d none of these
Q.10 Which technology do we use to mix business logic with presentation logic ?
a JSP b servlet
c both a and b d none of these
Q.11 Which tag is used to execute java source code in JSP ?
a declaration tag b scriptlet tag
c expression tag d both b and c
Q.12 In JSP page directive which attribute defines the MIME(Multipurpose Internet Mail
Extension) type of HTTP response ?
a import b info
c extends d ContentType
Q.13 Choose the correct alternative
a Servlets are built on JSP semantics and all servlets are compiled to JSP pages
for runtime usage.
b JSP and servlets are unrelated technologies.
c Servlets and JSP are competing technologies for handling web requests.
Servlets are being superseded by JSP, which is preferred.
The two technologies are not useful in combination.
d JSPs are built on servlet semantics and all JSPs are compiled to servlets for
runtime usage.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 4 - 100 JSP and Web Services

Q.14 What is the initial contact point for handling a web request in a Page-Centric
architecture ?
a A JSP page b A JavaBean.
c A servlet d A session manager.
Q.15 What is the key difference between using a <jsp:forward> and
HttpServletResponse.sendRedirect() ?
a Forward executes on the server while sendRedirect() executes on the client.
b Forward executes on the client while sendRedirect() executes on the server.
c The two methods perform identically.
d None of these
Q.16 In Struts2 Action classes are the components of ______.
a view b controller
c model d deployment
Q.17 In Struts2, What does validate() method of ActionForm returns ?
a ActionErrors b ActionForward
c ActionMapping d ActionError
Q.18 Which of the following methods is overridden by Action class ?
a run() b destroy()
c execute() d service()

Answers Keys for Multiple Choice Questions :

Q.1 d Q.2 c Q.3 c Q.4 c Q.5 c

Q.6 a Q.7 c Q.8 a Q.9 a Q.10 b

Q.11 b Q.12 d Q.13 d Q.14 a Q.15 a

Q.16 b Q.17 b Q.18 c



TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


UNIT- V

5 Server Side Scripting


Languages
Syllabus
PHP: Introduction to PHP, uses of PHP, general syntactic characteristics, Primitives, operations
and expressions, output, control statements, arrays, functions, pattern matching, form handling, files,
cookies, session tracking, using MySQL with PHP, WAP and WML. Introduction to ASP.NET :
Overview of the .NET Framework, Overview of C#, Introduction to ASP.NET, ASP.NET Controls,
Web Services. Overview of Node JS.

Contents
5.1 Introduction to PHP
5.2 General Syntactic Characteristics
5.3 Primitives ............................................... May-18,19, ............................ Marks 4

5.4 Type Conversion

5.5 Operations and Expressions


5.6 Output

5.7 Statements Control


5.8 Arrays ............................................... May-18,19, Dec.-18, ............. Marks 6

5.9 Functions

5.10 Built in Functions

5.11 Form Handling

5.12 Pattern Matching

5.13 Files ............................................... Dec.-18,................................. Marks 6

5.14 Cookies
5.15 Session Tracking ............................................... Dec.-19,................................. Marks 8

5.16 Using MySQL with PHP............................................... May-18, Dec.-19, .................. Marks 8

(5 - 1)
Web Technology 5-2 Server Side Scripting Languages

5.17 WAP

5.18 WML

5.19 Introduction to ASP.NET

5.20 Overview of the .NET Framework


5.21 Overview of C#

5.22 Introduction to ASP.NET


5.23 ASP.NET Web Form Model

5.24 ASP.NET Controls

5.25 Web Services


5.26 Overview of Node JS ............................................... May-18, ................................. Marks 4

5.27 Multiple Choice Questions

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5-3 Server Side Scripting Languages

Part - I : PHP

5.1 Introduction to PHP

5.1.1 Origins and Uses of PHP


 PHP was developed in 1994 by Apache group.
 PHP stands for PHP : Hypertext Preprocessor.
 PHP is a server-side scripting language. It is mainly used for form handling and
database access.
 It is free to download and use.

5.1.2 Overview
 PHP is a server side scripting language embedded in XHTML. It is an alternative to
CGI, ASP, ASP.NET and JSP.
 The extensions to the PHP files are .php, .php3 or .phtml.
 The php processor works in two modes. If the PHP processor finds XHTML tags in
the PHP script then the code is simply copied to the output file. But when the PHP
processor finds the PHP code in the script then that code is simply interpreted and
the output is copied to the output file.
 If you click for view source on the web browser you can never see the PHP script
because the output of PHP script is send directly to the browser but you can see the
XHTML tags.
 PHP makes use of dynamic typing that means there is no need to declare variables
in PHP. The type of variable gets set only when it is assigned with some value.
 PHP has large number of library functions which makes it flexible to develop the
code in PHP.

5.1.3 Installation of PHP


 There are various methods of getting PHP installed on your machine.
 The PHP requires the Apache Web server to execute its code. The Apache web
server is open source software and can be easily downloaded from the Internet. The
site for getting the Apache web server is http://httpd.apache.org/download.cgi.
 Then PHP can be installed on your machine from the web site http://www.php.net.
 Another approach which is the most efficient way to install Apache, PHP, MYSQL
on your machine is to use the packages like XAMPP (The X stands for any OS) or

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5-4 Server Side Scripting Languages

WAMPP (the W stands for Windows OS). These packages support the Apache,
PHP, MYSQL, PERL.
 I have installed the XAMPP package. The root directory can be accessed using the
http://localhost/\

5.2 General Syntactic Characteristics


 PHP code can be embedded in the XHTML document. The code must be enclosed
within <?php and >
 If the PHP script is stored in some another file and if it needs to be referred then
include construct is used. For instance :
Include(“myfile.inc”)
 The variable names in PHP begin with the $ sign.
 Following are some reserved keywords that are used in PHP.

and default false if or this

break do For include require true

case else foreach list return var

class elseif function new static virtual

continue extends gloabal not switch while

xor

 The comments in PHP can be #,//, /* …*/


 The PHP statements are terminated by semicolon.
Open some suitable text editor like Notepad and type the following code. Save your
code by the extension .php.
It is expected that the PHP code must be stored in htdocs folder of Apache.
As I have installed xampp, I have got the directory c:\xampp\htdocs. I have created a
folder named php-examples inside the htdocs and stored all my PHP documents in
that folder.
Hence when I want to get the output of the PHP code I always give the URL
http://localhost/php-examples/programmName.php
The http://localhost refers to the path c:\xampp\htdocs

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5-5 Server Side Scripting Languages

Following is the first example of PHP script

PHP Document[FirstCode.php]
<html>
<head>
<title> PHP Demo </title>
</head>
<body>
<?php
$i=10;
echo "<h3>Welcome to first PHP Document</h3>";
echo "The value of variable is = $i";
?>
</body>
</html>

Output

5.2.1 Variables
 Variables are the entities that are used for storing the values.
 PHP is a dynamically typed language. That is PHP has no type declaration.
 The value can be assigned to the variable in following manner -
$variable_name=value
 If the value is not assigned to the variable then by default the value is NULL. The
unsigned variables are called unbound variable.
 If the unbound variable is used in the expression then its NULL value is converted
to the value 0.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5-6 Server Side Scripting Languages

 Following are some rules that must be followed while using the variables -
1. The variable must start with letter or underscore _ , but it should not begin with
a number.
2. It consists of alphanumeric characters or underscore.
3. There should not be space in the name of the variable.
4. While assigning the values to the variable the variable must start with the $. For
example
$marks=100;
 Using the function IsSet the value of the variable can be tested. That means if
IsSet($marks) function returns TRUE then that means some value is assigned to the
variable marks.
 If the unbound variable gets referenced then the error reporting can be done with
the help of a function error_reporting(7). The default error reporting level is 7.

5.3 Primitives SPPU : May-18,19, Marks 4

5.3.1 Integer Type


 For displaying the integer value the Integer type is used.
 It is similar to the long data type in C.
 The size is 32 bit.

5.3.2 Double Type


 For displaying the real values the double data type is used.
 It includes the numbers with decimal point, exponentiation or both. The exponent
can be represented by E or e followed by integer literal.
 It is not compulsory to have digits before and after the decimal point. For instance
.123 or 123. is allowed in PHP.

5.3.3 String Type


 There is no character data type in PHP. If the character has to be represented then it
is represented using the string type itself; but in this case the string is considered to
be of length 1.
 The string literals can be defined using either single or double quotes.
 In single quotes the escape sequence or the values of the literals can not be
recognized by PHP but in double quotes the escape sequences can be recognized.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5-7 Server Side Scripting Languages

For example -
‘The total marks are= $marks’
will be typed as it is but
“The total marks are= $marks”
will display the value of $marks variable.

5.3.4 Boolean Type


 There are only two types of values that can be defined by the Boolean type and
those are TRUE and FALSE.
 If Boolean values are used in context of integer type variable then TRUE will be
interpreted as 1 and FALSE will be interpreted as 0.
 If Boolean values are used in context of double type then the FALSE will be
interpreted as 0.0.

Review Question

1. Classify data types of PHP and describe various data types in each type.
SPPU : May-18,19, Marks 4

5.4 Type Conversion


 PHP supports for both implicit and explicit type conversion.
 The implicit type conversion is called coercion. In implicit type conversion the
context of expression determines the data type that is expected or required.
Implicit conversion
 The coercion takes place between integer and double types and between Boolean
and other scalar type.
 The coercion is also between the numeric and string types. That means whenever a
numeric value appears in string context then it is converted to string type, similarly
when the string value appears in numeric context it is automatically converted to
numeric type.
 When the double value is converted to integer the fractional part is eliminated and
the value is not rounded.
Explicit conversion
 There are three ways by which the explicit conversion takes place.
1. The syntax is
(datatype)$variable_name

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5-8 Server Side Scripting Languages

For example -
(int)$marks
2. The syntax is -
Conversion_function($variable_name)
For example -
Intval($marks)
3. The syntax is -
settype($variable_name,”datatype”)
For example -
settype($marks,”integer”);
 The gettype function is useful to obtain the data type of the variable.

5.5 Operations and Expressions

5.5.1 Arithmetic Operators


 PHP supports the collection of arithmetic operators such as +, -, /, *, %, ++ and –
with their usual meaning.
 While using the arithmetic operators if both the operands are integer then the result
will be integer itself.
 If either of the two operands is double then the result will be double.
 PHP has large number of predefined functions. Some of these functions are enlisted
in the following table -

Function Purpose

floor The largest integer less than or equal to the parameter is returned.
For example floor(4.9) will return 4,

ceil The smallest integer greater than or equal to the parameter is returned.
For example ceil(4.9) will return 5,

round Nearest integer is returned.

abs Returns the absolute value of the parameter.

min It returns the smaller element.

max It returns the larger element.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5-9 Server Side Scripting Languages

5.5.2 Relational Operators


 There are eight relational operators used in PHP.
 These are <, >, <=, >=, !=, == has their usual meaning. These are six traditional
operators.
 The operator === is used in PHP. It returns true if both operands that are using ===
have same type and have same value.
 The operator !== is opposite of ===.
 If one of the operand in the six operators is not same then the coercion will occur
automatically.

5.5.3 Boolean Operators


 The Boolean operators are

Operator Meaning

and The binary AND operation is performed.

&&

or The binary OR operation is performed.

||

xor The XOR operation will be performed.

5.5.4 String Operators


 Concatenation is the only one operator used in string. It is denoted by dot.
 Strings are treated as the array of characters. The first position of the character is
indexed as 0.
 The sample PHP script that stores the string in a variable is as given below -

PHPScript[stringDemo1.php]
<?php
$s="I like PHP";
echo $s;
?>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 10 Server Side Scripting Languages

Output

Note that the variable s is assigned with the string. The string is given in a double
quote. Then using the echo whatever string is stored in the variable s is displayed on the
console.

5.6 Output
 The PHP is a server side scripting language and is used to submit the web page to
the client browser. Hence it is a standard method of embedding the PHP code
within the XHTML document. That means we can use the XHTML tags in PHP
while displaying the output.
 The print function is used to create simple unformatted output. For example : The
string can be displayed as follows
print “I am proud of my <b>country</b>”
The numeric value can also be displayed using the print. For example -
print(100);
It will display the output as 100.
 PHP also makes use of the printf function used in C. For example
printf(“The student %d has %f marks”,$roll_no,$marks);
 Following is a simple PHP document which makes use of the statements for
displaying the output.

PHP Document[OutputDemo.php]
<html>
<head>
<title> Output Demo</title>
</head>
<body>
<?php
print "<h2>Welcome to my Website </h2>";

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 11 Server Side Scripting Languages

print "<hr/>";
$roll_no=1;
$name="AAA";
printf("<b>The roll number: %d</b>",$roll_no);
print "<br/><b>";
printf("The name: %s",$name);
print "</b>";
?>
</body>
</html>
Output

5.7 Statements Control


 The control statements in PHP are similar to the control statements that are used in
C.
 The control statements include if statements, while, do while and for loops.

5.7.1 The Selection Statement


 The if statement, the if … else statement or if…elseif statements are used in
selection statements. Following is an example of it.

PHPDocument[selection.php]
<html>
<head>
<title>Selection Demo</title>
</head>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 12 Server Side Scripting Languages

<body>
<?php
print "<h2>Selection Statement </h2>";
$a=10;
$b=20;
$c=30;
if($a>$b)
if($a>$c)
print "<b><I>a is the largest number </I></b>";
else
print "<b><I> c is the largest number</I></b>";
else
if($b>$c)
print "<b><I>b is the largest number</I></b>";
else
print "<b><I>c is the largest number</I></b>";
?>
</body>
</html>
Output

 Similar to if statement the switch statement can also be used for selection.
Following is a simple PHP script for demonstrating switch statement -

PHPDocument[SwitchDemo.php]
<?php
$today = getdate();
switch($today['weekday'])
{

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 13 Server Side Scripting Languages

case "Monday":print "Today is Monday";


break;
case "Tuesday":print "Today is Tuesday ";
break;
case "Wednesday":print "Today is Wednesday ";
break;
case "Thursday":print "Today is Thursday";
break;
case "Friday":print "Today is Friday";
break;
case "Saturday":print "Today is Saturday";
break;
case "Sunday":print "Today is Sunday ";
break;
default: print "Invalid input";
}
?>
Output

5.7.2 Looping Structure


 The while, for and do-while statements of PHP are similar to JavaScript.
 Following is a simple PHP script which displays the first 10 number.

PHPDocument[LoopDemo1.php]
<?php
$i=1;
print "The numbers are ...";
print "<br/>";

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 14 Server Side Scripting Languages

while($i<=10)
{
print $i;
print "<br/>";
$i++;
}
?>
Output

Similarly we can modify the above script by using do-while and for loop as follows -

do …while for

<?php <?php
$i=1; print "The numbers are ...";
print "The numbers are ..."; print "<br/>";
print "<br/>"; for($i=1;$i<n)
do {
{ print $i;
print $i; print "<br/>";
print "<br/>"; $i++;
$i++; }
}while($i<=10); ?>
?>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 15 Server Side Scripting Languages

Example 5.7.1 Write a PHP script to display the squares and cubes of 1 to 10 numbers.
Solution :
<html>
<head>
<title>Square and Cube Table </title>
</head>
<body>
<center>
<?php
print "<table border =1>";
print "<tr>";
print "<th>Number</th>";
print "<th>Square</th>";
print "<th>Cube</th>";
print "</tr>";
for($i=1;$i<=10;$i++)
{
print "<tr>";
print "<td>$i";
print "</td>";
print "<td>";
print $i*$i;
print "</td>";
print "<td>";
printpow($i,3);
print "</td>";
print "</tr>";
}
print "</table>";
?>
</center>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 16 Server Side Scripting Languages

Output

Example 5.7.2 Write a PHP script to compute the sum and average of N numbers.
Solution :
<html>
<head>
<title> Sum and Average </title>
</head>
<body>
<center>
<?php
$sum=0;
for($i=1;$i<=10;$i++)
{
$sum+=$i;
}
$avg=$sum/10;
print "The Sum is: $sum";
print "<br/>";
print "the Average is: $avg";
?>
</center>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 17 Server Side Scripting Languages

Output

5.8 Arrays SPPU : Dec.-18, May-18,19, Marks 6

 An array is a collection of similar type of elements, but in PHP you can have the
elements of mixed type together in single array.
 In each PHP, each element has two parts key and value.
 The key represents the index at which the value of the element can be stored.
 The keys are positive integers that are in ascending order.

5.8.1 Creating and Manipulating Arrays


For creating an array in PHP, we use array() construct.
Syntax :
$array_name=array(value)
Example : Following PHP script shows how to create an array in PHP.
ArrayCreateDemo.php
<!DOCTYPE html>
<html>
<body>

<?php
$fruits = array("Mango", "Apple", "Banana","Grapes");
echo $fruits[0] . "," . $fruits[1] . "," . $fruits[2] . ",". $fruits[3];
?>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 18 Server Side Scripting Languages

Output

Program Explanation : In above program,


1) We have created an array named fruits using array() construct
2) In the echo statement we are displaying each element of the array with the help
of array index such as fruts[0],fruits[1],… and so on.
Adding and Deleting Elements
 In PHP, arrays are dynamic. That means they can grow in size or can shrink.
 We can add the element in the array using key/index that hasn’t used. For example -
$name[5]=”CCC”;
 As there is no current value for index 5, the array will grow. Similarly we can skip
the index value and add the element as follows -
$name[ ]=”CCC”;
 The advantage to this approach is that we don’t have to worry about skipping an
index key.
 We can skip some index and can insert the element in the array. For example -
$names=array(“AAA”,”BBB”,”CCC”,”DDD”);
$names[8]=”HHH”;
 If we iterate through the array elements then -
Array ([0]=>AAA [1]=>BBB [2]=>CCC [3]=>DDD [8] =>HHH)
 Thus there is now gap in our array. If we try to reference the array[4] then it will
return NULL value which represents that there is no value present at that index.
 Using the unset function we can create gaps in the PHP array. For example -
PHP Document
<!DOCTYPE html>
<html>
<body>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 19 Server Side Scripting Languages

<?php
$Student = array("AAA","BBB","CCC","DDD","EEE");
echo "<br/>Original Array<br/>";
print_r($Student);
echo "<br/>Deleting element at index 2<br/>";
unset($Student[2]);
print_r($Student);
echo "<br/>Adjusting gap<br/>";
$Student=array_values($Student);
print_r($Student);
?>
</body>
</html>
Output

Script Explanation :
1. In above script we have used unset function to create a gap at index 2.
2. Later on we have used array_values() to adjust this gap by subsequent element.
3. Using the print_r function the array can be displayed on the browser window.
Checking if value exists

 The isset () function is used to check whether a variable is set or not.


 If a variable is already unset with unset() function, it will no longer be set.
 The isset() function return false if testing variable contains a NULL value.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 20 Server Side Scripting Languages

PHP Document
<!DOCTYPE html>
<html>
<body>
<?php
$Student = array(1=>"AAA",2=>"BBB");
echo "<br/>Original Array<br/>";
print_r($Student);
if(isset($Student[0]))
echo "<br/>There is no value set at index 0<br/>";
if(isset($Student[1]))
echo "The value present at index 1 is: ".$Student[1];
?>
</body>
</html>

5.8.2 Types of Arrays


There are three types of arrays.
1. Indexed array : Indexed array are the arrays with numeric index. The array values
can be stored from index 0. For example -
<html>
<head>
<title>PHP Indexed Arrays</title>
</head>
<body>
<?php
$names = array("AAA", "BBB", "CCC");
// Printing array structure
print_r($names);
?>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 21 Server Side Scripting Languages

Here values get stored at corresponding index as follows -


$mylist[0] = 10;
$mylist[1] = 20;
$mylist[2] = 30;
$mylist[3] = 40;
$mylist[4] = 50;
We can directly assign some value at specific index.
$mylist[5] = 100;
2. Associated array : Associated arrays are the arrays with named keys. It is a kind of
array with name and value pair. For example -
<html>
<head>
<title>PHP Associative Array</title>
</head>
<body>
<?php
$city["AAA"] = "Pune";
$city["BBB"] = "Mumbai";
$city["CCC"] = "Chennai";

// Printing array structure


print_r($city);
?>
</body>
</html>
Output

3. Multidimensional Arrays

 PHP support for multidimensional arrays.


 We can store the elements in two dimensional array as
$Student = array

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 22 Server Side Scripting Languages

(
array(10,"AAA"),
array(20,"BBB"),
array(30,"CCC"),
);
 The complete PHP program in which the multidimensional array is created and
accessed is as follows -
PHP Document
<!DOCTYPE html>
<html>
<body>
<?php
$Student = array
(
array(10,"AAA"),
array(20,"BBB"),
array(30,"CCC"),
);
echo "The elements in Two dimensional array...<br/>";
for ($row = 0; $row < 3; $row++) {
for ($col = 0; $col < 2; $col++) {
echo " ".$Student[$row][$col];
}
echo "<br/>";
}
?>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 23 Server Side Scripting Languages

5.8.3 Extracting Data from Arrays, Implode, Explode and Flip Functions
i) The extract function :

Using the extract() function the array keys becomes the variable name and the array
values become the variable values.
Syntax :
int extract($input_array, $extract_rule, $prefix)
Where
$input_array : is the name of the array whose values need to be extracted. This is a
required parameter.
$extract_rule : This is an optional parameter. This parameter specifies how invalid
variable names will be treated.
$prefix : The prefix is automatically separated from the array key by an underscore
character. This is an optional parameter.
Example Program
<!DOCTYPE html>
<html>
<body>

<?php
$arr = array("a" => "Pune","b" => "Mumbai", "c" => "Chennai");
extract($arr);
echo "\$a = $a; \$b = $b; \$c = $c";
?>
</body>
</html>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 24 Server Side Scripting Languages

ii) The implode function :


The implode function converts array into the string. For example -
implodeDemo.php
<!DOCTYPE html>
<html>
<body>
<?php
$arr[0] = "Red";
$arr[1] = "Blue";
$arr[2] = "Green";
$arr[3] = "Yellow";
$text = implode(",",$arr);
echo $text;
?>
</body>
</html>
Output

iii) The explode function

The explode() function is to split a string.


Syntax :
explode(delimiter, string_name, limit)
Where
Delimiter : It sets the boundary string within the input string
String_name : The name of the string to be split
Limit : It indicates the maximum number of elements in the output array if set to +ve
value. If set to -ve value, all but the last element will be present in the output array.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 25 Server Side Scripting Languages

Example Program
<!DOCTYPE html>
<html>
<body>

<?php
$str="I Love my Country";
$arr=explode(" ",$str);
print_r($arr);
?>
</body>
</html>
Output

iv) The flip function

The array_flip() function is used to exchange the keys with their associated values in
array.
That means after applying the array_flip function we get keys from array become
values and values from array become keys.
Syntax :
array_flip(name_of_array)

Example Program
<!DOCTYPE html>
<html>
<body>

<?php
$arr=array("Red"=>10,"Green"=>20,"Blue"=>30,"Black"=>40);
$result=array_flip($arr);

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 26 Server Side Scripting Languages

print_r($result);
?>

</body>
</html>
Output

5.8.4 Traversing Arrays


1. The current and next function

 The array element reference start at the first element and array maintains an
internal pointer using which the next element can be easily accessible.
 This helps to access the array elements in sequential manner.
 The pointer current is used to point to the current element in the array. Using the
next function the next subsequent element can be accessed. Following PHP code
illustrates this idea -
PHP Document[ArrayFunDemo4.php]
<?php
$mylist = array("Hello", "PHP","You","Are","Wonderful!!!");
$myval=current($mylist);
print("The current value of the array is <b>$myval</b>");
print "<br/>";
$myval=next($mylist);
print("The next value of the array is <b>$myval</b>");
print "<br/>";
$myval=next($mylist);
print("The next value of the array is <b>$myval</b>");

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 27 Server Side Scripting Languages

print "<br/>";
$myval=next($mylist);
print("The next value of the array is <b>$myval</b>");
print "<br/>";
$myval=next($mylist);
print("The next value of the array is <b>$myval</b>");
?>
Output

2. The each and foreach function

 Using each function we can iterate through the array elements.


PHP Document[ArrayFunDemo5.php]
<?php
$mylist = array("Hello", "PHP","You","Are","Wonderful!!!");
while($myval=each($mylist))
{
$val=$myval["value"];
print("The current value of the array is <b>$val</b>");
print "<br/>";
}
?>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 28 Server Side Scripting Languages

Output

 The foreach function is used to iterate through all the elements of the loop. The
syntax of foreach statement is as follows -
foreach($array as $value)
{
statements to be executed
}
 The above code can be modified and written as follows -
PHP Document[ArrayFunDemo6.php]
<?php
$mylist = array("Hello", "PHP","You","Are","Wonderful!!!");

foreach($mylist as $value)
{
print("The current value of the array is <b>$value</b>");
print "<br/>";
}
?>
The output will be the same as above.

Review Questions

1. What is associative arrays in PHP ? Explain it with the help of simple PHP code.
SPPU : May-18,19, Marks 6
2. What is multi-dimensional arrays in PHP ? Explain it with simple PHP code.
SPPU : Dec.-18, Marks 6

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 29 Server Side Scripting Languages

5.9 Functions
The functions in PHP are very much similar to the functions in C. Let us discuss it in
detail.

5.9.1 General Characteristics of Functions


 The syntax of the function definition is as follows -
functionname_of_function(parameter list)
{
statements to be executed in function


…}
 The function gets executed only after the call to that function. The call to the
function can be from anywhere in the PHP code. For example -

PHPDocument[FunDemo1.php]
<?php
functionmyfun()
{
print "<i>This statement is in myfun()</i>";
}
print "<b>The Function Demo Program</b>";
print "<br/>";
myfun();
?>
Output

 The return statement is used for returning some value from the function body.
Following PHP scripts shows this idea.

PHPDocument[FunDemo2.php]
<?php
function Addition()

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 30 Server Side Scripting Languages

{
$a=10;
$b=20;
$c=$a+$b;
return $c;
}
print "<b>The Function Demo Program with return statement</b>";
print "<br/>";
print "10+20= ".Addition();
?>
Output

5.9.2 Parameters
 The parameter that we pass to the function during the call is called the actual
parameter. These parameters are generally the expressions.
 The parameters that we pass to the function while defining it is called the formal
parameters. These are generally the variables. It is not necessary that the number of
actual parameters should match with the number of formal parameters.
 If there are few actual parameter and more formal parameters then the value of
formal parameter will be some unbounded one.
 If there are many actual parameters and few formal parameters then the excess of
actual parameters will be ignored.
 The default parameter passing technique in PHP is pass by value. The parameter
passing by value means the values of actual parameters will be copied in the formal
parameters. But the values of formal parameters will not be copied to the actual
parameters.
 Following PHP script illustrates the functions with parameters.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 31 Server Side Scripting Languages

PHP Document[FunDemo3.php]
<?php
function Addition($a,$b)
{
$c=$a+$b;
return $c;
}
print "<b>The Function Demo Program with parameter passing and return
statement</b>";
print "<br/>";
$x=10;
$y=20;
print "10+20= ".Addition($x,$y);
?>
Output

5.10 Built in Functions


PHP has number of predefined functions.

5.10.1 Functions based on Basic Operations


These function help in performing basic operations such floor, ceil, round and so on.

Function Purpose

floor The largest integer less than or equal to the parameter is returned. For example -
floor(4.9) will return 4,

ceil The smallest integer greater than or equal to the parameter is returned. For example -
ceil(4.9) will return 5,

round Nearest integer is returned.

abs Returns the absolute value of the parameter.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 32 Server Side Scripting Languages

min It returns the smaller element.

max It returns the larger element.

5.10.2 String Handling Functions


Various functions used for string handling are -

Function Purpose Sample PHP code Output

strlen(string1) It finds the total number of characters in <?php 6


the string $s=”Friend”;
echo $s
<?php

strcmp It compares the two strings. <?php 0


(string1,string2) It is case sensitive. echo
strcmp("PHP”,”PHP”);
If this function returns 0 then two strings
?>
are equal.
If this function returns >0 then string1 is
greater than string2.
If this function returns <0 then string1 is
less than string2.

strtolower This function converts the characters in <?php php


(string1) string1 to lower case. echo strtolower("PHP.");
?>

strtoupper This function converts the characters in <?php PHP


(string1) string1 to upper case. echo strtolower("php");
?>

trim(string1) This function eliminates the white space <?php : PHP


from both the ends of the string. $str = " PHP "; : PHP
echo "<h3>: $str</h3>";
echo "<h3>:".trim($str);
echo "</h3>";
?>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 33 Server Side Scripting Languages

Example 5.10.1 Write a PHP program to do string manipulations.

Solution : For this program we will apply various built in string manipulating functions to
the string. The PHP code is as follows -

<?php
$Str1="PHP is Fun";
$length = strlen($Str1);
echo "<b> Length:</b>The length of string: $Str1 is = $length";
echo "<br/><b>Position: </b>The position of word Fun in the $Str1 is ".strpos($Str1,'Fun');
$Str1="Hello";
$Str2="hello";
if(strcmp($Str1,$Str2))
echo "<br/><b>Comparison: </b> The two strings $Str1 and $Str2 are not equal";
else
echo "<br/><b>Comparision: </b> The two strings $Str1 and $Str2 are equal";
$Str1="HELLO";
echo "<br/><b>Changing Case: </b> The string $Str1 becomes ".strtolower($Str1);
echo "<br/><b>Reversing String: </b> The string $Str1 is reversed as ".strrev($Str1);
$Str1="Hello";
$Str2="Friend";
echo "<br/><b>Concatenating strings: </b> The string $Str1 and $Str2 are concatenated
".$Str1.$Str2;
echo "<br/><b>Replacing all instances of string: </b> The string tictactoe is now ";
echo str_replace("t","p","tictactoe");
$Str1="PHP is fun";
$newstring=substr_replace($Str1,"FUN",7,9);
echo "<br><b>Replacing substring: </b> $Str1 becomes $newstring";
?>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 34 Server Side Scripting Languages

Output

5.10.3 Data Type Conversion Functions

Syntax :
Conversion_function($variable_name)

Example :
Intval($marks)

Syntax :
settype($variable_name,”datatype”)

Example :
settype($marks,”integer”);
 The gettype function is useful to obtain the data type of the variable.

5.10.4 Array Handling Functions

Function Purpose

array() Creates an array.

array_change_key_case(array,nameof case) Changes the elements of array from lower to upper


or from upper to lower case.

array_fill() Fills the array with values.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 35 Server Side Scripting Languages

array_keys() Returns all the keys of the array.

array_merge() Merges one or more arrays into one array.

array_search() Searches array for given value and returns the keys.

array_value() Returns the values of array.

count() Returns the elements in array.

current() Returns current element in an array.

each() Returns current key and value pair from array.

end() Returns last element value form array.

next() Advances the internal pointer of the array to point to


the next element.

sizeof() Returns the total number of elements.

sort() This function is for sorting the array.

5.11 Form Handling


 PHP is used for form handling. For that purpose the simple form can be designed in
HTML and the values of the fields defined on the form can be transmitted to the
PHP script using GET and POST methods.
 For forms that are submitted via "GET" method, we can obtain the form via the
$_GET array variable.
 For forms that are submitted via "POST" method, we can obtain the form via the
$_POST array variable.

Example 5.11.1 Create HTML form with one textbox to get user's name. Also write PHP code
to show length of entered name when, the HTML form is submitted.

Solution : Step 1 : The HTML form can be created as follows.


<!DOCTYPE html>
<html>
<head><title> HTML-PHP DEMO</title>
</head>
<body>
<form method="post"
action="http://localhost/getdata.php">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 36 Server Side Scripting Languages

Name: <input type="text" name="myname" size="20"/>


<br/>
<input type="submit" name="submit"
value="submit"/>
</form>
</body>
</html>
Step 2 : The PHP script to display the length of submitted name is as written below.
<?php
print "The name is: ";
print $_POST["myname"];
$len= strlen($_POST["myname"]);
print "<br/> The length of name is: ";
print $len;
?>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 37 Server Side Scripting Languages

Example 5.11.2 Create HTML form to enter one number. Write PHP code to display the
message about number is odd or even.

Solution : Step 1 : The HTML form for accepting number is created as below -
<!DOCTYPE html>
<html >
<head><title> HTML-PHP DEMO</title>
</head>
<body>
<form method="post" action="http://localhost/getdata.php">
Enter Number: <input type="text" name="mynum" size="5"/>
<br/>
<input type="submit" name="submit" value="submit"/>
</form>

</body>
</html>
Step 2 : The PHP script deciding whether the number is even or odd is as given
below -
<?php
print "The number is: ";
print $_POST["mynum"];
$a= $_POST["mynum"];
if($a%2==1)
print "<br/> The number is odd ";
else
print "<br/> The number is even ";
?>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 38 Server Side Scripting Languages

Example 5.11.3 Create a form containing information sl.no, title of the book, publishers,
quantity, price read the data from the form and display it using PHP script.

Solution : Step 1 : Create an HTML page for inputting the data. Following is the code for
HTML script .

HTML Document[input.html]
<!doctype html>
<html>
<head>
<title> Book Order Form </title>
</head>
<body>
<h3> Enter the Book Data </h3>
<form method="post" action="http://localhost/php-examples/formdemo.php">
<table>
<tr>
<td>Sr.No.</td>
<td><input type="text" name="SLNo"></td>
</tr>
<tr>
<td>Book name</td>
<td><input type="text" name="BName"></td>
</tr>
<tr>
<td>Publisher</td>
<td><input type="text" name="PUBName"></td>
</tr>
<tr>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 39 Server Side Scripting Languages

<td>Price</td>
<td><input type="text" name="Price"></td>
</tr>
<td>Quantity</td>
<td><input type="text" name="Qty"></td>
</tr>
<tr>
<td><input type="submit" value="Submit"></td>
<td><input type="submit" value="Clear"></td>
</tr>
</table>
</form>
</body>
</html>

Step 2 : Create a PHP script which will read out the data entered by the user using HTML
form. The code is as follows -

PHP Document[formdemo.php]
<html>
<head>
<title>Book Information</title>
</head>
<body>
<?php
$BName=$_POST["BName"];
$PUBName=$_POST["PUBName"];
$Price=$_POST["Price"];
$Qty=$_POST["Qty"];
?>
<center>
<h3> Book Data </h3>
<table border=1>
<tr>
<th>Book name</th>
<th>Publisher</th>
<th>Price</th>
<th>Quantity</th>
</tr>
<tr>
<td><?php print ("$BName"); ?></td>
<td><?php print ("$PUBName"); ?></td>
<td><?php printf("%3.2f",$Price); ?></td>
<td><?php printf("%d",$Qty); ?></td>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 40 Server Side Scripting Languages

</tr>
</table>
</center>
</body>
</html>
Step 3 : Open some suitable web browser and enter the address for the HTML file
which you have created in step 1.

Now click on the Submit button and the PHP file will be invoked. The output will then
be as follows -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 41 Server Side Scripting Languages

Example 5.11.4 Write a PHP program to accept a positive integer 'N' through a HTML form
and to display the sum of all the numbers from 1 to N.
Solution :
<html>
<head>
<title> PHP Demo </title>
</head>
<body>
<form method="post">
<input type="text" name="num"/>
<input type="submit" value="Submit"/>
</form>
</body>
</html>
<?php
//getting values from HTML form
$n = intval($_POST['num']);
$sum=0;
for($i=1;$i<=$n;$i++)
$sum=$sum+$i;
echo "The sum of all numbers from 1 to ".$n." is ".$sum;
?>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 42 Server Side Scripting Languages

5.12 Pattern Matching

 The pattern matching technique which is used in PHP is of two types -The first one
is based on POSIX regular expression and the another is based on Perl regular
expression.

 There is a preg_match function which is used to check the matching of the pattern
from the text. It takes two parameters the first parameter is the pattern to be
matched and the second parameter is the text against which the pattern is to be
matched.

 The preg_split is the function that splits the string into the chunks.

 Following is a PHP script in which both of these functions are discussed.

PHP Document[PatternMatchDemo.php]
<?php
print "<h3>Use of preg_match function</h3>";
if (preg_match("/gram/", "I like Programming in PHP!"))
print "The pattern is matching <br />";
else
print "The pattern does not match <br />";
print "<h3>Use of preg_split function</h3>";
$text ="Hello:friends:how:are:you?";
print "The original string is<b> $text</b>";
print "<br/>";
print "The split is as follows ...<br/>";
$chunks=preg_split("/:/",$text);
while($myval=each($chunks))
{
$val=$myval["value"];
print("<b>$val</b>");
print "<br/>";
}
?>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 43 Server Side Scripting Languages

Output

Example 5.12.1 Explain the string comparison capability of PHP using regular expression with
an example.

Solution : The preg_match function is used to compare two strings using regular
expression. The first parameter to this function is a regular expression and second
parameter is the string which is used for matching with the regular expression.
Following PHP program illustrates, the matching of date pattern using regular
expression.

Example program in PHP


<?php
$regex = "/[a-zA-Z]+ \d+/";
if (preg_match($regex, "May 16"))
{
// The expression "[a-zA-Z]+ \d+" matches the date string
echo "The date is matching with given regular expression!";
}
else
{
// If preg_match() returns false, then the regex does not
// match the string
echo "The regex pattern does not match.";
}
?>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 44 Server Side Scripting Languages

Output

Example 5.12.2 Write a PHP program that tests whether an email address is input correctly.
Verify that the input begins with a series of characters followed by the @ character, another
series of characters, a period ‘.’ And a final series of characters. Test your program with both
valid and invalid email address.
Solution : Step 1 : The HTML form containing the text box for inputting the email address
is created as follows -
<html>
<head>
<title> Inserting Data into Database Table</title>
</head>
<body>
<form method = "post" action = "http://localhost/php-examples/ValidateEmail.php ">
<label>Email</label>
<input type="text" name="email" />
<br />
<input type="submit" value="Submit">
</form>
</body>
</html>
Step 2 : The PHP script that validates the given email address using regular
expression is as follows -
ValidateEmail.php
<?php
$reg = '/^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*(\.[a-z]{2,3})$/';

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 45 Server Side Scripting Languages

$email=$_POST["email"];
if (preg_match($reg, $email))
{
echo "Valid Email ID";
}
else
{
echo "Invalid Email ID.";
}
?>

Example 5.12.3 Design application to send an email using PHP.

Solution :
<?php
$to = "[email protected]";
$subject = "Hi!";
$body = "Hi,\n\nHow are you?";
if (mail($to, $subject, $body))
{
echo("<p>Email successfully sent!</p>");
}
else
{
echo("<p>Failure in Email delivery!!!</p>");
}
?>

5.13 Files SPPU : Dec.-18, Marks 6

PHP is known as a server-side scripting language. Hence file handling functions such
as create, read, write, append are some file related operations that are supported by PHP.

5.13.1 Opening and Closing Files


 The first step in file handling is opening of the file.
 It takes two parameters - The first parameter of this function contains the name of
the file to be opened and the second parameter specifies in which mode the file
should be opened.
Modes Description

r Read only. Starts reading from the beginning of the file.

r+ Read/Write. Starts reading from the beginning of the file.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 46 Server Side Scripting Languages

w Write only. Opens and clears the contents of file; or creates a new file if it is not
created

w+ Read/Write. Opens and clears the contents of file; or creates a new file if it is not
created.

a Append. Opens and writes to the end of the file or creates a new file if it is not
created.

a+ Read/Append. Preserves file content by writing to the end of the file.

For example :
$my_file = 'file.txt';
$file_handle = fopen($my_file, 'a') or die('Cannot open file: '.$my_file);
The fopen function returns TRUE if the required file is opened.

5.13.2 Reading from File


 The fread is the function which is used to read the file.
 It takes two parameters. The first parameter is the handle to the file and the second
parameter is the number of bytes to be read. The filesize is the function which takes
the filename as the parameter. For example -
$mystring = fread($file_handle, filesize(“file.txt”));
 There is another function named file_get_contents using which the contents of the
file can be obtained.
 The fgets() function is used to read a single line from the file. For example,
following code displays the contents of the file line by line.
while(!feof($file_handle))
{
echo fgets($file_handle). "<br />";
}

5.13.3 Writing to a File


 The fwrite is the function which is used to write the contents to the file.
 It takes two parameters - the first parameter is the handle to the file and the second
parameter is the number of bytes to be written. For example -
$Written_string = fread($file_handle, $my_data);

Example 5.13.1 Create a form containing information sl.no, title of the book, publishers,
quantity, price read the data from the form and write onto the file using PHP script.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 47 Server Side Scripting Languages

Solution : Step 1 : We will create an input form for the user to enter the data. The HTML
code is as follows. (It is the same HTML form which we have discussed in the last section)

HTML Document[input.html]
<!doctype html public "-//w3c//dtd html 4.0 transitional//en">
<html>
<head>
<title> Book Order Form </title>
</head>
<body>
<h3> Enter the Book Data </h3>
<form method="post" action="http://localhost/php-examples/formdemo.php">
<table>
<tr>
<td>Sr.No.</td>
<td><input type="text" name="SLNo"></td>
</tr>
<tr>
<td>Book name</td>
<td><input type="text" name="BName"></td>
</tr>
<tr>
<td>Publisher</td>
<td><input type="text" name="PUBName"></td>
</tr>
<tr>
<td>Price</td>
<td><input type="text" name="Price"></td>
</tr>
<td>Quantity</td>
<td><input type="text" name="Qty"></td>
</tr>
<tr>
<td><input type="submit" value="Submit"></td>
<td><input type="submit" value="Clear"></td>
</tr>
</table>
</form>
</body>
</html>
Step 2 : Following is a simple PHP script which displays the data and then writes it to
the file.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 48 Server Side Scripting Languages

PHP Document
<html>
<head>
<title>Book Information</title>
</head>
<body>
<?php
$BName=$_POST["BName"];
$PUBName=$_POST["PUBName"];
$Price=$_POST["Price"];
$Qty=$_POST["Qty"];
?>
<center>
<h3> Book Data </h3>
<table border=1>
<tr>
<th>Book name</th>
<th>Publisher</th>
<th>Price</th>
<th>Quantity</th>
</tr>
<tr>
<td><?php print ("$BName"); ?></td>
<td><?php print ("$PUBName"); ?></td>
<td><?php printf("%3.2f",$Price); ?></td>
<td><?php printf("%d",$Qty); ?></td>
</tr>
</table>
</center>
<?php
$my_file = 'file.txt';
$file_handle = fopen($my_file, 'a') or die('Cannot open file: '.$my_file);
fwrite($file_handle, $BName);
fwrite($file_handle, "\r\n");
fwrite($file_handle, $PUBName);
fwrite($file_handle, "\r\n");
fwrite($file_handle, $Price);
fwrite($file_handle, "\r\n");
fwrite($file_handle, $Qty);
fclose($file_handle);
?>
<p>The contents are written to the file <u>file.txt<u></p>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 49 Server Side Scripting Languages

Step 3 : Now open the web browser and type the address of the html file which you
have created in step 1. On clicking the submit button on the this input form the data will
be displayed as follows -

Step 4 : Open the current directory folder (The folder in which your html and PHP
scripts are present). You will obtain a text file file.txt. Just Open the file and see the
contents. I have got the following contents -

Review Question

1. Explain server side include in PHP with sample code.


SPPU : Dec.-18, Marks 6

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 50 Server Side Scripting Languages

5.14 Cookies
In this section we will discuss how to create and read cookies.

5.14.1 Introduction to Cookies


 Cookie is a small file that server embeds in the user's machine.
 Cookies are used to identify the users.
 A cookie consists of a name and a textual value. A cookie is created by some
software system on the server.
 In every HTTP communication between browser and server a header is included.
The header stores the information about the message.
 The header part of http contains the cookies.
 There can be one or more cookies in browser and server communication.

5.14.2 PHP Support for Cookies


 PHP can be used to create and retrieve the cookies.
 The cookie can be set in PHP using the function called setcookie()
 The syntax for the cookie is -
setcookie(name,value,expire_period,path,domain)
 Following is a simple PHP document which illustrates how to set the cookies -
PHP Document[CookieSetDemo.php]
<?php
$Cookie_period=time()+60*60*24*30;
setcookie("Myname", "Monika", $Cookie_period);
?>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 51 Server Side Scripting Languages

Note that you have got the blank screen it indicates that the cookie is set. In above PHP
document we have set the PHP script for one month. Just observer the third parameter of
the setcookie function.
Now you can retrieve the cookie and read the value to ensure whether or the cookie is
set.

PHP Document[CookieReadDemo.php]
<html>
<head><title>Reading Cookies</title>
<body>
<?php
if (isset($_COOKIE["Myname"]))
echo "<h3>Welcome " . $_COOKIE["Myname"]."!!!</h3>";
else
echo "<h3>Welcome guest!</h3>";
?>
</body>
</html>
Output

Program Explanation
The isset function is used for checking whether or not the cookie is set. Then using the
$_COOKIE the value of the cookie can be retrieved.

5.15 Session Tracking SPPU : Dec.-19, Marks 8

 When you open some application, use it for some time and then close it. This entire
scenario is named as session.
 Session state is a server-based state mechanism that lets web applications store and
retrieve objects of any type for each unique user session. That is, each browser
session has its own session state stored as a serialized file on the server, which is
deserialized and loaded into memory as needed for each request. Refer Fig. 5.15.1.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 52 Server Side Scripting Languages

Fig. 5.15.1 Session state

 Because server storage is a finite resource, objects loaded into memory are released
when the request completes, making room for other requests and their session
objects. This means there can be more active sessions on disk than in memory at any
one time.
 Sometimes the information about the session is required by the server. This
information can be collected during the session. This process is called session
tracking.
 In PHP, session state is available to the developer using the $_SESSION variable.
The unique ID for the sessions can be stored in superglobal array $_SESSION.
 PHP keeps track of session by using a function called session_start(). Due to the call
to session_start() function the session ID is created and recorded.
 Following is a simple PHP script in which the information about session is tracked.
PHP Document[SessionDemo.php]
<?php
session_start();
if(isset($_SESSION['pgvisit']))
{
$_SESSION['pgvisit']=$_SESSION['pgvisit']+1;
echo "<h3>You are visiting this page for <i>". $_SESSION['pgvisit']."</i> times</h3>";
}
else
{
$_SESSION['pgvisit']=1;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 53 Server Side Scripting Languages

echo "<h3>You are visiting this page for the first time</h3>";
}
?>

Program Explanation :

 In above program, we have started the session by using session_start() function.


 The isset() function checks if the pgvisit variable has already been set. If pgvisit has
been set, we can increment our counter. If pgvisit is not set, then we create a set it to
1.
 The value of pgvisit is displayed on the screen.

Review Question

1. Explain how session and cookies are used for session management in PHP.
SPPU : Dec.-19, Marks 8

5.16 Using MySQL with PHP SPPU : May-18, Marks 6, Dec.-19, Marks 8

5.16.1 Connecting to Database


The PHP function mysql_connect connects to the MySQL server. There are three
parameters that can be passed to this function. For example -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 54 Server Side Scripting Languages

For example
<?php
// Make a MySQL Connection
$conn=mysql_connect("localhost:3306/mydb","root","mypassword");
if(!$conn)
{
die('error in connection'.mysql_error());
}
else
{
print"connected";
}
mysql_close($conn); //closing the database
?>
The database can be closed using the function mysql_close

5.16.2 Creating Database


We can create a database using the function mysql_query. The mysql_error() function
is used to obtain the error messages if any command gets failed.

For example -
<?php
// Make a MySQL Connection
$conn=mysql_connect("localhost ","root","mypassword");
if(!$conn)
{
die('error in connection'.mysql_error());
}
//Create a database
if(mysql_query("CREATE DATABASE mydb",$conn))
{
print "Database created";
}
else
{
print "Error creating database: " . mysql_error();
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 55 Server Side Scripting Languages

mysql_close($conn); //closing the database


?>

5.16.3 Selecting Database


The database can be selected using the function mysql_select_db().

For example -
<?php
// Make a MySQL Connection
$conn=mysql_connect("localhost:3306/mydb ","root","mypassword");
if(!$conn)
{
die('error in connection'.mysql_error());
}
//Select a database
mysql_select_db("mydb", $conn);
mysql_close($conn); //closing the database
?>

5.16.4 Listing Database


There are various databases present in the MySQL which can be displayed using the
function mysql_list_db().

For example -
<?php
// Make a MySQL Connection
$conn=mysql_connect("localhost:3306/mydb ","root","mypassword");
if(!$conn)
{
die('error in connection'.mysql_error());
}

//Show databases
$db_lists=mysql_list_db($conn)
while($i=$mysql_fetch_object($db_list))
{
echo $i->Database. “\n”; //Present Databases will be displayed
}
mysql_close($conn); //closing the database
?>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 56 Server Side Scripting Languages

5.16.5 Listing Table Names


The tables are present inside the databases. The function mysql_list_tables function is
used to display the tables present in the database or we can use mysql_query

For example -
<?php
// Make a MySQL Connection
$conn=mysql_connect("localhost ","root","mypassword");
if(!$conn)
{
die('error in connection'.mysql_error());
}
$table_list=mysql_query("SHOW TABLES FROM mydb",$con)
if(!$table_list)
{
print "Error!!! " . mysql_error();
}
while($i=$mysql_fetch_row($table_list))
{
echo $i[0]. “\n”; //Listing the tables
}
mysql_close($conn); //closing the database
?>

5.16.6 Creating a Table


Before creating the table a database must be created and within which the table can be
created. Note that before creating a table the desired database must be selected.
<?php
// Make a MySQL Connection
$conn=mysql_connect("localhost ","root","mypassword");
if(!$conn)
{
die('error in connection'.mysql_error());
}

//Create a database
if(mysql_query("CREATE DATABASE mydb",$con))
{
print "Database created";
}
else
{

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 57 Server Side Scripting Languages

print "Error creating database: " . mysql_error();


}
mysql_select_db(“mydb”,$conn); //before creating table select the database
$query=”CREATE TABLE my_table
(
id INT(4),
name VARCHAR(20)
)”;
mysql_query($query,$conn);//Execution of Query

mysql_close($conn); //closing the database


?>

5.16.7 Inserting Data


Using PHP we can insert the data in the database created in the MySQL.

For example -
<?php
// Make a MySQL Connection
$conn=mysql_connect("localhost","root","mypassword");
if(!$conn)
{
die('error in connection'.mysql_error());
}
mysql_select_db(“mydb”,$conn); //select the database
$query=” INSERT INTO my_table (id,name) VALUES(1,'SHILPA')”;
mysql_query($query,$conn);//Execution of Query
$query=” INSERT INTO my_table (id,name) VALUES(2,'MONIKA')”;
mysql_query($query,$conn);//Execution of Query

mysql_close($conn); //closing the database


?>
Sometimes values that can be inserted in the table can be obtained from some another
script and these values might be present in the variables. Insertion of such data can be
done using $_POST variables. It is as shown below -
<?php
// Make a MySQL Connection
$conn=mysql_connect("localhost","root","mypassword");
if(!$conn)
{
die('error in connection'.mysql_error());
}
mysql_select_db(“mydb”,$conn); //select the database

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 58 Server Side Scripting Languages

$query=” INSERT INTO my_table (id,name)


VALUES(‘$_POST[MyID]’,’$_POST[MyName]’)”;
mysql_query($query,$conn);//Execution of Query

mysql_close($conn); //closing the database


?>
We can display these records using the SELECT query. For example -
<?php
// Make a MySQL Connection
$conn=mysql_connect("localhost ","root","mypassword");
if(!$conn)
{
die('error in connection'.mysql_error());
}
mysql_select_db(“mydb”,$conn); //select the database
//Execution of Query for displaying the data
$result=mysql_query(”SELECT * FROM my_table”);
while($row = mysql_fetch_array($result))
{
echo $row['id'] . " " . $row['name']; // Each record will be displayed line by line

echo "<br />";


}
mysql_close($conn); //closing the database
?>

5.16.8 Altering Table


The ALTER table command is useful for various reasons such as to add some columns
in the existing table, to delete some column from the table, for changing the size of some
field or to change the name of some column. In the following example we are adding one
column named addr to the existing table my_table
<?php
// Make a MySQL Connection
$conn=mysql_connect("localhost","root","mypassword");
if(!$conn)
{
die('error in connection'.mysql_error());
}
mysql_select_db(“mydb”,$conn); //select the database
$query=” ALTER TABLE my_table ADD COLUMN addrVARCHAR(30)”;
mysql_query($query,$conn);//Execution of Query
mysql_close($conn); //closing the database
?>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 59 Server Side Scripting Languages

5.16.9 Deleting Database


We can delete the values from the database using the DELETE query.
For example -
<?php
// Make a MySQL Connection
$conn=mysql_connect("localhost","root","mypassword");
if(!$conn)
{
die('error in connection'.mysql_error());
}
mysql_select_db(“mydb”,$conn); //select the database
$query=” DELETE FROM my_table WHERE id=1”;
mysql_query($query,$conn);//Execution of Query
mysql_close($conn); //closing the database
?>
Similarly we can delete a database using the query DROP.

For example -
<?php
// Make a MySQL Connection
$conn=mysql_connect("localhost","root","mypassword");
if(!$conn)
{
die('error in connection'.mysql_error());
}
mysql_select_db(“mydb”,$conn); //select the database
$query=” DROP DATABASE mydb”;
mysql_query($query,$conn);//Execution of Query
mysql_close($conn); //closing the database
?>

Examples

Example 5.16.1 Write a PHP script to create a new database table with 4 fields of your choice
and perform following database operations.
1. Insert 2. Delete 3. Update 4. Display

Solution : We will create a table in the database test. The name of the table ismytable.
Then we will insert the record into the table using the INSERT command, update
particular field of the record using the command UPDATE and delete the record using
the command DELETE.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 60 Server Side Scripting Languages

The PHP script is as follows -


PHPDocument[DBDemo.php]
<?php
// Make a MySQL Connection
mysql_connect("localhost", "root", "mypassword") or die(mysql_error());
mysql_select_db("test") or die(mysql_error());
echo "Connected to database!";
mysql_query("CREATE TABLE mytable(id INT NOT NULL AUTO_INCREMENT, PRIMARY
KEY(id), name VARCHAR(30),
phoneINT,emailIdVARCHAR(30))")
or die(mysql_error());
print "<br/>";
echo "Table Created!";

// Insert a row of information into the table


mysql_query("INSERT INTO mytable
(name, phone,emailId) VALUES('Priyanka', '11111','[email protected]' ) ")
or die(mysql_error());

mysql_query("INSERT INTO mytable


(name, phone,emailId) VALUES('Kumar', '22222','[email protected]' ) ")
or die(mysql_error());

mysql_query("INSERT INTO mytable


(name, phone,emailId) VALUES('Archana', '33333','[email protected]' ) ")
or die(mysql_error());
print "<br/>";
echo "Data Inserted!";
$result =mysql_query("SELECT * FROM mytable")
or die(mysql_error());
print "<br/>";
print "<b>User Database</b>";
echo "<table border='1'>";
echo "<tr><th>ID</th><th>Name</th><th>Phone</th><th>Email-ID</th>
</tr>";
while($row = mysql_fetch_array( $result ))
{
// Print out the contents of each row into a table
echo "<tr><td>";
echo $row['id'];
echo "</td><td>";
echo $row['name'];
echo "</td><td>";

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 61 Server Side Scripting Languages

echo $row['phone'];
echo "</td><td>";
echo $row['emailId'];
echo "</td></tr>";
}
echo "</table>";
$result = mysql_query("UPDATE mytable SET phone='55555' WHERE phone='22222'")
or die(mysql_error());

print "<br/>";
echo "Data Updated!";
$result =mysql_query("SELECT * FROM mytable")
or die(mysql_error());
print "<br/>";
print "<b>User Database</b>";
echo "<table border='1'>";
echo "<tr><th>ID</th><th>Name</th><th>Phone</th><th>Email-ID</th>
</tr>";
while($row = mysql_fetch_array( $result ))
{
// Print out the contents of each row into a table
echo "<tr><td>";
echo $row['id'];
echo "</td><td>";
echo $row['name'];
echo "</td><td>";
echo $row['phone'];
echo "</td><td>";
echo $row['emailId'];
echo "</td></tr>";
}
echo "</table>";
$result = mysql_query("DELETE FROM mytable WHERE phone='33333'")
or die(mysql_error());
print "<br/>";
echo "Data Deleted!";
$result =mysql_query("SELECT * FROM mytable")
or die(mysql_error());
print "<br/>";
print "<b>User Database</b>";
echo "<table border='1'>";
echo "<tr><th>ID</th><th>Name</th><th>Phone</th><th>Email-ID</th>
</tr>";
while($row = mysql_fetch_array( $result ))

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 62 Server Side Scripting Languages

{
// Print out the contents of each row into a table
echo "<tr><td>";
echo $row['id'];
echo "</td><td>";
echo $row['name'];
echo "</td><td>";
echo $row['phone'];
echo "</td><td>";
echo $row['emailId'];
echo "</td></tr>";
}
echo "</table>";
?>
Output

Example 5.16.2 Create a HTML form "result.html" with a text box and a submit button to
accept registration number of the student. Write a "result.php" code to check the status of
the result from the table to display whether the student has "PASS" or "FAIL" status.
Assume that the MYSQL database "my_db" has the table "result_table" with two columns
REG_NO and STATUS.

Solution : Step 1 : Create a database named my_db. Create a table result_table for this
database and insert the values in this table. The table is created as follows -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 63 Server Side Scripting Languages

Sr. No. REG_NO STATUS

1 101 PASS

2 102 FAIL

3 103 PASS

4 104 FAIL

5 105 PASS

Table 5.16.1

Step 2 : Create an HTML form to accept the registration number; the HTML document
is as follows -
result.html
<!DOCTYPE html>
<html>
<head>
<title> STUDENT RESULT </title>
</head>
<body>
<form name="myform" method="post" action="http://localhost/php-
examples/result.php">
<input type="text" name="reg_no"/>
<input type="submit" value="Submit"/>
</form>
</body>
</html>
Step 3 : Create a PHP script to accept the registration number. This php script will
connect to MYSQL database and the status (PASS or FAIL) of the corresponding
registration number will be displayed.

result.php
<?php
// Make a MySQL Connection
$conn=mysql_connect("localhost","root","");
if(!$conn)
{
die('error in connection'.mysql_error());
}
mysql_select_db("my_db",$conn); //select the database
//Execution of Query for displaying the data

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 64 Server Side Scripting Languages

$reg_no = intval($_POST['reg_no']);

$result=mysql_query("SELECT REG_NO,STATUS FROM result_table


where REG_NO=$reg_no ");
while($row = mysql_fetch_array($result))
{
echo $row['REG_NO'] . " is " . $row['STATUS'];
echo "<br />";
}
mysql_close($conn); //closing the database
?>
Step 4 : Load the HTML form created in Step 2 and click the submit button by entering
some registration number.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 65 Server Side Scripting Languages

Example 5.16.3 Write a PHP program to delete a record from result_table.


(Refer example 5.16.2)
Solution :
<?php
// Make a MySQL Connection
$conn=mysql_connect("localhost","root","");
if(!$conn)
{
die('error in connection'.mysql_error());
}
mysql_select_db("my_db",$conn); //select the database
//Execution of Query for displaying the data
$reg_no = intval($_POST['reg_no']);

$result=mysql_query("DELETE FROM result_table where REG_NO=$reg_no");


while($row = mysql_fetch_array($result))
{
echo $row['REG_NO'] . " is " . $row['STATUS']; //Each record will be displayed line by line

echo "<br />";


}

mysql_close($conn); //closing the database


?>

Example 5.16.4 Write a user defined function 'CalculateInterest' using PHP to find the simple
interest to be paid for a loan amount. Read the loan amount, the number of years and rate of
interest from a database table called LOANDETAILS having three fields AMT, YEARS, and
RATE, and calculate the interest using the user defined function.

Solution : Step 1 : Create a database table named LOANDETAILS having three fields
AMT, YEARS and RATE. Insert the values in it. The sample table will be as follows -

AMT YEARS RATE

10000 5 6.9

Table 5.16.2

Step 2 : The PHP code for calculating the simple interest the above values in a function
will be as follows -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 66 Server Side Scripting Languages

Interest.php
<?php
function CalculateInterest()
{
// Make a MySQL Connection
$conn=mysql_connect("localhost","root","");
if(!$conn)
{
die('error in connection'.mysql_error());
}
mysql_select_db("my_db",$conn); //select the database
//Execution of Query for displaying the data
$result=mysql_query("SELECT * FROM LOANDETAILS");
$row = mysql_fetch_array($result);
$amount= $row['AMT'];
$rate= $row['RATE'];
$years= $row['YEARS'];
$interest=($amount * $rate *$years)/100;
mysql_close($conn); //closing the database
return $interest;
}
print "Simple Interest =".CalculateInterest();
?>
Output

Review Question

1. Identify and explain steps involved in connecting to MySQL with PHP.


SPPU : May-18, Marks 6, Dec.-19, Marks 8

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 67 Server Side Scripting Languages

5.17 WAP
 Wireless Application Protocol (WAP) is a set of standards designed to extend
Internet services to mobile phones and Personal Digital Assistants (PDA).
 A WAP browser is a web browser for mobile devices such as mobile phones that
uses the protocol.
 The mobile network gets connected to the Internet through WAP Gateway. The
function of WAP gateway is to convert the WAP request to a WEB request or a
WEB request to a WAP request.
 The mobile phones act as a client when gets connected to the internet. The
demanded web pages can be displayed on the mobile phones if it is WAP enabled.
 The Web pages are normally written in HTML language but the web pages written
in HTML gets loaded very slowly on the mobile phones. Hence the web pages for
mobile phones are written in the language called Wireless Markup Language
(WML)
 The WAP model follows the OSI model and is represented by Fig. 5.17.1.

Fig. 5.17.1 WAP model

Application Layer
o The WAP’s application layer is the Wireless Application Environment (WAE).
o The WAE supports WAP application development using the Wireless Markup
Language (WML).
o The WAE also includes the Wireless Telephony Application Interface (WTA)
which provides the programming interface to telephones. This allows WAP
technology to support for sending messages, initiating calls and other
networking capability.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 68 Server Side Scripting Languages

Session Layer
o The session layer makes use of Wireless Session Protocol (WSP).
o This protocol is similar to HTTP. But HTTP is not efficient for displaying the
web pages on mobile devices, WAP makes uses of WSP.
o The WSP conserves the bandwidth on the wireless links.
o The HTTP works with textual data whereas the WSP work with binary data.
o It supports for both connection-oriented and connectionless sessions.
Transaction, Security and Transport Layer

There are three different protocols used in these layers.


o Wireless Transaction Protocol (WTP) provides transaction level services.
These services are used for both reliable and unreliable transports. If packets
gets dropped then WTP performs the retransmission of packets. Similarly it
avoids transmission of duplicate copies of packets.
o Wireless Transaction Layer Security (WTLS) is just similar to Secured Socket
Layer (SSL). It performs the authentication and encryption functionality.
o Wireless Datagram Protocol (WDP) is similar to User Datagram Protocol
(UDP). WDP offers to the upper layers an invisible interface independent of the
underlying network technology used.
o At the lowest layer of the stack, there are bearer services. WAP supports dial-
up networking using IP and Point to Point Protocol (PPP) as a bearer service. It
also supports for Short Message Service (SMS) and General Packet Radio
Service (GPRS).

5.18 WML
 The topmost layer in the WAP architecture is made up of WAE (Wireless
Application Environment), which consists of WML and WML scripting language.
 WML stands for Wireless Markup Language.
 The role of WML is the same as that of HTML in web applications. WAP sites are
written in WML, while web sites are written in HTML.
 WML is basically the web language for making sites on mobile phones.
 WML is an application of XML, which is defined in a document-type definition.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 69 Server Side Scripting Languages

How to write WML ?


 The WML is a scripting language just similar to HTML. The web script can be
written in Notepad and executed on WAP simulator.
 The extension to the WML file is .wml.
 I have used WinWap for executing the WML scripts. The WinWAP is a web
browser for WAP made by Winwap Technologies available for Microsoft Windows.
Get it downloaded from internet using the site www.winwap.com, if you wish to
use WinWap browser for executing the WML scripts.

5.18.1 Cards and Decks


 In HTML, we can navigate from one page to another. But in case of WML you can
not move from page to page. The WML contains the very basic unit called card.
 WML file contains multiple cards. The multiple cards in a WML file forms a deck.
User can move from one card to another using the same deck.
 We can put text, images, links, form components and so on in the card.

5.18.2 Sample Program


Let us write the first simple WML script. Open the Notepad and type the following
code.

WML Document[FirstScript.wml]
<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">
<wml>
<card id="one" title="Welcome Card">
<p>
Hello, This is first card.
</p>
</card>
<card id="two" title="GoodBye Card">
<p>
Good bye, this is second card.
</p>
</card>
</wml>
Now open the WinWap browser and execute the above code. It will be as follows

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 70 Server Side Scripting Languages

Title of card id=”one”


is displayed here

The text within


<p> …</p> tag will be
displayed on browser
window.

Note that in above code


we have created two
cards.

Script Explanation :
1) The first line of the script says that it is XML document.
2) The second line indicates that document type definition (DTD). These are the
standard lines written in every WML script.
3) Then within <wml> …</wml> tag the entire code is written.
4) The two cards are created with their own ids. The title tag is used to display the
content on the title bard. Within the <p>…</p> i.e. paragraph tag the text which
is to be displayed on the browser window is displayed.

For displaying on title bar


<card id="one" title="Welcome Card"> for first card

<p>
Hello, This is first card. For displaying on
</p> browser window for first
card
</card>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 71 Server Side Scripting Languages

For displaying on title bar


for second card
<card id="two" title="GoodBye Card">

<p>
Good bye, this is second card. For displaying on browser
</p> window for second card
</card>

Instead of having pages, WAP sites have cards. These are what is displayed on the
screen at one time, just like a page. More than one card can be inserted in each WML
document. To declare a card, insert the following :
<card id="some id" title="some text">
Note that : Only one card will be displayed at a time on the web browser.

Closing Tag
Unlike HTML it is important to close every opened tag. Otherwise WML page will not
get executed. The card and wml tags are closed as follows
</card>
</wml>

5.18.3 Comments
Comments are placed inside <!-- --> in WML. This is the same as HTML. For example,
the following lines are comments. WAP browsers ignore all comments.
<!-- This is a comment in WML -->
<!-- This is a multi-line
comment -->

5.18.4 Paragraph
The <p> tag defines the paragraph of text. The paragraph in WML is always displayed
on a new line. The attributes of paragraph are as follows -
Attribute Value Purpose

align Left The text is displayed using left, right or center alignment.
right
center

mode Wrap The paragraph lines can be wrapped or not wrapped.


nowrap

Id Some user defined ID The unique ID of the element is specified.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 72 Server Side Scripting Languages

Example
<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">
<wml>
<card id="one" title="Welcome Card">
<p align="left">
Hello, This is first card.
</p>
</card>
<card id="two" title="description Card">
<p align="center">
And, this is second card.
</p>
</card>
<card id="three" title="GoodBye Card">
<p align="right">
Good bye, this is third card.
</p>
</card>
</wml>

5.18.5 Line Break


The line break in WML is specified using <br/> tag. Note that it is important to close
the tag.

Example

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">
<wml>
<card id="one" title="Welcome Card">
<p>
Hello, This is<br/> first card.
This is <br/> another line with line break
</p>
</card>
</wml>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 73 Server Side Scripting Languages

Output

5.18.6 Table
The table tags are just similar to HTML tags. For example - using <table> … </table>
the table can be created. The <tr> </tr>tag is used for creating rows and <td> </td> is used
for creating columns. The <table> element is placed within <p> </p> tag.
Various attributes used along with the <table> tag are
Attribute Value Purpose

align L C or R The text is displayed using left (L), right (R) or center (C)
alignment. If we specify LCR then that means, first column is
left aligned, Second column is center aligned and third
column is right aligned.

Id Some user defined ID The unique ID of the element is specified.

WML Document[TableDemo.wml]
<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">
<wml>
<card title="Displaying Tables">
<p>
<table columns="3" align="LCR">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 74 Server Side Scripting Languages

<tr>
<td>One</td>
<td>Two</td>
<td>Three</td>
</tr>
<tr>
<td>Four</td>
<td>Five</td>
<td>Six</td>
</tr>
</table>
</p>
</card>
</wml>

5.18.7 Image
 The <img> element is used to include an image in a WAP card. WAP-enabled
wireless devices only supported the Wireless Bitmap (WBMP) image format.
 WBMP images can only contain two colors : black and white.
 The file extension of WBMP is ".wbmp"
 There are free tools available on internet to convert the jpg or GIF images to .wbmp
format. For example Nokia Mobile Internet Toolkit, ImageMagic and so on. Hence
to display image on the browser using wml, we must convert our image file to
.wbmp format first.
 Example

WML Document[ImageDemo.wml]
<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">
<wml>
<card title="Displaying Image">
<p>
Good Morning!!!
<img src="flower.wbmp" alt="flower image"/>
</p>
</card>
</wml>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 75 Server Side Scripting Languages

Various commonly used attributes of <img> tag are -


Attribute Value Purpose

align Top, middle or bottom Image is aligned at the top, middle or bottom.

src Image file path

alt Alternative text The alternative text will be displayed if the image is
not getting loaded on the page.

width % or pixels The number of pixels or % is specified to mention the


width of the image.

height % or pixels The number of pixels or % is specified to mention the


height of the image.
Id Some user defined ID The unique ID of the element is specified.

5.18.8 Hyperlinks
The hyperlink can be used in WML using the anchor tag.
In WML we can use <anchor>, <a> tag to create anchor link.
Various attributes of <a> tag are as given below.

Attribute Value Purpose

href URL or address of the file The specified URL is linked with page and can be opened
up on clicking the link.

title String The text for identifying the link is specified

Id Some user defined ID The unique ID of the element is specified.

Example
WML Document[HyperlinkDemo1.wm]
<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">
<wml>
<card title="Displaying Hyperlink">
<p> This is hyperlink demo
<a href="test.wml">Clik here to navigate to next page</a>
</p>
</card>
</wml>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 76 Server Side Scripting Languages

Output

 Similarly we can use <anchor> tag for using hyperlink in WML document. This tag
is basically used along with <go/>, <refresh> or <prev/> tag.
 Example

WML Document[HyperlinkDemo2.wml]
<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">
<wml>
<card title="Displaying Hyperlink">
<p> This is hyperlink demo
<anchor>
<go href="test.wml"/>
</anchor>
</p>
Using <prev/> tag we
<p>
can go to Back page
<anchor>
<prev/>
</anchor>
</card>
</wml>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 77 Server Side Scripting Languages

5.18.9 Inputs
The <input/> tag allows the user to enter alphanumeric characters such as name, age,
address, phone number, email address and so on.
For example -

WML Document[InputDemo.wml]
<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">
<wml>
<card title="Displaying Input">
<p>
<h2>Student Information Form</h2>
Enter Name: <input name="name" size="20"/><br/><br/>
Enter Address: <input name="address" size="30"/><br/><br/>
Enter Email: <input name="email" size="20"/><br/>
</p>
</card>
</wml>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 78 Server Side Scripting Languages

5.18.10 Select
The <select>...</select> WML elements are used to define a selection list and the
<option>...</option> tags are used to define an item in a selection list.

WML Document[Select.wml]
<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">
<wml>
<card title="Displaying List">
<p> Select the color :
<select>
<option value="red">Red</option>
<option value="blue">Blue</option>
<option value="yellow">Yellow</option>
</select>
</p>
</card>
</wml>
Output

You can select multiple value if the attribute “multiple” is set to true. For example
WML Document[SelectDemo.wml]
<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 79 Server Side Scripting Languages

"http://www.wapforum.org/DTD/wml12.dtd">
<wml>
<card title="Displaying List">
<p> Select the color :
<select multiple="true">
<option value="red">Red</option>
<option value="blue">Blue</option>
<option value="yellow">Yellow</option>
</select>
</p>
</card>
</wml>
Output

5.18.11 Event
 The event is supported in WML using <onevent></onevent> tag. We can specify the
action to be taken whenever an event occurs.
 There are four types of events that are supported in WML -
(1) ontimer : This event occurs when a timer expires.
(2) onenterbackward : This event occurs when a user goes back to a card through
the WAP browser's URL history.
(3) onenterforward : This event occurs when a user goes to a card in the forward
direction. For example, if a user goes to a card by entering its URL directly in the
WAP browser, the onenterforward event will be triggered.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 80 Server Side Scripting Languages

(4) onpick : This event occurs when an item of a selection list is selected or
deselected.
 The syntax of specifying the event tag is as follows -
<onevent type="event_type">
Task to be performed when event occurs
</onevent>
Example using ontimer Event :
Using ontimer event, we can load the specific web page after some desired amount of
time automatically. User need not have to click any hyper link in this case. Following
script loads the test.wml web page after 3 second. The timer value is specified using
value attribute and the time unit is 1/10 seconds.
WML Document[onTimerDemo.wml]
<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.3//EN"
"http://www.wapforum.org/DTD/wml12.dtd">
<wml>
<card id="card1" title="Timer Demo">
<onevent type="ontimer">
<go href="test.wml"/>
</onevent>
<timer value="30"/>
<p>
WML Timer Test
</p>
</card>
</wml>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 81 Server Side Scripting Languages

After 3 seconds

Example using onenterbackward Event :


The onenterbackward event is triggered if a user goes back to a previous card through
the WAP browser's URL history, and the WML code placed in the event handler will be
executed.

WML Document[onenterBackward.wml]
<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.3//EN"
"http://www.wapforum.org/DTD/wml12.dtd">
<wml>
<template>
<onevent type="onenterbackward">
<go href="#card1"/>
</onevent>
</template>
<card id="card2">
<p>
<anchor>
<prev/>
Welcome
</anchor>
</p>
</card>
<card id="card1">
<p>
Hello friends!!! How are you

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 82 Server Side Scripting Languages

</p>
</card>
</wml>
Output

Example using onenterforward


The onenterforward event is triggered when a user goes to a card in the forward
direction. For example, if you go to a card by entering the URL directly or by following an
anchor link of which the action is <go>, the onenterforward event will be triggered and
the WML code associated with the event will be executed.

WML Document[onForwardEvent.wml]
<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">
<wml>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 83 Server Side Scripting Languages

<card id="card1" title="First Card">


<p>
<anchor>
<go href="#card2"/>
Go to card 2
</anchor>
</p>
</card>
<card id="card2" title="Second Card">
<onevent type="onenterforward">
<go href="#card3"/>
</onevent>
<p>
This is card 2
</p>
</card>
<card id="card3" title="Third Card">
<p>
This is card 3
</p>
</card>
</wml>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 84 Server Side Scripting Languages

Note that on clicking the link Go to card2 the control will move directly to card3,
because in card2 the onenterforward event will occur and control will be transferred
directly to card3.

Example using onpick


When an item from the selection list is selected or deselected then this even occurs.

WML Document[onPickEvent.wml]
<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">
<wml>
<card id="MainCard" title="Color Selection">
<p>
Select color :
<select>
<option onpick="#id1">Red</option>
<option onpick="#id2">Blue</option>
</select>
</p>
</card>
<card id="id1">
<p>
You have selected color RED!!!
</p>
</card>
<card id="id2">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 85 Server Side Scripting Languages

<p>
You have selected color Blue!!!
</p>
</card>
</wml>
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 86 Server Side Scripting Languages

Part - II : ASP.NET

5.19 Introduction to ASP.NET


Active Server Pages (ASP) is a server side scripting language. It is a part of Internet
Information Server (IIS). This is basically a product of Microsoft.
The ASP.NET is a server side scripting technology offered by Microsoft. It is a
powerful scripting language for creating dynamic and interactive web pages. The
ASP.NET is next generation ASP but it is entirely new technology. The ASP.NET runs
under IIS server.

5.19.1 How does ASP.NET Works ?


Step 1 : When user demands for the ASP.NET file, the web browser of the client’s PC
sends this request to IIS server.
Step 2 : The IIS server passes this request to .NET Engine.
Step 3 : The .NET engine reads the file line by line and generates the script in a file.
Step 4 : The requested .NET file is returned to the web browser.

Fig. 5.19.1

5.19.2 Features of ASP.NET


 ASP.NET is built on the Common Language Runtime (CLR), allowing programmers
to write ASP.NET code using any supported .NET language.
 ASP.NET pages are called web forms. These web forms have the extensions .aspx.
 These files contain static XHTML markup.
 The static and dynamic content can be inserted in the ASP.NET code.
 The code for appearance can be separated out from the code which is responsible
for responding the events. Microsoft treats the dynamic code using the code behind
the model. In this model the dynamic code is collected and placed in a separate file.
Such a file typically has the names like xyz.aspx.cs. This separates out the contents
from presentation.
 ASP.NET supports various types of controls. It also allows the programmer to build
the custom controls. These controls can be built in a .DLL file and can be loaded
whenever required.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 87 Server Side Scripting Languages

 ASP.NET supports some advanced techniques such as cookies, sessions handling,


query strings.

5.20 Overview of the .NET Framework


 The .NET framework is a software development platform developed by Microsoft.
It is designed for building and running windows applications.
 The first version of .NET framework was released in the year 2002. This version was
known as .NET framework 1.0.
 The .NET framework is used to create both form based and web based applications.
 The .NET framework is also useful in building the web services.
 It supports various programming languages like C#, VB.NET, Visual Basic and
many more. Developers can choose and select the language to develop the required
application.
Architecture of .NET Framework
The .NET framework architecture consists of three major components -
1. CLR
2. Library
3. Language
Let us discuss them in detail.

Fig. 5.20.1 The .NET framework


1. CLR
 The CLR stands for Common Language Runtime. It is a platform on which the .NET
programs are executed. Any .NET programming language can be executed by this
platform.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 88 Server Side Scripting Languages

 Just in Time (JIT) is a part of CLR. It converts the source code into native
intermediate code and then into machine instructions.
 The CLR is also responsible for performing some other tasks such as exception
handling, memory management and garbage collection.
 The important features of CLR are interoperability, security and portability.
2. Framework Class Library (FCL)
 It is a standard library which is actually a collection of various classes, interfaces,
and namespaces that can be used to build the application.
 It is the key component of .NET framework that provides the core functionalities of
.NET.
 Most of the methods of classes are split either into System.* or Microsoft.*
namespaces. A namespace is a logical separation of methods.
3. Language
 The .NET supports many languages. Developer can choose the desired language for
development of required application.
 Following are the categories of various types of applications that can be developed
using .NET
o WinForms : This is useful for developing form based applications.
o ASP.NET : The web based applications can be developed using ASP.NET.
These applications will run on the web browsers such as Google Chrome,
Mozilla FireFox, Internet Explorer and so on. The IIS server is responsible for
executing the ASP.NET application which is a part of Microsoft component.
o ADO.NET : This technology is used to interact with the databases like
Microsoft SQL servers, Oracle and so on. The most commonly used languages
for this category is C# and VB.NET.

5.21 Overview of C#
 The C# is a modern, object oriented programming language developed by
Microsoft.
 C# was developed by Anders Hejlsberg during the development of .NET
framework.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 89 Server Side Scripting Languages

 C# is designed for Common Language Infrastructure (CLI), which consists of the


executable code and runtime environment that allows use of various high-level
languages to be used on different computer platforms and architectures.
 Various features of C# are
1. Object Oriented
2. Standard Library
3. Automatic Garbage Collection
4. Boolean Condition
5. Properties and Events
6. Simple Multithreading
7. Integration with Windows.
Required Environment
For executing the C# programs we need Visual Studio 2019. Install the Microsoft
Visual Studio 2019 edition.

5.21.1 Parts of C# Program


A C# program basically consists of the following parts :
 Namespace declaration
 A class
 Class methods
 Class attributes
 A Main method
 Statements and Expressions
 Comments

5.21.2 Creating First C# Program

In this section we will write and execute the first C# program.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 90 Server Side Scripting Languages

Step 1 : Open Visual Studio. Click on ‘Create a new Project’

Step 2 : Select Console application and then click on Next button.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 91 Server Side Scripting Languages

Step 3 : Give any suitable name to your project. I have given the name as
MyFirstApplication.

Step 4 : The source code window will appear now. This window contains the default
C# code. We can write our first C# code as follows -
using System;

namespace MyFirstApplication
{
class Program
{
static void Main(string[] args)
{
Console.WriteLine("Welcome User!!!!");
}
}
}
Step 5 : Click on

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 92 Server Side Scripting Languages

The console window will appear and display the output of the above program.

Program Explanation :
1. The first line of the program is using System; the word using is a keyword that
is used to include the System namespace in the program. The namespace is a
collection of classes.
2. On the next line the namespace is declared by the name of the program. This
namespace contains the class definition named Program in which the method
Method() is defined.
3. This is the only method defined in the class. This is the entry point for all C#
programs. The Main method states what the class will do when executed.
4. Inside the Main method we have written Console.writeln statement. The
Console is the class and we are invoking the writeln method of this class. By this
statement we can display the desired message on the output screen.
Comment Statement
The comments in C# are similar to C++ comment statements. The // and /* … */ are
used as comments in C#.
Points to Remember
1. C# is case sensitive
2. The execution of the program starts at Main method.
3. Every statement in C# must be terminated by semicolon.
4. The file name can be different from the class name.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 93 Server Side Scripting Languages

5.21.3 Variables
Variables are used for storing values. The syntax for variables is as follows -
Data type variable = value
For example -
int age = 20;

5.21.4 Data Types


The data types are used for specifying the type of the variable.
Following table shows various data types used -

Data Types Memory Size

char 1 byte

signed char 1 byte

unsigned char 1 byte

short 2 byte

signed short 2 byte

unsigned short 2 byte

int 4 byte

signed int 4 byte

unsigned int 4 byte

long 8 byte

signed long 8 byte

unsigned long 8 byte

float 4 byte

double 8 byte

decimal 16 byte

5.21.5 Input and Output


The user input is given by Console.ReadLine() and the output is displayed using
Console.WriteLine() method. For example :
using System;
using System.Collections.Generic;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 94 Server Side Scripting Languages

using System.Linq;
using System.Text;

namespace MyFirstApplication
{
class Program
{
static void Main(string[] args)
{
Console.WriteLine("Enter your name: ");
String name = Console.ReadLine();
Console.WriteLine("You have entered..."+name);
Console.ReadKey();
}
}
}
Output

5.21.6 Operators
The operators are the symbols that are used to perform various operations.
Various operators that are used in Java are enlisted in following table -
Type Operator Meaning Example

Arithmetic + Addition or unary plus c=a+b

– Subtraction or unary minus d= – a

* Multiplication c=a*b

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 95 Server Side Scripting Languages

/ Division c=a/b

% Mod c=a%b

Relational < Less than a<4

> Greater than b>10

<= Less than equal to b<=10

>= Greater than equal to a>=5

== Equal to x==100

!= Not equal to m!=8

Logical && And operator 0&&1

|| Or operator 0 ||1

Assignment = is assigned to a=5

Increment ++ Increment by one ++i or i++

Decrement –– Decrement by one – – k or k– –

Conditional operator

The conditional operator is "?" The syntax of conditional operator is


Condition?expression1:expression2
where expression1 denotes the true condition and expression2 denotes false condition.
For example :
a>b?true:false
This means that if a is greater than b then the expression will return the value true
otherwise it will return false.
Program for Demonstrating Arithmetic Operations
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace MyFirstApplication
{
class Program
{
static void Main(string[] args)
{

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 96 Server Side Scripting Languages

Console.WriteLine("Arithmetic Operations");
int a = 20;
int b = 10;
int c;
Console.WriteLine("a = " + a);
Console.WriteLine("b = " + b);
c = a + b;
Console.WriteLine("Addition of two numbers..."+c);
c = a - b;
Console.WriteLine("Subtraction of two numbers..." + c);
c = a * b;
Console.WriteLine("Multiplication of two numbers..." + c);
c = a / b;
Console.WriteLine("Division of two numbers..." + c);

Console.ReadKey();
}
}
}
Output

Program Demonstrating Relational Operators


using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 97 Server Side Scripting Languages

namespace MyFirstApplication
{
class Program
{
static void Main(string[] args)
{
Console.WriteLine("\n Performing Relational operations ");
int a = 10, b = 20, c = 10;
Console.WriteLine("a= " + a);
Console.WriteLine("b= " + b);
Console.WriteLine("c= " + c);
Console.WriteLine("\n The a<b is " + (a < b));
Console.WriteLine("\n The a>b is " + (a > b));
Console.WriteLine("\n The a==c is " + (a == c));
Console.WriteLine("\n The a<=b is " + (a <= b));
Console.WriteLine("\n The a>=c is " + (a >= c));
Console.WriteLine("\n The a!=b is " + (a != b));
Console.ReadKey();
}
}
}
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 98 Server Side Scripting Languages

Program Demonstrating Logical Operators


using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace MyFirstApplication
{
class Program
{
static void Main(string[] args)
{
Console.WriteLine("\n Performing Logical operations ");
Boolean oper1, oper2;
oper1 = true;
oper2 = false;
Boolean ans1, ans2;
ans1 = oper1 & oper2;
ans2 = oper1 | oper2;
Console.WriteLine("The oper1 is: " + oper1);
Console.WriteLine("The oper2 is: " + oper2);
Console.WriteLine("The oper1&oper2 is: " + ans1);
Console.WriteLine("The oper1|oper2 is: " + ans2);
Console.ReadKey();
}
}
}
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 99 Server Side Scripting Languages

Program Demonstrating Conditional Operator


using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace MyFirstApplication
{
class Program
{
static void Main(string[] args)
{
Console.WriteLine("\n Performing Conditional operations ");
int a, b, c;
a = 10;
b = 20;
Console.WriteLine("a = " + a);
Console.WriteLine("b = " + b);
c = a > b ? a : b;
Console.WriteLine(c + " is greatest");
Console.ReadKey();
}
}
}
Output

5.21.7 Control Structure


Various control structures are -
1. if statement 2. while statement
3. do-while statement 4. switch case statement
5. for loop

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 100 Server Side Scripting Languages

Let us discuss these control structures with the help of simple examples.
1. If statement
 There are two types of if statements - simple if statement and compound if
statement. The simple if statement is a kind of if statement which is followed by
single statement. The compound if statement is a kind of if statement for which a
group of statements are followed. These groups of statements are enclosed within
the curly brackets.
 If statement can also be accompanied by the else part.
 Following table illustrates various forms of if statement.
Type of Syntax Example
statement

simple if if(condition) if(a<b)


statement Console.WriteLine(”a is smaller than b”);

compound if if(condition) if(a<b)


{ {
statement 1; Console.WriteLine(”a is smaller than b”);
… Console.WriteLine(”b is larger than a”);
… }
}
if…else if(condition) if(a<b)
statement; Console.WriteLine(”a is smaller than b”);
else else
statement; Console.WriteLine(”a is larger than b”);
compound if(condition) if(a<b)
if…else { {
statement 1; Console.WriteLine(“a is smaller than b”);
… Console.WriteLine(”b is larger than a”);
… }
} else
else {
{ Console.WriteLine(”a is larger than b”);
statement 1; Console.WriteLine(“b is smaller than a”);
… }

}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 101 Server Side Scripting Languages

if…else if if(condition) if(a<b)


{ Console.WriteLine(”a is smaller than b”);
statement 1; else if(a<c)
… Console.WriteLine(”a is smaller than b”);
… else
} Console.WriteLine(”a is larger than b and c”);
else if(condition)
{
statement 1;


}
else
{
statement 1;


}

2. while statement

The while statement is executing repeatedly until the condition is false. The while
statement can be simple while or compound while. Following table illustrates the forms
of while statements -
Type of statement Syntax Example

simple while while(condition) while(a<10)


statement Console.WriteLine(“a is smaller than 10”);

compound while while(condition) while(a<10)


{ {
statement 1; Console.WriteLine(”a is less than b”);
… a++;
… }
}

3. do..while

 The do…while statement is used for repeated execution. The difference between do
while and while statement is that, in while statement the condition is checked

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 102 Server Side Scripting Languages

before executing any statement whereas in do while statements the statement is


executed first and then the condition is tested. There is at least one execution of
statements in case of do…while. Following table shows the use of do while
statement.
Type of Syntax Example
statement

do…while do do
{ {
statement 1; Console.WriteLine(”a is less than b”);
… a++;
… } while(a<10);
}while(condition);

Note that the while condition is terminated by a semicolon.


4. Switch statement

From multiple cases if only one case is to be executed at a time then switch case
statement is executed. Following table shows the use of switch case statements.

Type of Syntax Example


statement

switch …case switch(condition) Console.WriteLine(”\n Enter choice”);


{ cin>>choice;
case caseno:statements switch(choice)
break; {
…. case 1: Console.WriteLine(”You have selected 1”);
default: statements break;
} case 2: Console.WriteLine(”You have selected 2”);
break;
case 3: Console.WriteLine(”You have selected 3”);
break;
default: Console.WriteLine(”good bye”);
}

5. for loop

The for loop is a not statement it is a loop, using which the repeated execution of
statements occurs. Following table illustrates the use of for loop -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 103 Server Side Scripting Languages

Loop Syntax Example

Simple for loop for(initialization; termination; step count) for(i=0;i<10;i++)


statement c[i]=a[i]+b[i];

Compound for for(initialization; termination; step count) for(i=0;i<10;i++)


loop { {
statement 1; for(j=0;j<10;j++)
statement 2; c[i][j]=a[i][j]+b[i][j];
… }
}

5.21.8 The Break and Continue Statements


The break and continue statements are used to alter the normal control flow of the
program.

Break statement : The break statement is used to terminate the loops such as for, while,
do…while and switch.
Syntax :
break;

Example Program :
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace MyFirstApplication
{
class Program
{
static void Main(string[] args)
{
int i, count = 5;
for (i = 0; i < 10; i++)
{
if (i == count)
{
break;
}
Console.WriteLine("\n i = "+i);
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 104 Server Side Scripting Languages

Console.ReadKey();
}
}
}
Output

Continue statement : Sometime we need to skip certain test condition within a loop. At
that time continue statement is used.
Syntax :
continue;

Example Program
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace MyFirstApplication
{
class Program
{
static void Main(string[] args)
{
int i, count = 5;
for (i = 0; i < 10; i++)

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 105 Server Side Scripting Languages

{
if (i == count)
{
continue;
}
Console.WriteLine("\n i = " + i);
}
Console.ReadKey();
}
}
}
Output

5.21.9 Class and Object


The programming style of C# is just similar to C++. Just similar to C++, you can write
the class in C# and can access the methods of that class using the object of the class.
Following example illustrates this concept.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace ConsoleApplication2
{
class Circle

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 106 Server Side Scripting Languages

{
double radius;
double pi=3.14;
double a;
public void getdata()
{
radius = 10;
}
public void area()
{
a = pi * radius * radius;
Console.WriteLine("Radius: {0}", radius);
Console.WriteLine("Area: {0}", a);
}
}
class Program
{ Note that while displaying the variables they
static void Main(string[] args) are displayed using the index{0},{1} and so
{ on.
Circle obj = new Circle(); These two statements can be combined into
obj.getdata(); one statement as follows -
obj.area(); Console.WriteLine("Radius: {0},Area: {1}",
Console.ReadKey();
radius, a);
}
}
}
Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 107 Server Side Scripting Languages

5.22 Introduction to ASP.NET


 ASP.NET is a platform for developing web applications. It works on HTTP protocol
and makes use of HTTP commands.
 The ASP.NET application programs can be written in one of the following
languages -
1. C# 2. Visual Basic .NET
3. Jscript 4. J#
 ASP.NET consists of large number of controls such as textboxes, buttons, labels and
checkboxes and so on for developing the web pages. Basically the HTML tags are
used to manipulate the code.

5.22.1 ASP.NET Component Model


 The ASP.NET component model provides various building blocks of the ASP.NET
pages. It describes the -
1. Server side pages that uses the HTML tags
2. Server controls that are used for building complex web applications.
 In ASP.NET programming the .aspx page uses the HTML tags. During execution,
the .aspx page is transformed into an instance of a class which inherits from the
base class Page of the .Net framework.
 In this technology each ASP.Net page is an object and all its components i.e., the
server-side controls are also objects.

5.22.2 Life Cycle of ASP.NET Application


The life cycle of ASP.NET application is divided into two categories -

Application life cycle

There are mainly two phases in the application life cycle -


1. Request phase

a) User makes a request for accessing particular resource.


b) Browser sends this request to the web server.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 108 Server Side Scripting Languages

c) An object of ApplicationManager class is created.


d) An object of the HostingEnvironment class is created to provide information
regarding the resources.
e) Required items in the application are compiled.
2. Response Phase

a) Response objects are created.


b) There are some application objects of the class HttpContext, HttpRequest and
HttpResponse. These objects are initialized.
c) The request is processed by the HttpApplication class. Hence an instance of the
HttpApplication object is created and assigned to the request.
d) Different events are raised by this HttpApplication class for processing the
request.
3. Page life cycle

Various stages of page life cycle are -


1. Page request : The page request occurs before the page life cycle begins. When
the page is requested by a user, ASP.NET determines whether the page needs to
be parsed and compiled or whether a cached version of the page can be sent in
response without running the page.
2. Start : In stage the page properties such as Request and Response are set. At this
stage, the page determines whether the request is postback or it is a new request.
It then sets the IsPostBack property. At this stage the UICulture property is also
set.
3. Initialization : In this stage controls on the page are available. Each control’s
UniqueID property is set. A master page and themes are set. For a new request
postback data is loaded and the control properties are restored to the view-state
values.
4. Load : At this stage, the control properties are loaded with information obtained
from view state and control state.
5. Postback event handling : If the request is a postback, then control event
handlers are called. Then to validate the controls the Validate method is called.
6. Rendering : At this stage, the page calls the Render method for each control. The
output of rendering is written to the OutputStream class of the Page's Response
property.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 109 Server Side Scripting Languages

7. Unloading : The Unload event is raised after the page is fully rendered. At this
point, page properties such as Response and Request are unloaded and cleanup
is performed.
Page life cycle events

Within each stage of the life cycle of a page, the page raises events. The following table
lists the page life-cycle events that are used most commonly.

Page event Purpose

PreInit This event is raised after start stage is complete and before initialization
stage. It Checks the IsPostBack property to determine whether this is the
first time the page is being processed. It sets the Master page and theme
property dynamically.

Init This event is raised after all controls have been initialized.

InitComplete It is raised at the end of the page's initialization stage

PreLoad It is raised after the page loads view state.

Load The Page object calls the OnLoad method. This events is raised for the
page loading and then recursively for all the child controls.

LoadComplete It is raised at the end of the event-handling stage. This event can be
handled by overloading the OnLoadComplete method

PreRender When all the controls for the page are created then this event is raised.
The Page object raises the PreRender event on the Page object, and then
recursively does the same for each child control.

PreRenderComplete After completion of preRendering stage this event is raised.

Render This is not an event; instead, at this stage of processing, the Page object
calls this method on each control that writes out the control's markup to
send to the browser

Unload Raised for each control and then for the page. During the unload stage,
the page and its controls have been rendered so further changes to
response stream can not be done.

Control Events These events are used to handle specific control events. For instance
Button control has click event.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 110 Server Side Scripting Languages

5.23 ASP.NET Web Form Model


 The ASP.NET web forms make use of events-driven techniques for the interaction
of the web application. The browser actually submits the web form to the web
server and then server returns the HTML page in response.
 The client side activities are forwarded to the server and the server sends the
response to its client. The HTTP protocol plays an important role in this
communication.
 The HTTP is a stateless protocol. So ASP.Net helps in storing the information
regarding the state of the application. It consists of :
1. Page state
2. Session state
The page state is the state of the client. That means at this state, the client has the web
application page having various input fields on the web form. On the other hand the
session state is the state in which the information is collected from various pages the user
visited or worked with. ASP.Net session state and server side infrastructure keeps track
of the information collected globally over a session.

5.24 ASP.NET Controls


Various controls that can be used by the web forms are -
1. Button controls
2. Text boxes and labels
3. Check boxes and Radio buttons
4. List controls
5. List items
and so on.
We will discuss some most commonly used controls for designing the web forms.

5.24.1 How to Create Web Form Application ?


Following are the steps to be taken to create and build the web forms
Step 1 : Start an instance of Visual Studio 2019 and create a new Web Application
Project by clicking Create a New Project. Locate ASP.NET Web Application (.NET
Framework)

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 111 Server Side Scripting Languages

Click on Next button. Give the suitable project name. I have given project name as
UserControlsDemo.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 112 Server Side Scripting Languages

Click on Create button. Then Select Empty project.


Step 2 : Now in the Solution Explorer window, right click on the project name

Select the Web Form, and then click Add button.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 113 Server Side Scripting Languages

Step 3 : The default code for WebForm1.aspx will be displayed in the Source code
window. We can add the user controls using Toolbox.

If we double click on some control, then the code for the user control will appear in the
source code window. For instance if we want to insert a text box then,
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs"
Inherits="UserControlsDemo.WebForm1" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 114 Server Side Scripting Languages

<div>
<b> User Name:</b>
<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
</div>
</form>
</body>
</html>
Step 4 : The above web from can be executed on IIS Express server. Click on the IIS
Express option present below the menu bar.

The output of the web service will be displayed on the web browser as follows -

Step 5 : The default code for WebForm1.aspx is displayed in the Code window. Just
below that the Design, Split and Source options are located. Click on Design. The
form window will get opened up. Now we can select the controls from the ToolBox
under the Standard option. Click and drag the desired controls on the form. The most
commonly used controls are Button, TextBoxes, Labels, Checkboxes, ListBoxes and so
on.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 115 Server Side Scripting Languages

Step 6 : Set the properties of the controls using the Properties Window. If you can
not locate this window just press F4. You can set the properties like ID, Text,
ForeColor, Font and so on.
Step 7 : A sample form is designed as follows by simply dragging the controls.

Automatically the code will get generated. This code can be viewed by clicking the
Source.
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs"
Inherits="WebApplication3.WebForm1" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"


"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<div>

<asp:Label ID="Label1" runat="server" Text="Name:"></asp:Label>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 116 Server Side Scripting Languages

<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>

</div>
<p>
<asp:Label ID="Label2" runat="server" Text="Address:"></asp:Label>
<asp:TextBox ID="TextBox2" runat="server"></asp:TextBox>
</p>
<p>
<asp:Label ID="Label3" runat="server" Text="Phone:"></asp:Label>
<asp:TextBox ID="TextBox3" runat="server"></asp:TextBox>
</p>
<asp:Button ID="Button1" runat="server" Text="Click Me" />
</form>
</body>
</html>

Step 8 : The output will be displayed on the web browser.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 117 Server Side Scripting Languages

Examples on Web Form

Example 5.24.1 Write ASP.NET code to demonstrate the button control.


Solution :

<%@ Page Language="C#" %>


<script runat="server">
void Button1_Click(object sender, EventArgs e)
{
Label1.Text = "You have clicked the Button";
}
</script>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:Label ID="Label1" runat="server"></asp:Label>
</div>
<div>
<asp:Button ID="Button1" runat="server" Type="submit" onclick="Button1_Click"
Text="Click" />
</div>
</form>
</body>
</html>

In above code, on the Button click the function Button_Click is called. In this function
we are just assigning the Button clicked message as a Label control’s text.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 118 Server Side Scripting Languages

The output will be

just click on the Click button and you will get

Example 5.24.2 Write ASP.NET code to demonstrate the TextBox control.


Solution :
<%@ Page Language="C#" %>
<script runat="server">
void Button1_Click(object sender, EventArgs e)
{
Label1.Text ="Welcome "+ TextBox1.Text+ "!!!";
}
</script>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 119 Server Side Scripting Languages

</head>
<body>
<form id="form1" runat="server">
<div>
<asp:Label ID="Label1" runat="server" Text="Enter Some Text in the TextBox
"></asp:Label>
</div>
<div>
<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
</div>
<div>
<asp:Button ID="Button1" runat="server" onclick="Button1_Click" Text="Click" />
</div>
</form>
</body>
</html>
Output

Just type some name in TextBox. And then click the button.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 120 Server Side Scripting Languages

Example 5.24.3 Write ASP.NET code to demonstrate the CheckBox and ListBox control.
Solution :
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="ChkBoxFrm.aspx.cs"
Inherits="CheckBoxDemo.ChkBoxFrm" %>

<script runat="server">
void CheckBox1_CheckedChanged(object sender, EventArgs e)
{
if (CheckBox1 .Checked==true)
{
ListBox1.Items.Add(CheckBox1.Text);
}
else
{
ListBox1.Items.Remove(ListBox1.Items.FindByText(CheckBox1.Text));
}
}
void CheckBox2_CheckedChanged(object sender, EventArgs e)
{
if (CheckBox2.Checked == true)
{
ListBox1.Items.Add(CheckBox2.Text);
}
else
{
ListBox1.Items.Remove(ListBox1.Items.FindByText(CheckBox2.Text));
}
}
void CheckBox3_CheckedChanged(object sender, EventArgs e)
{
if (CheckBox3.Checked == true)
{
ListBox1.Items.Add(CheckBox3.Text);
}
else
{
ListBox1.Items.Remove(ListBox1.Items.FindByText(CheckBox3.Text));
}
}
</script>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 121 Server Side Scripting Languages

<body>
<form id="form1" runat="server">
<div>
<asp:CheckBox ID="CheckBox1" runat="server" AutoPostBack="True"
oncheckedchanged="CheckBox1_CheckedChanged" Text="C++" />

</div>
<div>
<asp:CheckBox ID="CheckBox2" runat="server" AutoPostBack="True"
oncheckedchanged="CheckBox2_CheckedChanged" Text="Java" />
</div>
<div>
<asp:CheckBox ID="CheckBox3" runat="server" AutoPostBack="True"
oncheckedchanged="CheckBox3_CheckedChanged" Text="C#" />
</div>
<div>
<asp:ListBox ID="ListBox1" runat="server" Height="140px" Width="120px">
</asp:ListBox>
</div>
</form>
</body>
</html>

Output
Just check or uncheck the checkboxes to experience the effect of this control.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 122 Server Side Scripting Languages

5.25 Web Services


 Web service is a software program using which the information can be exchanged.
That means using web service one application can invoke the method another
application. These applications can be on the same computer or different
computers.
 The web services make use of the standard protocols such as HTTP, XML and
SOAP. As these are open and standard protocols the applications can exchange the
information on any platform with the help of web services. For instance - Web
service built using .NET application can be consumed using JSON or Java
application.
Features
1) Web service is a language independent.
2) It is platform independent.
3) It is based on XML.
4) It is discoverable. That means, applications and developers can search for and
locate the desired web services through registries.
5) It is based on a stateless service architecture.

Basic terminologies used in web services

1) HTTP : The HTTP is a standard protocol which is widely used by the web
services to send and receive messages.
2) SOAP : The SOAP (Simple Object Access Protocol) provides the mechanism
between web services and applications. SOAP messages are in XML
format.
3) XML : XML is a scripting languages intended for describing the data.
4) WSDL : It stands for Web Services Description Language. It is basically XML
notation for describing the interface provided by web service
provider.
5) Extension .asmx : In .NET the web services have the extension ASMX.

5.25.1 Writing Web Service


 In this section we will write the web service method in the web application
program. For writing the web services, ASP.NET Web application (.NET
Framework) is used.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 123 Server Side Scripting Languages

Step 1 : Open Visual Studio. Click on Create a New Project. Select ASP.NET Web
Application (.NET Framework). Give the name of the application. I have given the name
as CalculatorWebService. Then select Empty project template.

Step 2 : In the Solution Explorer window locate the name of the project. Right click on
project name.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 124 Server Side Scripting Languages

Locate Web service option. Following screenshot illustrates it.

Step 3 : The source code window appears. Initially the default source code will be
present in the source code window. Inside the webservice class, there exists a default
[WebMethod]. Replace default WebMethod by any desired method for which you want
to develop a web service. I want to write a web service for displaying maximum number
out of two numbers. I have written a method with the name ShowMaxValue. To this
method two integer parameters are passed as arguments.
 The code for this web service is as follows -
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Services;
namespace CalculatorWebService
{
/// <summary>
/// Summary description for WebService1
/// </summary>
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[System.ComponentModel.ToolboxItem(false)]

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 125 Server Side Scripting Languages

// To allow this Web Service to be called from script, using ASP.NET AJAX, uncomment the
following line.
// [System.Web.Script.Services.ScriptService]
public class WebService1 : System.Web.Services.WebService
{
[WebMethod]
public int ShowMaxValue(int a,int b)
{
if (a > b)
return a;
else
return b;
}
}
}
Program Explanation :

The web service application is written in some namespace. In above program we


have saved the web service by the name of the namespace as
CalculatorWebService.
1) Web service is a class which is declared with [WebService] attribute. It is
inherited from System.Web.Services.WebService base class. The attribute
[WebService] tells that this class contains the code for web services.
WebService namespace is used to uniquely identify our web service among all
other web services present on the internet. It is generally written as follows -
[WebService(Namespace = "http://pragimtech.com/webservices")]
In above program, we have created a web service using the method
ShowMaxValue. Before declaring this method we use the attribute
[WebMethod]. If you want a method name to be displayed on the web browser
as a part of the web service, then it must be declared as public and it must be
decorated with [WebMethod] attribute.
We have passed two arguments to ShowMaxValue method. This method finds
the largest among the two numbers and return this largest number.
Step 4 : Here the web service is created. The above web service can be executed on IIS
Express server. Click on the IIS Express option present below the menu bar.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 126 Server Side Scripting Languages

The output of the web service will be displayed on the web browser as follows -

Step 5 : From above window, just click on Service Description link. In the address bar we
get the URL as https://localhost:44388/WebService1.asmx?WSDL. Just copy this link and
save it to notepad.
If we click on ShowMaxValue we get following screen.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 127 Server Side Scripting Languages

The two different values can be entered in the text boxes. On hitting the Invoke
button, we get the result in the XML document. It is as follows. Note that the above layout
is a default layout provided by .NET framework.

5.25.2 Writing Web service Client

 The above created web service can be invoked using the proxy web client. In this
section we will create web service client by creating a HTML form. On the button
click event of the form, the above created web service method ShowMaxValue will
be invoked. The return value of this method is displayed as a result on the web
browser.
Step 1 : In above section we have created a web service for displaying the maximum out
of two numbers. Just right click on the name of the above web project which is displayed
in the solution explorer window. Select Add New Project->ASP.NET Empty Web Site.
Give suitable name to your web service client. I have given the name myWebClient.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 128 Server Side Scripting Languages

In the step 5 of section **, we have copied a link as


https://localhost:44388/WebService1.asmx?WSDL for WSDL in notepad. Just paste this
link as a service reference and then click on Go button.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 129 Server Side Scripting Languages

Click OK button. Thus the web service reference by the namespace ServiceReference1
is created for the web service client.
Step 2 : In the solution explorer window, right click on myWebClient and add a form.
Write following HTML code for creating two text boxes for inputting two numbers,
one label for displaying the result and one button to invoke the web service for showing
the maximum out of two numbers.
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs"
Inherits="_Default" %>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<table>
<tr><td><b>Enter first Number:</b></td>
<td> <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox></td>
</tr>
<tr><td><b>Enter second Number:</b></td>
<td> <asp:TextBox ID="TextBox2" runat="server"></asp:TextBox></td>
</tr>
<tr><td><b>Maximum Number is:</b></td>
<td><asp:Label ID="LblResult" runat="server" Text=""></asp:Label> </td>
</tr>
<tr><td>
<asp:Button ID="btnResult" runat="server" Text="Click Me" OnClick="btn_Click"/>
</tr>
<tr><td colspan="2">
<td>&nbsp;</td>
</tr>

</table>
</form>
</body>
</html>

Script Explanation : In above given HTML document we have created two text boxes
for inputting two numbers. One label control for displaying the maximum of the two
numbers. On button click, the web service method ShowMaxValue is called.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 130 Server Side Scripting Languages

Step 3 : Click on Design tab, the form design will be as follows –

 Double click on ‘Click Me’ button. Write the code for button click event as follows –

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
public partial class _Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
}
protected void btn_Click(object sender, EventArgs e)
{

ServiceReference1.WebService1SoapClient client = Web Service method named


new ServiceReference1.WebService1SoapClient(); (ShowMaxValue) written in
previous section is invoked.
int result = client.ShowMaxValue(
Convert.ToInt32(TextBox1.Text), Convert.ToInt32(TextBox2.Text));

LblResult.Text = result.ToString();

}
The Convert.ToInt32 method is
}
used to convert the textbox string
to numeric value.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 131 Server Side Scripting Languages

Step 4 : Right click on web client project and click on ‘view in Browser’. The output will
be as follows -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 132 Server Side Scripting Languages

Example 5.25.1 Write a web service and web client for implementing addition of two numbers
using .NET.

Solution : Step 1 : Web service application


using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Services;
namespace CalculatorWebService
{
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[System.ComponentModel.ToolboxItem(false)]

public class WebService1 : System.Web.Services.WebService


{
[WebMethod]
public int Add(int a,int b)
{
return a+b;
}
}
}

Step 2 : The web service client.


HTML Document for creating GUI
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs"
Inherits="_Default" %>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<table>
<tr><td><b>Enter first Number:</b></td>
<td> <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox></td>
</tr>
<tr><td><b>Enter second Number:</b></td>
<td> <asp:TextBox ID="TextBox2" runat="server"></asp:TextBox></td>
</tr>
<tr><td><b>Addition is:</b></td>
<td><asp:Label ID="LblResult" runat="server" Text=""></asp:Label> </td>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 133 Server Side Scripting Languages

</tr>
<tr><td>
<asp:Button ID="btnResult" runat="server" Text="Click Me" OnClick="btn_Click"/>
</tr>

</table>
</form>
</body>
</html>

C# Program for handling button click event


using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

public partial class _Default : System.Web.UI.Page


{
protected void btn_Click(object sender, EventArgs e)
{
ServiceReference1.WebService1SoapClient client =
new ServiceReference1.WebService1SoapClient();
int result = client.Add(
Convert.ToInt32(TextBox1.Text), Convert.ToInt32(TextBox2.Text));
LblResult.Text = result.ToString();
}
}

Part - III : Node.js

5.26 Overview of Node JS SPPU : May-18, Marks 4

 NodeJS is an open source technology for server.


 Using Node.js we can run JavaScript on server.
 It runs on various platform such as Windows, Linux, Unix, and MacOS.
Uses of Node.js
 It can perform various tasks such as -
1. It can create, open, read, delete, write and close files on the server.
2. It can collect form data.
3. It can also add, delete, modify data in databases.
4. It generate dynamic web pages.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 134 Server Side Scripting Languages

How to write and execute Node.js document ?

 For executing the Node.js scripts we need to install it. We can get it downloaded
from https://nodejs.org/en.
 The installation can be done on Linux or Windows OS. It has very simple
installation procedure.
 After successful installation we can now execute the Node.js document.
 The Node.js file has extension .js.
Step 1 : Open Notepad and type the following code. Save the file with some filename
having extension .js

Test.js
var http = require('http');
http.createServer(function (req, res) {
res.writeHead(200, {'Content-Type': 'text/html'});
res.end("Welcome to the Learn NodeJS!");
}).listen(8082);
console.log('Server is running at http://localhost:8082/');

Step 2 : Open command prompt window and type the command for executing above
script. The screen-shot for this execution is as follows -

Now open the web browser such as Mozilla Firefox or Chrome or Internet Explorer
and in the address bar type the URL http://localhost:8082/

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 135 Server Side Scripting Languages

The output will be as follows –

Components of Node.js Application


 Module is similar to JavaScript libraries. It is basically the set of functions that need
to be included in the application. For including the module we need a function
require(). For example to include the HTTP module in the application we write -
var http = require('http');
 Node.js has a built-in module called HTTP, which allows Node.js to transfer data
over the Hyper Text Transfer Protocol.
 The HTTP module can create an HTTP server that listens to server ports and gives a
response back to the client. Use the createServer() method to create an HTTP server.
For example -
http.createServer(function (req, res) {
res.writeHead(200, {'Content-Type': 'text/html'});
res.end("Welcome to the Learn NodeJS!");
}).listen(8082);
 If the response from the HTTP server is supposed to be displayed as HTML, you
should include an HTTP header with the correct content type. For example
res.writeHead(200, {'Content-Type': 'text/html'});
The status code, 200 means that all is OK, the second argument is an object containing
the response headers.
 The above code can be executed and the web page can be displayed on the Web
browser on particular port using .listen(port number)

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 136 Server Side Scripting Languages

5.26.1 Features of Node JS


 Following are some remarkable features of node.js –
1) Non blocking thread execution : Non blocking means while we are waiting for a
response for something during our execution of tasks, we can continue executing
the next tasks in the stack.
2) Efficient : The node.js is built on V8 JavaScript engine and it is very fast in code
execution.
3) Open source packages : The Node community is enormous and the number of
permissive open source projects available to help in developing your application
in much faster manner.
4) No buffering : The Node.js applications never buffer the data.
5) Single threaded and highly scalable : Node.js uses a single thread model with
event looping. Similarly the non-blocking response of Node.js makes it highly
scalable to sever large number of requests.

Review Question

1. Write short note on NodeJS. SPPU : May-18, Marks 4

5.27 Multiple Choice Questions


Q.1 In PHP, a variable starts with the sign _______.
a $ b &
c # d @

Q.2 PHP supports the following data types :


a String b Integer
c Array d All the above

Q.3 In PHP, to represent exponentiation, the following operator is used :


a * b **
c ^ d $

Q.4 A cookie is created by using the following function :


a getcookie b setcookie
c getcookie() d setcookie()

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 137 Server Side Scripting Languages

Q.5 The following mode opens the file for write only :
a w b r
c w+ d a+

Q.6 How do you get information from a form that is submitted using the “get” method ?
a $_GET[]; b Request.Form;
c Request.QueryString; d Request.GetQuery;

Q.7 Which superglobal variable holds information about header, paths and script, locations ?
a $_GLOBALS b $-SERVER
c $-SESSION d $_GET

Q.8 The filesize() function returns the file size in _______.


a bits b bytes
c kilobytes d gigabyte

Q.9 Which function sets the file filename’s last-modified and last-accessed times ?
a sets() b Set()
c touch() d touched()

Q.10 The file extension to ASP.NET web form is _______.


a .net b .aspx
c .docx d .html

Q.11 ASP.NET was developed by ______.


a Google b IBM
c Oracle d Microsoft

Q.12 The JIT is a part of _______ in .NET framework.


a Framework Class Library (FCL)
b Languages
c Common Language Runtime (CLR)
d All of the above

Q.13 In ASP.NET application, the DLL files are stored in _______ folder.
a bin b App_data
c App_code d App_LocalResources

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 5 - 138 Server Side Scripting Languages

Q.14 Which of the following is the first event of ASP.NET page when the user requests a web
page ?
a Init b PreInit
c Render d Control Events

Q.15 Which of the following is the page life cycle event of ASP.NET page when the user makes
use of button control to invoke click events a web page ?
a Init b PreInit
c Render d Control Events

Q.16 Web services can be discovered using _______.


a UDDII b UDDI
c UDDDI d UDII

Q.17 Which of the following is a directory service where enterprises register and search for
web services ?
a WSDL b UDDI
c Supporting protocols of SOAP d None of the above

Q.18 Node.js is written in _______.


a C b C++
c JavaScript d All of the above

Q.19 The extension used to store the Node.js script is _______.


a .html b .java
c .js d .node

Answer Keys for Multiple Choice Questions :

Q.1 a Q.2 d Q.3 b Q.4 b Q.5 a

Q.6 a Q.7 a Q.8 b Q.9 c Q.10 b

Q.11 d Q.12 c Q.13 a Q.14 b Q.15 d

Q.16 b Q.17 b Q.18 d Q.19 c



TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


UNIT - VI

6 Ruby and Rails

Syllabus
Introduction to Ruby : Origins & uses of Ruby, scalar types and their operations, simple input and
output, control statements, fundamentals of arrays, hashes, methods, classes, code blocks and
iterators, pattern matching. Introduction to Rails : Overview of Rails, Document Requests,
Processing Forms, Rails Applications and Databases, Layouts, Rails with Ajax. Introduction to EJB.

Contents
6.1 Origins & Uses of Ruby
6.2 Scalar Types and their Operations
6.3 Simple Input and Output
6.4 Control Statements
6.5 Fundamentals of Arrays
6.6 Hashes
6.7 Methods
6.8 Classes
6.9 Code Blocks and Iterators
6.10 Pattern Matching
6.11 Overview of Rails
6.12 Document Requests
6.13 Processing Forms
6.14 Rails Applications and Databases
6.15 Layouts
6.16 Rails with Ajax
6.17 Introduction to EJB ............................................... May-18, 19, Dec.-19, ............ Marks 8
6.18 Multiple Choice Questions

(6 - 1)
Web Technology 6-2 Ruby and Rails

Part I : Introduction to Ruby

6.1 Origins & Uses of Ruby


 Ruby is a scripting language designed by Yukihiro Matsumoto also known as Matz.
 Ruby executes on variety of platforms such as Windows, Linux, Mac and so on.
 Ruby is a pure object oriented programming language. Ruby is an open source and
it is freely available on the web.
 Ruby is similar to smalltalk, python, Perl.
 Ruby has the pattern matching feature which is similar to the Perl.
 Ruby can be easily connected to the databases like MYSQL, DB2 and Oracle.
Environment
 For executing the Ruby programs we need to install Rubystack.
 The Ruby Stack can be downloaded and installed from
http://bitnami.com/stack/ruby.
 It can be downloaded on Windows/ Linux or MacOS platform. It consists of Ruby,
Rails, Apache, MySQL, SQLite, Git, PHP and phpMyAdmin in one pack. Installing
Ruby Stack is quick and easy. It is a self - contained system.
 After installing the Ruby Stack we can start the Apache Server and MYSQL Server
using the Managers.

6.2 Scalar Types and their Operations


 There are three types of data types used in Ruby and those are Scalar, Arrays and
hashes.
 The scalar types are further classified as numeric and character strings. Refer
Fig. 6.2.1.

Fig. 6.2.1 Scalar types

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6-3 Ruby and Rails

6.2.1 Numeric and String Literals


 All the numeric data types in Ruby are derived from the Numeric class.
 The immediate children of Numeric class are Float and Integer.
 The Integer class has two child classes - Fixnum and Bignum.
 The integer objects which lies within the size of 32 bit is called the Fixnum object
and the object which is greater in size of 32 bit is called the Bignum object.
 If a Fixnum object whose size grows beyond the 32 bit then it is implicitly typecast
to Bignum object.
 Similarly in expression evaluation the size of particular Bignum object becomes less
than 32 bit then it is converted to the Fixnum object.
 The integer literal may contain the underscore character to read out the large
integer conveniently. For example 231456981 can be read using the underscore as
231_456_981.
 The numeric literal that contains the floating point is called the Float object. It
denotes the double precision floating type value.
 The decimal point must be preceded and followed by at least one digit. For example
.22 will be illegal literal in Ruby.
 The string object consists of the string literals that are nothing but the collection of
characters.
 There are two types of strings - single quoted and double quoted string.
 If we want to print some character literally like apostrophe s then the \ is used.
Following is a simple script written in Ruby to demonstrate the use of string literal
Step 1 : Open the Notepad or some suitable text editor and type the following code -
Ruby Document [StringDemo1.rb]
puts 'Cheers!'
puts 'It\'s a beautiful day'
puts "An apple a day \n keeps the doctor away"
Step 2 : Open the command editor for ruby and you can see the following output -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6-4 Ruby and Rails

6.2.2 Variable and Assignment Statements


 The variable used for storing the data values.
 The variables in Ruby are case sensitive.
 It may contain the letters, underscore and digits. Conventionally the variable must
be declared in the lower case.
Ruby Script [VariableDemo.rb]
pi =3.14
r=15
puts "The value of pi variable is #{pi}"
puts "The radius of the circle is #{r}";
puts "The area of the circle is #{pi*r*r}"

Output
The value of pi variable is 3.14
The radius of the circle is 15
The area of the circle is 706.5
 There is no need to declare the variable in Ruby.
 In Ruby every data value is an object. Hence objects need references.
 If a scalar variable is not assigned with a value then it is assigned with the value nil.
 The constants in Ruby are declared with the first letter capital. A constant is created
when a variable is assigned with some value it becomes a constant variable.
 There are special variables in variables which are called as implicit variables. The
scalar variables that are implicit variables begin with dollar sign while other type of
implicit variables can begin either by underscore _, carrot ^ or back slash \
 The variables in Ruby are typeless. All that is assigned in an assignment statement
is address of an object.

6.2.3 Numeric Operators


 The arithmetic operators such as + addition, - subtraction, * multiplication /
division and mod operators.
 The precedence rules specify which operator is to be evaluated first when to
operators of different level of precedence appear in the expression.
 The associativity rule specify which operator is to be evaluated first when two
operators of same level of precedence appear in the expression.
 The Ruby does not include increment ++ or decrement -- operator.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6-5 Ruby and Rails

 There is a math module supported by Ruby. This module provides the methods for
basic trigonometric and mathematical functions. For instance the functions such as
cos, sin, tan, sqrt are supported by this module.
 Along with the software package of Ruby an interactive interpreter is provided.
This interpreter is called Interactive Ruby. The acronym for this interpreter is irb.
The user can type the expression and get the answer of this expression immediately.
 For that purpose, click on Start->All Programs->Ruby 1.9.2->Interactive Ruby.
Following is the illustration -

6.2.4 String Methods


 Ruby supports various string methods.
 String method supports concatenation operator. The operator is denoted by +. The
operator + is used for concatenation.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6-6 Ruby and Rails

 The operator << is used to append the string. For example :

 Every variable in Ruby refers to some memory location. If one variable is assigned
to another variable then that variable will refer to the same memory location. For
example :

For example : In above screen-shot you can see that the variable str1 contains the string
“MyRuby”. Another variable str2 is assigned with the value of str1. Hence on typing the
string str2 we get the same string i.e.”MyRuby”. Now the string str1 is assigned with
another string “Program”. Hence we get str1=”Program” but still the value of
str2=”MyRuby”.
 Instead of directly assigning some string to str1, we can use the replace method for
assigning some new string.
For example: Instread of
str1=”Program”
we can write
str1.replace(“Program”);

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6-7 Ruby and Rails

 Following are some methods that are used for various string operations -
Method/Operator Action Example

Capitalize This method converts the first letter to "india".capitalize => "India"
uppercase But
"11a".capitalize => "11a"
chop This method removes the last character. "Lucky".chop => "Luck"

chomp This method the newline from the right "Hello\n Friends\n".chomp
end, if there is one. => "Hello\n Friends"
equal The method equal is used to compare "Nisha".equal?("Nisha") => false
== two objects. because these are treated as two
The == equal to operator treats the string different objects
literally. "Nisha"=="Nisha" => true
because the string is compared
literally
upcase This method converts all the lower case "nisha".upcase => "NISHA"
letters to the object case.
downcase This method converts the upper case " NISHA ".upcase => "nisha”
letters of the string to lower case.
strip This method removes the space on both " India ".strip => "India"
ends.
lstrip This method removes the space from the " India ".lstrip => "India "
left end
rstrip This method removes the space from the " India ".strip => " India"
right end

swapcase This method converts the upper case to "NiSha".swapcase => "nIsHA"
lower case and lower case to upper case.
reverse It reverses the string. "Ruby".reverse => "ybuR"

* The repetition operator is used to specify "Hurray!!! "*3


the repetition. The repetition is specified =>"Hurray!!! Hurray!!!
by asterisk(*) Hurray!!! "
<=> This is called the spaceship operator. "aaa"<=>"bbb" => -1
If two operands are equal then it returns "bbb"<=>"aaa" => 1
the 0; "aaa"<=>"aaa" => 0
If first operand is greater than the second
operand then it returns 1;
If the second operand is greater than the
first one then it returns -1

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6-8 Ruby and Rails

6.3 Simple Input and Output


 The input and output operations are the most important operations for any
programming language.
 Typically the input is given by the keyboard and the output is displayed on the
screen.

6.3.1 Screen Output


 The puts method is used to display the output on the screen.
 The operand for the puts method is string.
 The value is the variable can be displayed using the puts method but in that case
#{…} is used. For example :
RollNo=10
Puts “My Roll number is #{RollNo}”
 The new line character can be appended at the end of the string so that next
subsequent contents can be displayed on the screen. But it writes the word nill at
the end. For example :
puts "My favorite langauge is #{str}"
My favorite langauge is Ruby
=> nil

6.3.2 Keyboard Input


 In Ruby the keyboard input is rarely needed but we can give the input to the
program using keyboard.
 For the keyboard input the method gets is used. This method reads the line of
input.

Here it waits for input to get typed.

Due to the gets.chomp


function there is no \n at
the end of the string.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6-9 Ruby and Rails

 The gets.to_i or the gets.to_f method is useful for obtaining the integer or the float
value. Following are the simple steps that can be followed for executing the ruby
program :

Step 1 : Open the suitable text-editor such as Notepad or Wordpad. Type the following code
and save this file using the extension .rb.
InputDemo.rb
puts "Enter the value of a"
a=gets.to_i
puts "Enter the value of b"
b=gets.to_i
c=a+b
puts "The addition of two numbers a and b is #{c}"

Step 2 : Now type the command at the command prompt for executing the ruby program as
Ruby InputDemo.rb

6.4 Control Statements


 In Ruby the control statements are used for controlling the flow of control.
 It consists of control expressions, selection statements and looping statements.

6.4.1 Control Expressions

 The control expressions are Boolean type expressions.


 The relational expression has two operands and one operator.
 There are two sets of Boolean operators. The operators &&(AND), ||(OR), and
!(NOT) are of highest precedence while the operators and, or and not are of lower
precedence.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 10 Ruby and Rails

 The operators are enlisted in the following table -


Operator Meaning

== Equal to operator. If two operands are equal then


it returns true.
!= Not equal to. If the two operands are not equal
then it returns true.
< The less than
> The greater than
<= Less than equal to
>= Greater than equal to
<=> Compares the two operands
eql? It returns true if the receiver object and the
parameter both have the same type and values.
Equal? Compares the two objects.

 The associativity of the operators is as shown in the following table. The highest
precedence operators are listed first and then the lowest precedence operators.

Operator Description Associativity

** Exponentiation Right

! ~ unary + unary - Not, complement, unary plus and Right


minus

*/% Multiply, divide and modulo Left

+- Plus and minus Left

& Bitwise `and' Left

<= < > >= Comparison operators Not associative

<=> == === != =~ !~ Equality and pattern match operators Not associative


(!= and !~ may not be defined as
methods)

&& Logical `and' Left

|| Logical `or' Left

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 11 Ruby and Rails

=, %= , /=, ,+= ,|= ,&= ,>>=, <<=, *=, Assignment Right


&&=, ||=,**=,-=

Not Logical negation Right

or and Logical composition Right

6.4.2 Selection and Looping Statements


Explain how multiple selection constructs are implemented in Ruby.

 The control statements are for controlling the flow of control of the program.
 The if statement is of following form -

 The if else statement is -

 Ruby allows two kinds of multiple selection constructs. Both named case. The first
form of case statement is as follows -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 12 Ruby and Rails

 Another form of case statement


case
when Boolean expression then
statement sequence
when Boolean expression then
statement sequence

else Expression
end
 The while and for statements are similar to C language. These are as follows -

 The for statement is as follows -

 The until statement is also used for looping. The body of until statement executes
when the condition is false.
Syntax
until conditional [do]
loop body statements
end
Ruby Script[UntilDemo.rb]
$i = 0;
$n = 3;
until $i > $n do
puts("Inside loop with i = #$i" );
$i +=1;
end
puts("Outside the loop with i=#$i")
Output
Inside loop with i = 0
Inside loop with i = 1
Inside loop with i = 2
Inside loop with i = 3
Outside the loop with i=4

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 13 Ruby and Rails

The break statement is used to terminate the current execution. For example :
Ruby Script[BreakDemo.rb]
for count in 0..7
if count > 2*2 then
break
end
puts "count= #{count}"
end

Output
count= 0
count= 1
count= 2
count= 3
count= 4

Example 6.4.1 Write a Ruby program that inputs the list of numbers from keyboard and finds
the second smallest number in the list, along with its position in the list.

Solution :
Ruby Program[SecondDemo.rb]
i=0
arr=Array.new
puts "Enter the elements for the list. Press Cntrl+z for to terminate the list"
while(val=gets)
arr[i]=val
i+=1
end
first = arr[0]
second = arr[0]
i=0
for value in arr
if value < first
second = first
secondkey=i
first = value
elsif value < second
second = value
secondkey=i
end
i+=1
end
puts "The smallest element is #{second}and the position is #{secondkey}"

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 14 Ruby and Rails

Output

6.5 Fundamentals of Arrays


 In Ruby the arrays are more flexible because of two reasons -
o The arrays in Ruby are dynamic that means the array can grow and shrink.
o The arrays in Ruby can store the elements of different data types.
 The arrays can be created in two different ways.
 The first way is to use the keyword new. For example :
o Marks =Array.new
o Marks=Array.new(10)  the array of 10 locations gets created.
 The second way is to assign the list of literals to the variables. For example :
o Student=[10,20,30,”Archana”,[ ]]
 The subscript of array elements is integer and every array starts at the subscript 0.
 The length method is used to retrieve the length of the array.
 The at method returns the element present at the pointed subscript.
Ruby Script [ArrayDemo.rb]
A=[10,20,30,40,50]
puts "The array is : #{A}"
num=A.at(3)
puts "The element at 3rd index is :#{num}"
len=A.length
puts "The length of the array is :#{len}"
Output
The array is : [10, 20, 30, 40, 50]
The element at 3rd index is :40
The length of the array is :5

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 15 Ruby and Rails

6.5.1 The for-in Statement


 The for-in statement is used to visit the elements of an array. Following is a simple
example that illustrates the use of for-in statement -
Ruby Script [ForInDemo.rb]
A=[10,20,30,40,50]
for i in [0,1,2,3,4]
puts "For index: #{i}, value=#{A[i]}"
end
Output
For index: 0, value=10
For index: 1, value=20
For index: 2, value=30
For index: 3, value=40
For index: 4, value=50

6.5.2 Built in Methods for Arrays and Lists


 In this section, we use various built in methods for supporting array operations.
Open the Interactive Ruby interpreter and invoke various methods.
 The shift method removes the first element of an array. For example :
irb(main):001:0> A=[10,20,30,40,50]
=> [10, 20, 30, 40, 50]
irb(main):002:0> num=A.shift
=> 10
irb(main):003:0> A
=> [20, 30, 40, 50]
irb(main):004:0>
 The push method is used to push the elements from the end in the array. For
example :
irb(main):001:0> A=[10,20,30]
=> [10, 20, 30]
irb(main):002:0> A.push(40,50)
=> [10, 20, 30, 40, 50]
irb(main):003:0>
 The two arrays can be combined together using the + operator. For example :
irb(main):001:0> A=[10,20,30]
=> [10, 20, 30]
irb(main):002:0> B=[1.1,1.2,1.3]
=> [1.1, 1.2, 1.3]
irb(main):003:0> C=A+B
=> [10, 20, 30, 1.1, 1.2, 1.3]
irb(main):004:0>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 16 Ruby and Rails

 The reverse method is used to reverse the contents of the array. For example :
irb(main):001:0> A=[10,20,30,40,50]
=> [10, 20, 30, 40, 50]
irb(main):002:0> A.reverse
=> [50, 40, 30, 20, 10]
irb(main):003:0> A
=> [10, 20, 30, 40, 50]
irb(main):004:0>
 The sort method is used to sort the contents of the arrays. For example
irb(main):001:0> A=[30,10,20,50,40]
=> [30, 10, 20, 50, 40]
irb(main):002:0> A.sort
=> [10, 20, 30, 40, 50]
irb(main):003:0>
 The include? is used to check whether the array contains particular element or not.
irb(main):001:0> A=[10,20,30,40]
=> [10, 20, 30, 40]
irb(main):002:0> A.include?(20)
=> true
irb(main):003:0> A.include?(99)
=> false
irb(main):004:0>

6.5.3 Examples
Following is a simple Ruby program that sorts the array and then searches the
desired element from the array.
Ruby Program
i=0
A=Array.new
puts "Enter the elements in the array"
while(i<5)
val=gets
A[i]=val
i+=1
end
A.sort!
puts "The sorted array is "
for val in A
puts val
end
puts "Serching the elements from an array"
puts "Enter the number to be searched"

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 17 Ruby and Rails

key=gets
if A.include?(key)
puts "The element #{key} is present in the list"
else
puts "The element #{key} is not present in the list"
end

Output(Run1)
Enter the elements in the array
30
10
50
40
20
The sorted array is
10
20
30
40
50
Serching the elements from an array
Enter the number to be searched
40
The element 40
is present in the list
(Run1)
Enter the elements in the array
30
20
10
50
40
The sorted array is
10
20
30
40
50
Serching the elements from an array

Enter the number to be searched


88
The element 88
is not present in the list

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 18 Ruby and Rails

6.6 Hashes
 A hash is a collection of key-value pairs like this : "Roll" =>10
 Hashes are also called as associative arrays.
 The hashes are similar to arrays but the only difference between the two is that,
Hashes Arrays

The hash uses the string values as a The arrays use the integer values as a
subscript to address the elements. These subscript to address the element.
string values are basically the keys.
The elements in hash are not ordered. The elements in array are ordered by
The arrangement of elements in hash subscript. The arrangement of elements
resembles the set. in array resembles the list.

 The hash can be created using either the new method or by assigning the key-value
pair. For example :
Ruby Program [HashDemo1.rb]
A = Hash.new( "one" )
puts "\tFirst Method of Hash Creation"
puts "#{A[0]}"
puts "#{A[3]}"
puts "#{A[5]}"
puts "\tSecond Method of Hash Creation"
B=Hash["AAA"=>100,"BBB"=>200,"CCC"=>300]
puts "#{B['AAA']}"
puts "#{B['BBB']}"
puts "#{B['CCC']}"
puts "\t Displaying the keys of the array"
keys=B.keys
puts "#{keys}"

Output

First Method of Hash Creation


one
one
one
Second Method of Hash Creation
100
200
300
Displaying the keys of the array
["AAA", "BBB", "CCC"]

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 19 Ruby and Rails

6.7 Methods
 Methods in Ruby are similar to the functions.
 When a block of statements that get repeated many times in the program then the
method is used.
 The method is defined outside the class.
 In this section we will discuss how to write the methods in Ruby and call them.
6.7.1 Fundamentals
 The method definition includes method header and sequence of statements.
 The method header consists of the reserved word def.
 The method name must begin with lower case.
 The syntax of method definition is as given below -
def method_name ( argument list )
method body
end
or
def method_name
method body
end
 If the method has no parameter then the parenthesis can be omitted.
Ruby Program[MethodDemo.php]
def mymethod
puts " This is the method demo"
end
mymethod
Output
This is the method demo
Program Explanation :
 In above, program, we have defined the method named mymethod. The method is
called only by its name. The keyword def is used to define the method.
 Every method in Ruby returns something. The values can be returned using the
keyword return If there is no return statement then by default the last sentence of
the method is returned. For example :
def mymethod1
i=10
j=20
end
puts mymethod1
The above code will display the output as 20.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 20 Ruby and Rails

 We can make use of the return statement to return the values.


 In Ruby we can return more than one values.
For example :
def mymethod2
i=10
j=20
return i,j
end
puts mymethod2
Output
10
20

6.7.2 Local Variables

 Local variables are the variables that are created inside the method.
 The scope of the method during the definition of the method.
 The advantage of local variables in the method is that if the name of the local
variable conflicts with the name of the global variable then the conflict gets resolved
automatically by using the local variable.
 The name of the local variable must begin with either the lower case letter or by
underscore.
 The lifetime of the local variable is the period of time over which it exists.

6.7.3 Parameters
 There are two types of parameters - Actual parameter and the formal parameter.
For example :
Ruby Program[testmethod.rb]
def testmethod(arg1,arg2)
puts "The first parameter is #{arg1}"
puts "The second parameter is #{arg2}"
end
puts testmethod 10,20

Output

The first parameter is 10


The second parameter is 20

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 21 Ruby and Rails

 Variable number of parameters can be handled by the method using the asterisk *.
For example :
Ruby Program [testmethod1.rb]
def testmethod1(*arg)
puts "The total number of parameters are: #{arg.length}"
for i in 0...arg.length
puts "The parameters are #{arg[i]}"
end
end
testmethod1 10,20,30
testmethod1 11.1,12.2,13.3,14.4,15.5
Output
The total number of parameters are: 3
The parameters are 10
The parameters are 20
The parameters are 30
The total number of parameters are: 5
The parameters are 11.1
The parameters are 12.2
The parameters are 13.3
The parameters are 14.4
The parameters are 15.5
 The call to the method must have same number of actual parameters as the number
of formal parameters.

6.8 Classes
 Ruby is purely an object oriented programming language. Hence class is an
important factor of this programming language.
 The objects are created from the classes. In other words we can say object is an
instance of a class.

6.8.1 Basics of Classes


 Every class contains two things the variables and the functions. The class in the
Ruby can be defined as follows -
class className

end
 The class name must begin with the capital letter. The keyword class can be used to
define the class. The class must be terminated by the keyword end.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 22 Ruby and Rails

 In Ruby there are two types of variables in class -


o Instance Variables : The instance variables are defined in the method. The
instance variables change from object to object. These variables are available
across the methods. The syntax of these variables is ,
@variable_name

o Class Variables : The class variables belongs to the class. They are used to
define the characteristics of the class. These are available across the objects. The
syntax of these variables is,
@@variable_name

 Objects are the instances of the class and these can be created using the method
new.
For example :
Obj1= Myclass.new

 There is a method named initialize is a constructor of the class which initializes the
values of the variables. Using the def and the end the method initialize can be
defined.
 The name of the method must be starting with the lower case letter. It must be
ended by the keyword end.
Example : Create a class for obtaining the roll number,name and marks of the student. Display
the records.
class Student
@@TotalStudents=0 Class Variables
def initialize(roll, name, marks)
@stud_roll=roll
@stud_name=name
Instance Variables
@stud_marks=marks
end
def display()
puts "Roll Number: #@stud_roll"
puts "name: #@stud_name"
puts "Marks: #@stud_marks"
end
def total()
@@TotalStudents += 1
puts "\tTotal number of students: #@@TotalStudents"
end
end
S1=Student.new("1", "Shilpa", 97.11)

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 23 Ruby and Rails

S2=Student.new("2", "Rashmi", 89.21)


# Call Methods
S1.display()
S1.total()
puts "---------------------------------------------------"
S2.display()
S2.total()

Output

F:\Ruby-Examples>Ruby classDemo.rb
Roll Number: 1
name: Shilpa
Marks: 97.11
Total number of students: 1
---------------------------------------------------
Roll Number: 2
name: Rashmi
Marks: 89.21
Total number of students: 2

6.8.2 Access Control

 There are three access control for the methods - Public, private and protected.
 The default access control for the method is public.
 The public access method means that the method can be called by any code.
 The protected access means only objects of defining class and its subclasses may call
the method.
 The private access means private methods of another object can not be accessed by
one object.
 For example
Ruby Program [Test.rb]
class Test
def method1
puts "This is the first method"
end
private
def method2
puts "This is second method"
end
protected
def method3

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 24 Ruby and Rails

puts "This is third method"


end
end
obj=Test.new()
obj.method1
Output
This is the first method
Note that if you call the obj.method2 or obj.method3 then we will get the error.

6.8.3 Inheritance
 Inheritance is the most important feature of any object oriented programming
language.
 By inheritance the two classes are created one base class and another derived class.
 Using the object of derived class one can access the methods of itself and the base
class both.
 The syntax for declaring the derived class is,
class Derived_class_name < Base_class_name
For example :
Ruby Program [InheritanceDemo.rb]
class A
def method1
puts "I am in method1 of class A."
end
def method2
puts "I am in method2 of class A."
end
end

Class B is derived from class A


class B < A
def method3
puts "I am in method3 of class B."
end
end
obj = B.new
obj.method1
obj.method2
obj.method3
Output
I am in method1 of class A.
I am in method2 of class A.
I am in method3 of class B.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 25 Ruby and Rails

Note that in above code, using the object of derived class we can access the methods of
base class (i.e. method1 and method2) and the derived class (method3) as well.

6.9 Code Blocks and Iterators


 Block consists of collection of code.
 The block is always enclosed within { and }.
 Blocks can be used with methods.
 Using the iterator each we can display each element of the array and apply it to
block.
 For example :
Ruby Program [BlockDemo.rb]

A=[10,20,30,40]
A.each{|num| puts "The number is #{num}"}

Output

The number is 10
The number is 20
The number is 30
The number is 40
 Using the iterator step the specific values can be displayed. For Example
Ruby Program [BlockDemo1.rb]

Output

The number is 10
The number is 12
The number is 14
The number is 16
The number is 18
The number is 20

 Using the yield method the block can be invoked.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 26 Ruby and Rails

 A block is always invoked from a function. But the name of the function and the
name of the block must be the same in this case.
 For example :
Ruby Program [BlockDemo1.rb]

def myfun
puts "This statement is in method" Block is called
yield
puts "Returning back to the method"
end Block is defined

myfun {puts "This statement is in block"}

Output

This statement is in method


This statement is in block
Returning back to the method

6.10 Pattern Matching

6.10.1 Basics of Pattern Matching

 For pattern matching the operator =~ is used.


 The pattern can be placed within /
 For example :

 Open the Interactive Ruby interpreter and type the following commands and
observe the results.
irb(main):001:0> T="Success"
=> "Success"
irb(main):002:0> T=~/es/
=> 4
irb(main):003:0>

 The split method is used to separate out the words from the given string. For
example following commands on Interactive Ruby interpreter will show how to
separate out the words from the string using split command.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 27 Ruby and Rails

irb(main):005:0> s="hello friends how are you"


=> "hello friends how are you"
irb(main):006:0> w=s.split(/[ .,]\s*/)
=> ["hello", "friends", "how", "are", "you"]
irb(main):007:0>

6.10.2 Remembering Matches

 Ruby allows to save the matched part of the pattern in the variable. Later on we can
use this variable to get the desired part of the pattern.
 For example - Open the Interactive Ruby interpreter and type the following
command and observe the results -
irb(main):001:0> pattern="Anuradha-19999"
=> "Anuradha-19999"
irb(main):002:0> pattern=~ /(\w+)-(\d+)/
=> 0
irb(main):003:0> puts "First string is #{$1}"
First string is Anuradha
=> nil
irb(main):004:0> puts "Second string is #{$2}"
Second string is 19999
=> nil
irb(main):005:0>

 In above example we have first stored the pattern in a variable say pattern. Then
this pattern is matched with the regular expression. The \w stands for matching the
words. The \d stands for matching the digits. Thus we get the groups of substrings
from the given pattern. Then using $1,$2,… we can retrieve particular part of the
regular expression. The $1 stands for the value of first matched substring, $2 stands
for the value of second matched string.

6.10.3 Substitutions

 There are two methods sub and gsub which are for searching the desired pattern
and replacing them.
 The sub method searches the first part of the pattern and replace it.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 28 Ruby and Rails

 For example :
irb(main):001:0> mystr="PHP is a fun.Enjoy PHP"
=> "PHP is a fun.Enjoy PHP"
irb(main):002:0> mystr.sub(/PHP/,"Ruby")
=> "Ruby is fun.Enjoy PHP"
irb(main):003:0> Note that the first occurrence of PHP is replaced by the
word Ruby and the second occurrence remains

 The gsub method is similar to sub but it replaces all the occurrences of matched
substring. For example :
irb(main):001:0> mystr="PHP is a fun.Enjoy PHP"
=> "PHP is a fun.Enjoy PHP" Note that the all the occurrences of
irb(main):002:0> mystr.gsub(/PHP/,"Ruby") PHP are replaced by the word Ruby
and the second occurrence remains
=> "Ruby is a fun.Enjoy Ruby"
unchanged.
irb(main):003:0>

 Using sub or gsub have the mutator versions and those are sub! and gsub!. These
versions replace the original string also. For example :
irb(main):001:0> str="PHP is a fun. I like PHP"
=> "PHP is a fun. I like PHP"
irb(main):002:0> str.sub!(/PHP/,"Ruby")
=> "Ruby is a fun. I like PHP"
irb(main):003:0> str
=> "Ruby is a fun. I like PHP"
irb(main):004:0> str1="Java is OOP.I program in Java"
=> "Java is OOP.I program in Java"
irb(main):005:0> str1.gsub!(/Java/,"Ruby");
irb(main):006:0> str1
=>"Ruby is OOP.I program in Ruby"

Part II : Introduction to Rails

6.11 Overview of Rails


 Rails is a development framework for web - based applications. As Rails are closely
associated with Ruby it is often referred as Ruby on Rails or simply RoR.
 Rails was developed by David Heinemeier Hansson in early 2000 and was released
in July 2004.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 29 Ruby and Rails

 The web application can be developed ten times faster with Rails than with a typical
Java framework.
 Rails is based on MVC architecture - i.e. Model View Controller.
 The MVC architecture clearly separates the logical and physical parts of the
applications in three parts - Model, View and Controller.
 The Model part is for data and constraints on data. The View part prepares and
presents the result or output. The Controller controls the application.
 The most significant characteristic of Rails is its approach to connecting object
oriented software with relational database. But both the object oriented software
and relational databases are not compatible to each other. Hence Rails make use of
Object-Relational Mapping (ORM) approach. By this each relational database
table is simply mapped to a class. For example if the database has a table named
Student then it will be mapped to class Student. Thus ORM maps tables to classes,
rows to objects and columns to field of objects. The ORM of rails is called
activeRecord.
 The View and Controller part of MVC are supported by ActionPack components of
Rails. The view documents are generated for three categories of web documents
XHTML, XML and JavaScript and the Controller part of MVC interacts with data
model, user and the view.
 Rails can be more commonly used with Ajax. It makes use of the JavaScript
framework named prototype to support Ajax and interaction with JavaScript
model.
 Rails uses MVC architecture, consists of designing and building three parts of an
MVC system.

6.12 Document Requests


 Rails is a software development framework. The software development framework
consists of library of components that provide commonly needed services to an
application.
 The easiest method of downloading the and installing Rails is to make use of a
complete software system such as InstantRails or Ruby Stack.
 The Ruby Stack can be downloaded and installed from
http://bitnami.com/stack/ruby. It can be downloaded on Windows/ Linux or MacOS
platform. It consists of Ruby, Rails, Apache, MySQL, SQLite, Git, PHP and

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 30 Ruby and Rails

phpMyAdmin in one pack. Installing Ruby Stack is quick and easy. It is a


self-contained system.
 After installing the Ruby Stack we can start the Apache Server and MYSQL Server
using the Managers. The screenshot is as follows.

6.12.1 Static Documents - Creation of First Application in Rails


In this section, we will see the step by step method of building the first application in
Rails. The Ruby Stack is installed on my machine at C:\BitNami\rubystack-1.9.3-22.

Step 1 : Go to the Projects directory within the Ruby Stack's directory. Create a folder of
any name for storing various applications. I have created a folder named MyProject1.
This is the base directory in which the developer can add new Rails applications. Now we
will create another subdirectory say test1 by issuing the following command
> rails new test1
Following screenshot illustrates it.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 31 Ruby and Rails

 Rails respond to this command by generating number of files and directories. Out
of these directories the most important directory from the application point of view
is app. It has four subdirectories namely models, views, controllers and helpers.
The models, views and controllers are those directories that will support MVC of
Rails.
 For the sake of understanding just look at the directory structure as given below -

Fig. 6.12.1 Directory structure for the test1 application

Step 2 : This directory contains several important Ruby scripts that perform the services.
One of the service is generate. This service is used to create or generate the controller
methods. The two parameters are passed to this service - first is controller and second is
the name chosen for the controller. The controller indicates that we want the controller
class to be built. The command will be issued from the test1 directory. The command will
be as follows -
> rails generate controller first welcome

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 32 Ruby and Rails

 Due to the above command the FirstController class will be generated in


first_controller.rb at location app/controllers/
 There are now two Ruby classes application_controller.rb and first_controller.rb.

The first_controller.rb can be opened up in Notepad/Wordpad . It contains -


class FirstController < ApplicationController
end
Here FirstController is an empty class and is inherited from ApplicationController
class.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 33 Ruby and Rails

These Controllers are useful for producing the HTTP responses. To respond the
request there must be some actionmethod. This actionmethod simply indicate the
document as a response. The first_controller.rb will be as given below in appearance -
class FirstController < ApplicationController
def welcome
end
end

Step 3 : In above step the welcome is the action method name. It is the response to the
URL http://localhost:3000/first/welcome.
This is actually the view document. The view document is called as template. These
templates will be placed in app/views directory. The template will be written as an
XHTML file. The extension to this file will be .rhtml (or it can be html). The Ruby code
can be inserted in this file. Hence the extension is derived from the word Ruby HTML.
For our first application we can write the template as follows[Note that there is no Ruby
code embedded in the following rhtml file, it simply makes use of HTML tags].
welcome.rhtml
<html>
<head>
<title> FIRST RAILS PROGRAM</title>
</head>
<body>
<center>
<h1>Welcome!!!</h1>
<h3>This is my First Program using Rails </h3>
</center>
</body>
</html>
It can be illustrated as –

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 34 Ruby and Rails

Step 4 : Now we will start the server for running the above created static document
application by issuing the following command
> rails server
The following screenshot illustrates this command.

Now open suitable web browser and type the URL http://localhost:3000/first/welcome
on the address bar. [Note that the URL specified during the installation is localhost and
port is 3000]

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 35 Ruby and Rails

6.12.2 Dynamic Documents

 Dynamic document is a kind of web document in which the contents are changing
more often. For example if your web page is displaying the current date and time or
stack market position or Cricket match score then that document is said to be a
dynamic document.
 In this section we will build an application in which the dynamic web document is
created for displaying the current date and time. The implementation of such web
document is possible by embedding some Ruby code within it.
 The Ruby code can be embedded within the template file by using <% and %>
markers.
 If the Ruby code produces some result then the result can be inserted within the
template document by <%= and %> marker.
 Ruby's Time.now is used to display the current time. In earlier section we have seen
how to display the static web document. We will follow steps 1 and 2 from the
above section. The template document created in step 3 is slightly changed. It is as
follows -
welcome.html
<html>
<head>
<title> FIRST RAILS PROGRAM</title>
</head>
<body>
<center>
<h3>Current Date and Time … </h3>
<p> It is now <%= t = Time.now %> </p>
</center>
</body>
</html>
 Now start the server by going into the test1 directory by the command -
>Rails server

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 36 Ruby and Rails

Open the suitable web browser and get the output as follows -

6.13 Processing Forms


Form is an useful tool used in building the GUI using which the user can interact with
the system.
We will follow the following steps in processing form using Rails.
Step 1 : We have already created a folder named MyProject1 in the Projects directory of
Ruby Stack. Now go to the MyProject1 directory and create a sampleForm subdirectory
using following command by using the command prompt -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 37 Ruby and Rails

Now the sampleForm will have all those necessary directories such as app, config,
script and so on generated within it.
Step 2 : Now go to the sampleForm directory and issue the following command on the
command prompt for generating controller.
>rails generate controller order orderform displayorder

This will generate order_controller.rb file. Also create orderform.html and


displayorder.html files in the order sub-directory.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 38 Ruby and Rails

Step 3 : The code for orderform.html file is as follows -


orderform.html
<html>
<head>
<title> Submitted Order</title>
</head>
<body>
<h3> User Name: <%= @UserName %> </h3>
<table border="1">
<tr>
<td><b>Product Name</b></td>
<td><b>Price(Rs.)</b></td>
<td><b>Quantity</b></td>
<td><b>Cost</b></td>
</tr>
<tr>
<td>Apples</td>
<td>10 </td>
<td><%= @qty1 %></td>
<td><%= @apple_cost %></td>
</tr>
<tr>
<td>Oranges</td>
<td>7.50 </td>
<td><%= @qty2 %></td>
<td><%= @orange_cost %></td>
</tr>
</table>
<br/>
<h2> Total Cost = <%= @total_cost %> </h2>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 39 Ruby and Rails

Step 4 : Edit the controller file order_controller.rb as follows -


order_controller.rb
class OrderController < ApplicationController
def orderform Invokes orderform.html
end
#displayorder method - it fetches the data from form and compute
#total cost
Invokes displayorder.html
def displayorder
@UserName =params[:UserName]
@qty1 = params[:qty1].to_i
@qty2 = params[:qty2].to_i

#Computing the cost of each item


Reading the input from
@apple_cost = 10 * @qty1
the orderform.html and
@orange_cost = 7.50 * @qty2
preparing the computed
#computing the total cost of purchased items cost variables for
@total_cost = @apple_cost+@orange_cost displaying the result.

#Converting the values into strings with two digits


@total_cost = sprintf("%4.2f",@total_cost)
@apple_cost = sprintf("%4.2f",@apple_cost)
@orange_cost = sprintf("%4.2f",@orange_cost)
end
end

 Using the params symbol the parameters on the input rhtml file can be invoked.
The .to_i method is used to convert the string to integers.

 The sprintf function of C can be used to format the numbers in two decimal places.
This is done for displaying the floating point data in formatted manner.

 Save this file and close it. By the above code we have actually written the response
methods namely orderform and displayorder. The orderform.html and
displayorder.html files will be invoked as a response to these action methods. Out
of these the orderform.html is already created. Now we will created
displayorder.html web document.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 40 Ruby and Rails

Step 5 : Open app/views/order and create a file named displayorder.html.


It is as follows -
displayorder.html
<html>
<head>
<title> Submitted Order</title>
</head>
<body>
<h3> User Name: <%= @UserName %> </h3>
<table border="1">
<tr>
<td><b>Product Name</b></td>
<td><b>Price(Rs.)</b></td>
<td><b>Quantity</b></td>
<td><b>Cost</b></td>
</tr>
<tr>
<td>Apples</td>
<td>10 </td>
<td><%= @qty1 %></td>
<td><%= @apple_cost %></td>
</tr>
<tr>
<td>Oranges</td>
<td>7.50 </td>
<td><%= @qty2 %></td>
<td><%= @orange_cost %></td>
</tr>
</table>
<br/>
<h2> Total Cost = <%= @total_cost %> </h2>
</body>
</html>

Step 6 : Now open command prompt and start the server using the command.
>rails server

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 41 Ruby and Rails

Then open the suitable web browser and type the following URL in the address bar.
http://localhost:3000/order/orderform

Enter the data and click the Submit button on that form. You will get following
output.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 42 Ruby and Rails

6.14 Rails Applications and Databases


Step 1 : For creating a database application create a folder by some suitable name in
Ruby's directory. I have created a folder named dbdemo by following command
> rails new dbdemo
The screenshot is as follows -

By this command a directory dbdemo will be created with several useful


subdirectories such as app, config, doc, db, script and so on.

Step 2 : Now generate the controller by the following command in dbdemo directory
> rails generate controller mybook

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 43 Ruby and Rails

So a controller named mybookController will be created within the file


mybook_controller.rb of controller directory.

Step 3 : Now we will create a database in the MySQL by following command


>mysql -u root -p;
It will prompt for password if any. Then the mysql prompt will appear on the prompt
window.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 44 Ruby and Rails

Step 4 : Now create a database named bookinfo_development using CREATE


DATABASE command. Following screenshot illustrates it.

Then create tables books and subject. Following screenshot illustrates the creation
commands.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 45 Ruby and Rails

Step 5 : Now we will generate the model files that are required for this application. Use
following command for this.

These command will generate the files namely book.rb and subject.rb in app/model
directory.
Open these files using the text editor and edit them as follows -
book.rb
class Book < ActiveRecord::Base
belongs_to :subject
end
subject.rb
class Subject < ActiveRecord::Base
has_many :books
end
The has_many and belongs_to are the relationships used in MySql for specifying the
classes associated with the database tables. When these relationships are provided then
Rails generate the capabilities to manipulate the given relationship.

Step 6 : Now insert the data into tables books and subject. Following commands
illustrates the insertion of data.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 46 Ruby and Rails

Step 7 : Now open the controller file which is present in the controller folder. Edit it as
follows -
mybook_controller.rb
class MybookController < ApplicationController
def welcome
end
def show
@titlename = params[:title]
@bookarr = book.find(:all, :conditions => ["title =?",@titlename])
@subarr = subject.find(:all)
end

Step 8 : The welcome.rhtml file can be stored in app / views directory.


It will be as follows -
<html>
<head><title> RAILS-MYSQL DEMO </title></head>
<body>
<form method="post" action="show">
<input type="text" name="title" size="20"/>
<input button="submit" name="Display" />
</form>
</body>
</html>
The show.rhtml file can be stored in app / views directory. It will be as follows -
<html>
<head>
<title> Book Display</title>
</head>
<body>
<table border="1">
<tr>
<td><b>AccessNo</b></td>
<td><b>Title</b></td>
<td><b>Author</b></td>
<td><b>Edition</b></td>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 47 Ruby and Rails

<td><b>Publication</b></td>
<td><b>Subject</b></td>

</tr>
<% @bookarr.each do |b|
@accno=b.accNo
@title=b.tilte
@author=b.author
@edition=b.edition
@pub=b.publication
@subject_row=@subarr[b.title_id]
@subjectname=@subject_row. subject_name %>
<tr>
<td><b><%= accno %></b></td>
<td><b><%= title %></b></td>
<td><b><%= author %></b></td>
<td><b><%= edition %></b></td>
<td><b><%= pub %></b></td>
<td><b><%= subjectname %></b></td>
</tr>
<% end %>
</table>
</body>
<html>

6.15 Layouts
 The app/View directory of each application has two directories, one is for the
controller and another is named as layouts.
 A layout defines the surroundings of an HTML page. In layout directory you can
place a file for common look and feel of your final output. For that purpose layout
template is created.
 Rails must be informed about the name of the layout document by placing the
layout command in the ApplicationController class of the application.
 In the controller directory of app there is a file named application_controller.rb in
this file the following code can be placed -
class ApplicationController < ActionController::Base
layout "mainlayout"
end
 Now if we add mainlayout.rhtml document to layout directory then the basic
layout of the application can be defined.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 48 Ruby and Rails

6.16 Rails with Ajax


 AJAX stands for Asynchronous JavaScript and XML. It allows client side changes
without reloading the page.
 When you type http://localhost:3000 into your browser's address bar and hit 'Go',
the browser (your 'client') makes a request to the server. It parses the response, then
fetches all associated assets, like JavaScript files, stylesheets and images.
 It then assembles the page. If you click a link, it does the same processs : Fetch the
page, fetch the assets, put it all together, show you the results. This is called the
'request response cycle'.
 JavaScript can also make requests to the server, and parse the response. It also has
the ability to update information on the page. Combining these two powers, a
JavaScript writer can make a web page that can update just parts of itself, without
needing to get the full page data from the server. This is a powerful technique is
called as Ajax.
 For example -
fetch("/index")
.then((data) => data.text())
.then((html) => {
const results = document.querySelector("#compute");
results.insertAdjacentHTML("before_exit", data);
});
 This code fetches data from "/index" and then appends the result to the element
with an id of compute.
 Rails provides quite a bit of built-in support for building web pages with this
technique. Rails uses a technique called "Unobtrusive JavaScript" to handle
attaching JavaScript to the DOM. This is a technique by which we can mix
JavaScript code into HTML. With this, we can easily add behavior to any link by
adding data attribute.

Part III : EJB

6.17 Introduction to EJB SPPU : May-18, 19, Dec.-18, Marks 8

 J2EE application container contains the components that can be used by the clients
for executing the business logic. These components are known as Enterprise Java
Beans (EJB).
 EJB mainly contains the business logic and business data.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 49 Ruby and Rails

 Using the technology like EJB the server side, distributed Java components can be
built.
 EJBs provide a core set of system services to Java component. EJB components
always lie in some container which is called as EJB container.
 EJB component is an EJB class. It is a Java class written by EJB developer and this
class implements business logic.
 EJB component is similar to traditional Java beans but there are some difference
between the two. These differences are as given below -

Java Beans EJB

The java bean components can be visible or The EJB components are always invisible to the
invisible to the user. user.

The Java beans normally run locally. EJB are distributed components and always
exist on the servers.

The Java beans can be used as Activex Control. EJBs can’t be used as Activex Control.

The Java beans can be described with EJBs can be described using
properties, BeanInfo classes and Customizers. DeploymentDescriptor.

6.17.1 Types of EJB


 Following are the types of EJB.

Fig. 6.17.1 Types of EJB

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 50 Ruby and Rails

Entity Bean
 Entity beans are used for modelling the business concepts. Therefore entity beans
represent the data. For example entity bean can represent the bank account or a
customer. The nouns that are used in the problem description refer to the entity
beans. Basically the entity beans represent the real world objects.
 Such beans then act as a persistent record in the database.
Session Bean
 Session beans are used for managing processes or tasks. For example Compute net
profit or transaction or browsing for some information on the web browser. Hence session
beans are used for managing activities. Basically session beans represent the
activities. Hence session beans are transient, because activities generally exist for a
short period. Session bean does not represent anything in the database but it can
access the database. Session beans are client specific.
What are the differences between entity bean and session bean ?

Sr. No. Entity bean Session bean

1. These are persistent. These are transient.

2. It refers to the records in the database. These refers to the activities for the database.

3. These can survive on server crash. Session objects generally cannot survive on
(After server gets online these can be server crashes.
reconstructed from the underlying
data).

4. Entity beans are client-independent Session beans are client-specific entities.


entities.

Bean managed Persistent


 The bean managed persistent is a kind of entity bean that is used for saving bean’s
state.
 The container does not need to make any database call.

Container managed Persistent


 This kind of bean is used to manage the persistence of the entity bean.
 That means EJB container is responsible for saving the bean’s state.
 For container managed persistent bean implementation is independent of the data
source.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 51 Ruby and Rails

Stateless
 Stateless bean is designed for simple and lightweight components.
 This brings the scalability in server performance. As no state is maintained in this
type of bean it is called stateless bean.
 The stateless beans are not tied to any specific client. Hence any available instance
of stateless session bean can be used to service a client.
Stateful
 The stateful bean is used to store the internal states of the EJB.
 There is only one stateful session bean per EJB client.
 These types of beans can be saved across client sessions. And we can restore them
back.
Message driven Bean
 Message driven is similar to the session bean but it gets activated only when
asynchronous message arrives.
 A message-driven bean's instances retain no data or state for a specific client.
 A single message-driven bean can process messages from multiple clients.
 When a message arrives then the EJB container calls the message driven bean’s
onMessage method to process the method.

6.17.2 Benefits of EJB


1. Business to Business (B2B) e-commerce applications make use of EJB.
2. EJB can be used in web-centric as well as web-oriented applications.
3. Use of EJB is more suitable when there is large number of clients involved.
4. The Enterprise Application Integration (EAI) can use EJB for processing and
mapping different applications. There, encapsulation of business logic with the
data is possible due to EJB.
5. They can be customized at deployment time by editing the deployment
descriptor.
6. System-level services, such as transaction management and security, are
described separately from the enterprise bean.
7. A client never accesses an enterprise bean directly; the container environment
mediates access for the client. This provides component-location transparency.
8. The EJB is designed to be portable across EJB servers provided by different
vendors.
9. They can be included in an assembled application without requiring source code
changes or recompilation of them.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 52 Ruby and Rails

6.17.3 Architecture
Components of EJB
 The EJB container provides following services to EJB component -
o Security
o Transactions
o Messaging
o Persistence
o Distributions
o Connectivity
 The idea behind developing EJB is to provide a framework for the components that
can be plugged into a server. This ultimately helps to increase the functionality of
the server.
 EJB is a managed component that can be created, controlled and managed by its
container J2EE.
 There can be multiple EJBs in the container J2EE. The container J2EE provides the
resources (such as memory and database connections) required by the EJB.
 Thus J2EE maintains a pool of EJB instances. These instances can be assigned to the
clients.
 Client makes use of these EJB components and when it is no longer required by the
client, these instances can be returned to the pool so that other clients can used
these instances. The client who is using the EJB instance does not need to know
about its container.

Fig. 6.17.2

 EJB has a technique that keeps business logic separate from the database. In other
words, the business logic can deal with business data without caring about how
data is stored in database.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 53 Ruby and Rails

 There are two main purposes of the container firstly control the EJB it contains and
secondly provide the services to the EJB that are currently present in the container.
 The EJBs are typically one part of a three tier architecture as shown below.

Fig. 6.17.3 3 Tier architecture


 The following are the flows of the EJB architecture.
1. The client is working on a web browser.
2. There is a database server that hosts a database, like MySQL / Oracle.
3. The J2EE server machine is running on an application server.
4. The client interface is provided with JSP / Servlet. The enterprise beans reside in
the business tier providing to the client tier.
5. The Application Server manages the relationships between the client and
database machines.

6.17.4 EJB Technology


 Every EJB has three classes :
1. A home interface which acts as a factory of remote objects.
2. A remote object which is used for client interaction.
3. A bean object which contains all the business logic.
Setting Up the Environment
 In this section we will discuss how to develop an EJB stateless session bean.
 For that purpose we need to set up the environment for execution of EJB
stateless bean.
 We need following software to be installed in our machine -
o JDK
o NetBeans or Eclipse
o GlassFish

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 54 Ruby and Rails

 I have used NetBeans. The NetBeans is basically an Integrated


Development Environment (IDE). It is useful for developing various web
applications using Java, PHP, C++, EJB, mobile applications and so on. It is
an open source technology. That means you can get it downloaded freely
from the net. Following steps can be followed for setting up the
environment before creating our bean application.

Step 1 : The NetBeans can be downloaded from https://netbeans.org/downloads/

Now as I want GlassFish server for supporting my EJB app, I will choose
Java EE bundle for downloading. Here is the screenshot of download page
of NetBeans -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 55 Ruby and Rails

Step 2 : The exe file will start downloading on your machine. After getting the exe
file, click on it and start running the installer.

As shown in above screen-shot, Just check for GlassFish Server option. The GlassFish
is an Open Source server project started by Sun-Microsystems. It supports the
implementation of Enterprise Java Beans, JSF, RMI, JSP and Servlets.
Step 3 : Just go on installing the software by clicking Next button. Just uncheck for
Updates if you do not want any updates for NetBeans. Finally uncheck for
“Contribute to the NetBeans project by providing … “ and click Finish button.
Here completes the installation of your NetBeans software.

Creating a Simple EJB Stateless session Bean


We will follow the following steps for creation of this stateless bean -
Open NetBeans IDE

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 56 Ruby and Rails

Step 1 : Select File->New Project->Java EE-> EJB Module and Click Next Button.

 Give the Suitable Name to the project. Here I am giving “MyAddApp”. Click Next
Button.
 Select the server as GlassFish.
 Select the J2EE version what ever is installed on your machine and then click Finish
button.
Step 2 : Create a new Java Package called myPkg (I have given this name to my package.
You can give any suitable name) under the Source Package Folder.
Then create an interface called “MyInterface” under myPkg package and add
following code.

MyInterface.java
packagemyPkg;
import javax.ejb.Remote;
@Remote
public interface MyInterface {

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 57 Ruby and Rails

public int add(int a,int b);


}
Step 3 : Right click on myPkg, and add the Java class for implementation of above
interface. I have named this class as MyClass. This class contains the definition
of the function add which we have declared in above interface. The code is as
follows -
MyClass.java
package myPkg;
import javax.ejb.Stateless;
@Stateless
public class MyClass implements MyInterface{
@Override
public int add(int a,int b) {
return a+b;
}
}
Step 4 : We will create deployment descriptor file i.e the GlassFish Descriptor file.
Righ Click on the Project "MyAddApp" and then choose New -->Other--
>GlassFish-->GlassFish Descriptor and then click the "Next" button and click
the "Finish " Button.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 58 Ruby and Rails

The glassfish-ejb-jar.xml file will be created under the Configuration Files Folder.
Set the JNDI Name for the MyClass Bean by editing the file or by clicking the TAB
"EJB" and giving jndi name as "aaa". The edited xml file is as shown below -
Glassfish-ejb-jar.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE glassfish-ejb-jar PUBLIC "-//GlassFish.org//DTD GlassFish Application Server 3.1
EJB 3.1//EN" "http://glassfish.org/dtds/glassfish-ejb-jar_3_1-1.dtd">
<glassfish-ejb-jar>
<enterprise-beans>
<ejb>
<ejb-name>MyClass</ejb-name>
<jndi-name>aaa</jndi-name>
</ejb>
</enterprise-beans>
</glassfish-ejb-jar>

Step 5 : Right click on Project node(MyAddApp) and select Clean and Build.

After clean and Build again right click and click on project node and select deploy
For both these actions “BUILD SUCCESSFUL” message will be displayed in the
console output. Thus the JNDI name “aaa” is successfully deployed with our EJB bean
MyClass.
Step 6 : Now it’s the time to create the driver class which will call the method add which
we have defined in our bean program MyClass.java(Refer step 3). For that
purpose, again right click on the myPkg and create a Java Class. I have named it
as DriverClass . This program will contain the JNDI name and call to the method
add inside the public void main function. The code is as follows -
DriverClass.java
package myPkg;
import java.util.Properties;
import javax.naming.InitialContext;
public class DriverClass {
public static void main(String arg[])throws Exception
{
Properties p=new Properties();
InitialContext c=new InitialContext();
Object obj=c.lookup("aaa");
MyInterface inter=(MyInterface)obj;
System.out.println("The additon of two numbers is = "+inter.add(10,20));
}
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 59 Ruby and Rails

To let you know, the locations of these files I am giving the screen-shot of Project
explorer window for MyAddApp project.

Step 7 : Right click on DriverClass.java click on Run File option and you will get the
output on console window. Here is the output screenshot.

Creation of Simple Web Application using Stateful Session Bean


In this section we will learn how to create application using stateful session bean.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 60 Ruby and Rails

Step 1 : Click File-> New Project -> Java-> Java Class Library.

Click Next button. Add name to the Project. I have given the name as
MyWebAppInterface and click Finish button.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 61 Ruby and Rails

Step 2 : Now click File->New Project->Select ->Java EE->Enterprise Application. Then


click Next button. Give suitable name to your project. I have given the name
MyWebApp. Then click Next button. Then just click Finish Button. Your Project
explorer Window will look like this -

Step 3 : Now click on MyWebApp-War node, then click on Web-Pages folder, locate the
index.html file. Double click this file and edit it as follows -

index.html
<html>
<head>
<title>Web Application For Bank Transactions</title>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
</head>
<body>
<form action="Main">
Enter Amount: <input type="text" name="amt_txt">
<br/><br/>
Select Operation:
<br/><br/>
<select name="operation">
<option value="deposit">Deposit</option>
<option value="withdraw">Withdraw</option>
<option value="balance">Balance</option>
</select>
<br/><br/>
<input type="Submit" value="Submit">
</form>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 62 Ruby and Rails

Step 4 : Now right-click on MyWebApp-ejb node, click New->Session bean

Now give suitable name to your bean. Create this bean inside some package. I have
created a bean named MyBean inside the package named mypkg.

Since this is a stateful EJB application, Select the option Stateful. Here I have created
a Local interface. For that purpose, check for Local interface option. Finally click Finish
button. Edit the bean file as follows.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 63 Ruby and Rails

While inserting the code we can right click inside the class MyBean and add business
methods as -

MyBean.java
package myPkg;
import javax.ejb.Stateful;
@Stateful
public class MyBean implements MyBeanLocal {
int balance=0;
@Override
public void deposit(int amount) {
balance=balance+amount;
}
@Override
public boolean withdraw(int amount) {
if(amount<=balance)
{
balance=balance-amount;
return true;
}
return false;
}
@Override
public int getBalance() {
return balance;
}
}
Step 5 : Right click MyWebApp-ejb node and click Run. The GlassFish Server will start
running and you will get BUILD SUCCESSFUL message in console window at
the bottom of your NetBean IDE.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 64 Ruby and Rails

Step 6 : Now , inside the MyWebApp-War node there is a Source Packages , right click it
and create Servlet. I have named this as Main. Click the next button and Check
“Add information to deployment…” as shown -

 Click Finish Button.


 The servlet code window will appear with default
code. Locate the method void ProcessRequest(…)
inside this default code. Just above this method,
right click and select Insert Code and select Call
Enterprise Bean and then select MyWebApp-ejb
node and select MyBean inside it. Click OK button.
Due to this some built in code for Local Interface
reference will appear inside your servlet code. This
code will be for the lookup method.
 Inside this code you have to locate the instance for
this Local lookup. This instance is generally located
at the beginning of servlet definition as follows.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 65 Ruby and Rails

Now using the instance myBean we can invoke the methods defined in our Java Bean.
Note that this Java bean we have created in step 4.
The edited code for servlet is as follows -
Main.java
import java.io.IOException;
import java.io.PrintWriter;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import myPkg.MyBeanLocal;
public class Main extends HttpServlet {
MyBeanLocal myBean = lookupMyBeanLocal();
protected void processRequest(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=UTF-8");
try (PrintWriter out = response.getWriter()) {
String choice=request.getParameter("operation");
int amount=Integer.parseInt(request.getParameter("amt_txt"));
if(choice.equals("deposit"))
{
myBean.deposit(amount);
out.println("The amount is deposited successfully!!!");
}
if(choice.equals("withdraw"))
{

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 66 Ruby and Rails

if(myBean.withdraw(amount))
{
out.println("The amount is wihdrawn successfully!!!");
}
Else
out.println("Sorry, Balance insufficient!!!");
}
if(choice.equals("balance"))
{
out.println("The total balance is = "+myBean.getBalance());
}
}
}

….
private MyBeanLocal lookupMyBeanLocal() {
try {
Context c = new InitialContext();
return (MyBeanLocal) c.lookup("java:global/MyWebApp/MyWebApp-
ejb/MyBean!myPkg.MyBeanLocal");
} catch (NamingException ne) {
Logger.getLogger(getClass().getName()).log(Level.SEVERE, "exception caught", ne);
throw new RuntimeException(ne);
}
}

}
Step 7 : Now right click the MyWebApp-ejb and deploy it. Again click on the node
MyWebApp and Run. The browser window will execute the application as
follows -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 67 Ruby and Rails

Select the operations as perform the transactions.

6.17.5 EJB Container and its Services


 The EJB container provides following services to EJB component -
Persistence
 The EJB container provides the persistence service. That means, EJB can save its
state in web container. The persistence services include simple connection pooling,
reading some data from databases to generate dynamic pages or update some
simple information. Writing data access code is error prone and time consuming.
Hence the enterprise beans are created by application development tools in such a
way that the data access logic will be encapsulated within the components. Due to
this service the real-world project can be benefited in terms of time, budget and
personal constraints.

Declarative Transactions
 Transaction management is complex if multiple data access components or multiple
data sources are involved. The EJB provides the transaction management service in
such a way that the complex transaction can be managed without any coding.
 The Java API - Java Transaction API (JTA) provides standard interface between
transaction manager, application server and component. There is another Java API
Java Transaction Service (JTS) which is directly used by the application
programmer.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 68 Ruby and Rails

Declarative Security

 It is most essential to have security for data and business logic functionality.
Usually application developers provide security using servlets or JSP pages. But
this is complex and error prone task. The EJB uses the simplified security model
due to which EJB resources can be protected from unauthorized access. The EJB
developer rely on security provided at the web level.

Error Handling

 The EJB offers clear and consistent error handling framework. The EJB specification
defines how errors affect transactions, client results, server logging and recovery of
components.

Component Framework for Business Logic


 The software that requires a complex business logic require large number of
enterprise resources. EJB are server side components that can be used
simultaneously by different clients. Using the EJB’s common framework for the
business logic the building of complex application is possible.

Scalability
 Using EJB specification rules it is possible for the application server to manage large
number of simultaneous clients. EJB specification is useful to satisfy the multiple
demands for business logic components and data access components.

Portability

 EJB’s are written to an industry standard API. Hence they can be run on any new
J2EE compliant application server. There is no need to modify the EJB components
for running them on application servers.

Manageability

 EJB container provides the facility to manage access, add or remove users from
appropriate role. Using EJB it is possible to manage secure access to every user
interface that provides the functionality of accessing the users.

6.17.6 EJB Interfaces

 In EJB, the client can access the session bean using the business interface.
Depending upon the location of client, there are two types of interfaces used -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 69 Ruby and Rails

1) Remote Interface : The remote interface is used by client that may be running on
different machine than the bean. Using Remote Method Interface (RMI) the
access to the bean can be made.
2) Local Interface : The local interface can be used by the client which is running on
the same machine where the bean is residing.
Various aspects while deciding between local and remote interface are represented in
the following table -

Aspect Use of Remote Interface Use of Local Interface

Type of client If the clients are application If the clients are either web components or
clients, web components or EJBs EJBs executing on the same machine.
executing on different machine.

Protocol used If the RMI used for If the local function calls are used for
communication. communication.

Component If the component in the If the components are located on the same
distribution application are distributed, that machine where bean is present.
means present on different
machines.

Loose or tight If the client and bean are coupled If there is a requirement of tight coupling
coupling loosely. between EJB components.

Performance Slow performance due to RMI Better performance due to local calls.
calls.

Location If the client need not know the If the client wants to know that the current
transparency location of EJB and access it machine is the location of EJB.
transparently.

Communication If multiple objects are passed by If objects are passed by reference and the
value so that client and bean can client or bean can change the value of the
operate on different copies of the same object.
object.

Serialization If the serialized objects are passed. If the objects are not serialized.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 70 Ruby and Rails

6.17.7 EJB Clients

 EJB is the server-side and platform-independent Java Application Programming


Interface (API) for Java Platform, Enterprise Edition (Java EE). EJB is used to
simplify the development of large distributed applications. EJB client is a code
which will use the EJB functionality. Clients cannot create objects of EJB class
component. Clients can access any EJB only through the EJB container. Some of the
EJB clients are as follows -
1) Java Applications
2) Other EJBs on same or another application server.
3) Java Applets
4) A web service can access EJB
5) Servlets, JSP- some server side technologies.

Review Questions

1. Decide and explain various aspects while deciding between local and remote interface can be
considered. SPPU : May-18, Marks 8
2. What is enterprise Java Bean ? Draw and explain main components of EJB architecture.
SPPU : May-18, Marks 8
3. Draw and explain the role of EJB container in enterprise applications.
SPPU : May-18, Marks 6
4. Draw and explain scenario of client accessing remote EJB. List some of the EJB clients.
SPPU : Dec.-18, May-19, Marks 8
5. Draw and explain each tier of three tiers architecture using EJB.
SPPU : May-19, Marks 8

6.18 Multiple Choice Questions


Q.1 Ruby is a ___.
a scripting language
b server side programming language
c object oriented programming language
d procedural programming language
Q.2 ___ method in ruby removes the last character.
a Pop b Remove
c Del d Chop

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 71 Ruby and Rails

Q.3 ___ method in ruby is used to insert the element from the end.
a Insert b Push
c Put d None of these
Q.4 What is the extension used for saving the ruby file ?
a .ruby b .rb
c .ry d None of these
Q.5 Which of the following is valid conditional statement in ruby ?
a elseif b elsif
c else if d elseiff
Q.6 What will any variable evaluate to if it is of Boolean data type ?
a True b NULL
c False d Either True or False
Q.7 Which services are provided to EJB components by the EJB container ?
a Transaction support b Persistence support
c Naming support d All mentioned above
Q.8 Session beans don't have _____.
a ejbCreate() method b ejbStore() method
c ejbRemove() method d none of these
Q.9 An entity bean's local interface MUST extend the ________ interface.
a javax.ejb.EJBLocalObject b javax.ejb.EJBObject
c javax.ejb.RemoteObject d none of the above
Q.10 What executes EJB components ?
a A web server b An application server
c An EJB container d A database server
Q.11 What represents a persistent global data from the database ?
a Entity bean b Session bean
c Both A & B d None of the above

Answer Keys for Multiple Choice Questions :

Q.1 c Q.2 d Q.3 b Q.4 b


Q.5 b Q.6 d Q.7 d Q.8 a
Q.9 a Q.10 c Q.11 a


TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology 6 - 72 Ruby and Rails

Notes

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology Laboratory
Contents
Experiment 1 : Design the XML document to store the information of the employees of any
business organization and demonstrate the use of :
a) DTD b) XML Schema
And display the content in (e.g., tabular format) by using CSS/XSL.. ...........L - 2
Experiment 2 : Implement an application in Java Script using following :
a) Design UI of application using HTML, CSS etc.
b) Include Java script validation
c) Use of prompt and alert window using Java Script
e.g., Design and implement a simple calculator using Java Script for operations
like addition, multiplication, subtraction, division, square of number etc.
a) Design calculator interface like text field for input and output, buttons for
numbers and operators etc.
b) Validate input values
c) Prompt/alerts for invalid values etc ...... ....................................................L - 4
Experiment 3 : Implement the sample program demonstrating the use of Servlet. e.g., create a
database table ebookshop (book_id, book_title, book_author, book_price,
quantity) using database like Oracle/MySQL etc. and display (use SQL select
query) the table content using servlet.... .. ....................................................L - 9
Experiment 4 : Implement the program demonstrating the use of JSP. e.g., Create a database
table students_info (stud_id, stud_name, class, division, city) using database like
Oracle/MySQL etc. and display (use SQL select query) the table content using
JSP........................................................... . ...................................................L - 9
Experiment 5 : Build a dynamic web application using PHP and MySQL.
a. Create database tables in MySQL and create connection with PHP.
b. Create the add, update, delete and retrieve functions in the PHP web app
interacting with MySQL database.. .......... ..................................................L - 13
Experiment 6 : Design a login page with entries for name, mobile number email id and login
button. Use struts and performs following validations
a. Validation for correct names
b. Validation for mobile numbers
c. Validation for email id
d. Validation if no entered any value
e. Re-display for wrongly entered values with message
f. Congratulations and welcome page upon successful entries.. ................L - 13
Experiment 7 : Design an application using Angular JS. e.g., Design registration (first name, last
name, username, password) and login page using Angular JS... ...............L - 21
Experiment 8 : Design and implement a business interface with necessary business logic for
any web application using EJB. e.g., Design and implement the web
application logic for deposit and withdraw amount transactions using EJB
................................................................. ..................................................L - 26

(L - 1)
Web Technology L-2 Web Technology Laboratory

Experiment 1 : Design the XML document to store the information of the employees
of any business organization and demonstrate the use of :
a) DTD
b) XML Schema
And display the content in (e.g., tabular format) by using CSS/XSL.

Solution : a) Employee DTD

Employee.dtd
<!DOCTYPE Person[
<!ELEMENT Person (Employee+)>
<!ELEMENT Employee (EmpId,EmpName,Department)>
<!ELEMENT EmpId (#PCDATA)>
<!ELEMENT EmpName (#PCDATA)>
<!ELEMENT Department (#PCDATA)>
]>

b) Step 1 : The XML document containing employee information is as follows -


Employee.xml
<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" href="EmployeeSchema.xsl" ?>
<Person>
<Employee>
<EmpId>111</EmpId>
<EmpName>Archana</EmpName>
<Department>Accounts</Department>

</Employee>
<Employee>
<EmpId>222</EmpId>
<EmpName>Rashmi</EmpName>
<Department>Purchase</Department>

</Employee>
<Employee>
<EmpId>333</EmpId>
<EmpName>Sheetal</EmpName>
<Department>Sales</Department>

</Employee>
<Employee>
<EmpId>444</EmpId>
<EmpName>Aniket</EmpName>
<Department>Marketing</Department>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L-3 Web Technology Laboratory

</Employee>
</Person>

Step 2 : Display of information using xsl is done using following .xsl document.

Employeeschema.xsl

<?xml version="1.0" encoding="ISO-8859-1"?>

<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">

<xsl:template match="/">
<html>
<body>
<center>
<h2>Employee Information</h2>
<table border="1">
<tr bgcolor="gray">
<th>EmpId</th>
<th>EmpName</th>
<th>Department</th>
</tr>
<xsl:for-each select="Person/Employee">
<tr>
<td bgcolor="green"><xsl:value-of select="EmpId"/></td>
<td bgcolor="red"><b><xsl:value-of
select="translate(EmpName,'abcdefghijklmnopqrstuvwxyz','ABCDEFGHIJKLMNOPQRSTUVWXYZ')"/>
</b></td>
<td bgcolor="cyan"><xsl:value-of select="Department"/></td>
</tr>
</xsl:for-each>
</table>
</center>
</body>
</html>
</xsl:template>
</xsl:stylesheet>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L-4 Web Technology Laboratory

Experiment 2 : Implement an application in Java Script using following :


a) Design UI of application using HTML, CSS etc.
b) Include Java script validation
c) Use of prompt and alert window using Java Script
e.g., Design and implement a simple calculator using Java Script for
operations like addition, multiplication, subtraction, division, square
of number etc.
a) Design calculator interface like text field for input and output,
buttons for numbers and operators etc.
b) Validate input values
c) Prompt/alerts for invalid values etc.

Solution :

calci.html
<!DOCTYPE html>
<html>
<head>
<title> JavaScript and CSS Calculator </title>
<style>
.form_style
{
width: 300px;
height: 580px;
margin: auto;
border: 5px solid blue;
border-radius: 5px;
padding: 20px;
}
input
{
width: 20px;
background-color: grey;
color: white;
border: 3px solid black;
border-radius: 5px;
padding: 28px;
margin: 5px;
font-weight:bold;
font-size: 15px;
}
#calculate
{
width: 250px;
background-color: khaki;
color:black;

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L-5 Web Technology Laboratory

border: 5px solid black;


border-radius: 3px;
padding: 20px;
margin: auto;
}
#equal_to
{
width: 210px;
border: 3px solid gray;
border-radius: 3px;
padding: 26px;
background-color: skyblue;
}
</style>
</head>
<body>
<div class= "form_style">
<form name = "myform">
<input id = "calculate" type ="text" name = "answer"> <br> <br>
<input type = "button" value = "7" onclick = "display('7')">
<input type = "button" value = "8" onclick = "display('8')">
<input type = "button" value = "9" onclick = "display('9')">
<input type = "button" value = "+" onclick = "display('+') ">
<br> <br>

<input type = "button" value = "4" onclick = "display('4')">


<input type = "button" value = "5" onclick = "display('5')">
<input type = "button" value = "6" onclick = "display('6')">
<input type = "button" value = "-" onclick = "display('-')">
<br> <br>

<input type = "button" value = "1" onclick = "display('1') ">


<input type = "button" value = "2" onclick = "display('2') ">
<input type = "button" value = "3" onclick = "display('3') ">
<input type = "button" value = "*" onclick = "display('*')">
<br> <br>

<input type = "button" value = "0" onclick = "display('0')">


<input type = "button" value = "." onclick = "display('.')">
<input type = "button" value = "C" onclick = "clear_all()">
<input type = "button" value = "/" onclick = "display('/')">
<br>

<input type = "button" value = "SQ" onclick = "square_val()">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L-6 Web Technology Laboratory

<input type = "button" value = "=" onclick = "result() " id= "equal_to" >
</form>
</div>
<script>
function display(val)
{
myform.answer.value +=val
}

function clear_all()
{
alert("You have clicked clear all button")
myform.answer.value = ' '
}

function square_val()
{
num=myform.answer.value
myform.answer.value = num*num
}

function result()
{
ans = eval(myform.answer.value)
if(ans==Infinity)
{
alert("divide by Zero")
myform.answer.value=' '
}
if(ans==undefined)
{
alert("Enter some input")
myform.answer.value=' '
}
else
myform.answer.value = ans
}
</script>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L-7 Web Technology Laboratory

Output

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L-8 Web Technology Laboratory

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L-9 Web Technology Laboratory

Experiment 3 : Implement the sample program demonstrating the use of Servlet.


e.g., Create a database table ebookshop (book_id, book_title,
book_author, book_price, quantity) using database like
Oracle/MySQL etc. and display (use SQL select query) the table
content using servlet.

Solution : Refer similar example 3.14.2.

Experiment 4 : Implement the program demonstrating the use of JSP. e.g., Create a
database table students_info (stud_id, stud_name, class, division,
city) using database like Oracle/MySQL etc. and display (use SQL
select query) the table content using JSP.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L - 10 Web Technology Laboratory

Solution :

Step 1 : Create a database named registration_DB using following command on the


MYSQL prompt
mysql>CREATE DATABASE registration_DB;
Then create a table under the database registration_DB as follows -
mysql>USE registration_DB;
mysql>CREATE TABLE registration_table(id INT(4) NOT NULL AUTO_INCREMENT, name
VARCHAR(50) NOT NULL,
email VARCHAR(50) NOT NULL,
phone VARCHAR(10) NOT NULL,
PRIMARY KEY(id));
The created table fields can be seen using following command.
mysql>DESCRIBE registration_table;

Step 2 : The JSP page containing the input entry form is as given below. On this JSP page
itself we are retrieving the values from the database by connection to it.
Registration_Form.jsp
<%@ page language="java" import="java.sql.*" %>
<%@ page import="java.io.*" %>
<%
Connection conn=null;
ResultSet rs=null;
Statement stmt=null;
Class.forName("com.mysql.jdbc.Driver").newInstance();
conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/registration_DB",
"root","system");
out.write("Connected to mysql!!!");
stmt=conn.createStatement();
if(request.getParameter("action") != null)
{
String Studname=request.getParameter("Studname");
String Studemail=request.getParameter("Studemail");
String Studphone=request.getParameter("Studphone");
stmt.executeUpdate("insert into registration_table(name,email,phone) values(' "+Studname+"
',' "+Studemail+" ',' "+Studphone+" ')" );
rs=stmt.executeQuery("select * from registration_table");
%>
<html>
<body>
<center>
<h2>Student List</h2>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L - 11 Web Technology Laboratory

<table border="1" cellspacing="0" cellpadding="0">


<tr>
<td><b>No</b></td>
<td><b>User Name</b></td>
<td><b>E-Mail</b></td>
<td><b>Phone</b></td>
</tr>
<%
int num=1;
while(rs.next()){
%>
<tr>
<td><%=num%></td>
<td><%=rs.getString("name")%></td>
<td> <%=rs.getString("email")%></td>
<td> <%=rs.getString("phone")%></td>
</tr>
<%
num++;
}
rs.close();
stmt.close();
conn.close();
%>
</table>
</center>
</body>
</html>
<%}else{%>
<html>
<head>
<title>Student Registartion Demo</title>
<script language="javascript">
function validation(Form_obj)
{
if(Form_obj.Studname.value.length==0){
alert("Please,fill up the remaining information!!"); Form_obj.Studname.focus();
return false;
}
if(Form_obj.Studemail.value.length==0){
alert("Please,fill up the remaining information!!");
Form_obj.Studaddress.focus();
return false;
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L - 12 Web Technology Laboratory

if((Form_obj.Studphone.value.length==0)||
(Form_obj.Studphone.value.length>10))
{
alert("Invalid Phone number Entry, fill up once again!!");
Form_obj.Studphone.focus();
return false;
}

return true;
}
</script>
</head>

<body>
<center>
<form action="Registration_Form.jsp" method="post"
name="entry" onSubmit="return validation(this)">
<input type="hidden" value="list" name="action">
<table border="3" cellpadding="0" cellspacing="0">
<tr>
<td>
<table>
<tr>
<td colspan="2" align="center">
<h2>Student Entry Form</h2></td>
</tr>
<tr>
<td colspan="2">&nbsp;</td>
</tr>
<tr>
<td>Student Name:</td>
<td><input name="Studname" type= "text" size="50"></td>
</tr>
<tr>
<td>Student Password:</td>
<td><input name="Studpass" type= "password" size="50"></td>
</tr>
<tr>
<td>E-Mail:</td>
<td><input name="Studemail" type="text" size="50"></td>
</tr>
<td>Phone:</td>
<td><input name="Studphone" type="text" size="15"></td>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L - 13 Web Technology Laboratory

</tr>
<tr>
<td colspan="2" align="center">
<input type="submit" value="Submit"></td>
</tr>
</table>
</td>
</tr>
</table>
</form>
</center>
</body>
</html>
<%}%>

Experiment 5 : Build a dynamic web application using PHP and MySQL.


a. Create database tables in MySQL and create connection with PHP.
b. Create the add, update, delete and retrieve functions in the PHP
web app interacting with MySQL database

Solution : Refer example 5.16.1

Experiment 6 : Design a login page with entries for name, mobile number email id
and login button. Use struts and performs following validations
a. Validation for correct names
b. Validation for mobile numbers
c. Validation for email id
d. Validation if no entered any value
e. Re-display for wrongly entered values with message
f. Congratulations and welcome page upon successful entries

Solution : In this web application using struts2 we will create two JSP files and one Java
action file. Moreover, we will create two configuration files named struts.xml and
web.xml. For understanding the locations of these files refer the following screenshot.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L - 14 Web Technology Laboratory

Following are the steps to be followed to build the login validation web application.

Sep 1 : Start Eclipse. Create Dynamic Web Project. Copy the required jar files to WEB-
INF/lib folder.
Now Create a Login Page using JSP. This file is created in WebContent or webapp.
This page displays the login form with the textfields such as name, mobile number and
email-id. The code for this JSP script is as follows -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L - 15 Web Technology Laboratory

LoginPg.jsp
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<%@taglib uri="/struts-tags" prefix="s" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Login Page Demo</title>
<s:head />
</head>
<body>
<s:form action="Login" validate="true">
<s:textfield name="userName" label="User Name" />
<s:textfield name="mobileNum" label="Mobile Number" />
<s:textfield name="email" label="Email ID" />

<s:submit value="Login" />


</s:form>
</body>
</html>

Step 2 : Create one more JSP document under WebContent or webapp folder named
Welcome.jsp. This JSP file is for displaying welcome message for authentic user. The
code is
Welcome.jsp
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<%@taglib uri="/struts-tags" prefix="s"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>login Page Demo</title>
</head>
<body>
<h1>Congratulations!!! </h1>
<h2>Welcome, User <s:property value="userName"/>!!!</h2>
</body>
</html>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L - 16 Web Technology Laboratory

Step 3 : Now we will write the Java File for validating the user name, mobile number and
email-id.
The validation for empty fields, or incorrect values is done in this program. If user
enters incorrect values then the error message is displayed with the incorrect values
which user has entered. If user does not enter the values and press the login button, then
error message is displayed for the corresponding fields. If the user enters correct user
name, correct mobile number and correct email-id then only he/she is redirected to
welcome page. This validation is done inside validate() function
The code for this Java program is as follows -
LoginProg.java
package myPkg;
import com.opensymphony.xwork2.ActionSupport;

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class LoginProg extends ActionSupport{


private String userName;
private String mobileNum;
private String email;
public String execute() {
return SUCCESS;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getMobileNum() {
return mobileNum;
}
public void setMobileNum(String mobileNum) {
this.mobileNum = mobileNum;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L - 17 Web Technology Laboratory

public void validate() {


//validating user name
if (getUserName().length() == 0) {
addFieldError("userName", "User Name is required");
}
else if (!getUserName().equals("Admin")) {
addFieldError("userName", getText(userName)+" is not authentic user name");
}
//validating mobile number
if (getMobileNum().length() == 0) {
addFieldError("mobileNum", "Mobile Number is required");
}
else if(getMobileNum().length()!= 10)
addFieldError("mobileNum", getText(mobileNum)+" is invalid Mobile Number");
else if (!getMobileNum().equals("1234567890")) {
addFieldError("mobileNum", getText(mobileNum)+" is not authentic mobile number");
}
//validating email-id
if (getEmail().length() == 0) {
addFieldError("email", "Email-ID is required");
}
else if (!getEmail().equals("[email protected]")) {
addFieldError("email", getText(email)+" is not authentic email-id");
}
else {
String expression="^[\\w\\-]([\\.\\w])+[\\w]+@([\\w\\-]+\\.)+[A-Z]{2,4}$";
CharSequence inputStr = email;
Pattern pattern = Pattern.compile(expression,Pattern.CASE_INSENSITIVE);
Matcher matcher = pattern.matcher(inputStr);
if(!matcher.matches())
addFieldError("email","Invalid email address");
}
}
}

Step 4 : Now we will write the configuration files. The struts.xml file under the WEB-
INF/classes folder will be -
Struts.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L - 18 Web Technology Laboratory

<struts>
<constant name="struts.custom.i18n.resources" value="LoginProg" />
<package name="default" extends="struts-default" namespace="/">
<action name = "Login"
class = "myPkg.LoginProg"
method = "execute">
<result name = "success">/Welcome.jsp</result>
<result name = "input">/LoginPg.jsp</result>
</action>
</package>
</struts>

Step 5 : The web.xml file present inside the WEB-INF folder is modified as -

web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-
app_3_1.xsd"
id="WebApp_ID" version="3.1">
<display-name>Struts2</display-name>
<welcome-file-list>
<welcome-file>LoginPg.jsp</welcome-file>
<welcome-file>Welcome.jsp</welcome-file>
</welcome-file-list>
<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.FilterDispatcher
</filter-class>
</filter>

<filter-mapping>

<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

</web-app>

Step 6 : For executing the above application right-click on project name(here it is test) in
the Project Explorer window, click on Run As->Run Configuration. Set the tomcat(under
Apache) which is available on your machine.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L - 19 Web Technology Laboratory

Then right click on the project name and click Export > WAR File to create a War file.
Then deploy this WAR in the Tomcat's webapps directory. For a destination click the
Browse button and select the path c:/your_tomcat_directory/webapps folder by accepting
the default name of the war file. Normally "your_project_name.war" file gets generated.
Here we get test.war in the c:/tomcat_directory/webapps. The output can be viewed on a
browser window by typing the URL for localhost. Note that as my tomcat is running on
port 8082(default is 8080 port, but you can change the port number if you want), I am
giving the URL with localhost:8082
We will first check various invalid entries. Refer following screenshots -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L - 20 Web Technology Laboratory

Now we will enter all the authentic and valid entries and get the welcome page

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L - 21 Web Technology Laboratory

Experiment 7 : Design an application using Angular JS. e.g., Design registration


(first name, last name, username, password) and login page using
Angular JS.

Solution :

Step 1 : Create a javascript(.js) that defines the configurations and controllers written
using AngularJS. This file directs to respective homepage, registration or login page,
when the link for homepage, registration page or login page is clicked.

appDemo.js
var app = angular.module('myApp', ['ngRoute']);
app.config(function($routeProvider) {
$routeProvider
.when('/', {
templateUrl : 'home.html',
controller : 'HomeController'
})
.when('/registration', {
templateUrl : 'registration.html',
controller : 'RegistrationController'
})
.when('/login', {
templateUrl : 'login.html',

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L - 22 Web Technology Laboratory

controller : 'LoginController'
})
.otherwise({redirectTo: '/'});
});
app.controller('HomeController', function($scope) {
$scope.message = 'Welcome to a home page';
});

app.controller('RegistrationController', function($scope) {
$scope.message = 'Please fill up the Registration form(New User)';
});
app.controller('LoginController', function($scope) {
$scope.message = 'Please fill up the Login form(Existing User)';
});

Step 2 : Create a view in HTML file. The AngularJS script is as follows -

appDemo.html
<!DOCTYPE html>
<html ng-app="myApp">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"
href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.4.7/angular.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.4.7/angular-route.min.js"></script>
</head>
<body ng-app="myApp">
<div class = "row">
<div class = "col-sm-12 well">
<center><h1>OUR WEB SITE</h1></center>
</div>
</div>
<div class="row">
<div class ="col-sm-4 well" style = "background-color:pink;height:500px">
<ul>
<li><a href="#/">Home</a></li>
<li><a href="#/registration">Registration</a></li>
<li><a href="#/login">Login</a></li>
</ul>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L - 23 Web Technology Laboratory

</div>
<div class ="col-sm-8 well" style="background-color:aqua;height:500px">
<div ng-view></div>

</div>
</div>
<script src="appDemo.js"></script>
</body>
</html>

Step 3 : Now the HTML documents for home page, registration page and login page is as
follows.
home.html
<div>
<center><h3>{{message}}</h3></center> Message for home page
</div>

<div>
<center>
<img src="welcome.jfif"> Displaying image on welcome page
</center>
</div>
registration.html
<html>
<head>
<title>
Registration Form
</title>
</head>
<body>
<h3>{{message}}</h3>
<form>
<p>First Name:<input type="text" name="fname"></p>
<p>Last Name:<input type="text" name="lname"></p>
<p>User Name:<input type="text" name="username"></p>
<p>Password:<input type="password" name="password"></p>
<p><input type="submit" value="submit"></p>
</form>
</body>
</html>
login.html
<html>
<head>

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L - 24 Web Technology Laboratory

<title>
Login Form
</title>
</head>
<body>
<h3>{{message}}</h3>
<form>
<p>User Name:<input type="text" name="username"></p>
<p>Password:<input type="password" name="password"></p>
<p><input type="submit" value="submit"></p>
</form>
</body>
</html>

Step 4 : Make a separate directory and store above files (from step 1 to step 3) in it. It is
preferable to store this folder in your Apache’s htdocs folder. Open the web browser and
give the URL for appDemo.html document. The output can be viewed as follows -

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L - 25 Web Technology Laboratory

If we click on Registration link on the left panel we get following registration form.

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology L - 26 Web Technology Laboratory

If we click on Login link present in the left pane then we get following login form.

Experiment 8 : Design and implement a business interface with necessary business


logic for any web application using EJB. e.g., Design and implement
the web application logic for deposit and withdraw amount
transactions using EJB.

Solution : Refer section 6.17.4.




TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


SOLVED MODEL QUESTION PAPER (In Sem)
Web Technology
T.E. (Computer Engineering) Semester - VI (As Per 2019 Pattern)

Time : 1 Hour] [Total Marks : 30


N. B. :
i) Attempt Q.1 or Q.2, Q.3 or Q.4.
ii) Neat diagrams must be drawn wherever necessary.
ii) Figures to the right side indicate full marks.
iv) Assume suitable data, if necessary.

Q.1 a) List and discuss any four HTTP commands. (Refer example 1.4.1) [4]

b) Define the terms - i) Web site ii) Web server iii) URL. (Refer example 1.7.1) [3]

c) Create a HTML document for a company home page and explain.


(Refer example 1.14.2) [8]
OR

Q.2 a) What is the difference between HTML and HTML5 ? (Refer section 1.19.2) [5]

b) How will you create a password field in HTML form ? (Refer example 1.18.1) [4]

c) How to you create a multi colour text on a web page using CSS ?
(Refer example 1.26.1) [6]

Q.3 a) Explain data types used in JavaScript. (Refer section 2.5) [4]

b) How to create object in JavaScript ? Explain with suitable example.


(Refer section 2.15) [3]

c) Write JavaScript to validate a for consisting of Name, Age, Address, EmailID, hobby
(check box), Gender(radio box), country(Drop down menu).
(Refer example 2.24.2) [8]
OR
Q.4 a) Demonstrate the use of load() method using jQuery. (Refer section 2.25.3) [3]
b) When to use jQuery ? What are the advantages and disadvantages of jQuery ?
(Refer section 2.25) [5]

c) Write a AngularJS document for creating a table. (Refer section 2.26.6) [7]

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


(M - 1)
Web Technology M-2 Solved Model Question Papers

SOLVED MODEL QUESTION PAPER (End Sem)


Web Technology
T.E. (Computer Engineering) Semester - VI (As Per 2019 Pattern)

1
Time : 2 Hours] [Total Marks : 70
2
N. B. :
i) Attempt Q.1 or Q.2, Q.3 or Q.4, Q.5 or Q.6, Q.7 or Q.8.
ii) Neat diagrams must be drawn wherever necessary.
ii) Figures to the right side indicate full marks.
iv) Assume suitable data, if necessary.

Q.1 a) What is the difference between server side scripting language and client side scripting
language. (Refer section 3.1) [5]

b) Write a Java servlet program which will display “welcome servlet” message.
(Refer section 3.3) [8]

c) Write HTML form to read user name and password. This data is sent to the servlet. If
the correct user name and password is given then welcome him/her by his/her name
otherwise display the message for invalid user. (Refer example 3.7.2) [5]

OR

Q.2 a) Enlist the steps for connectivity between servlet and database.
(Refer section 3.14.3) [5]

b) What are the strengths of XML technology ? Also list the limitations of XML.
(Refer section 3.15) [5]

c) Write AJAX script to obtain the student information stored in XML document. The
information should be displayed on clicking the button. It should be displayed in
tabular form. (Refer example 3.26.1) [8]

Q.3 a) Write advantages of JSP over servlets. Also explain the life cycle of JSP.
(Refer section 4.2) [5]

b) Explain the scripting elements in JSP. (Refer section 4.3.6) [5]

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology M-3 Solved Model Question Papers

c) What is MVC ? Draw and explain MVC architecture for developing web applications.
(Refer section 4.6) [7]

OR

Q.4 a) Write a short note on SOAP. (Refer section 4.10) [5]

b) Draw and explain neat diagram which depicts MVC to struts architecture.
(Refer section 4.12) [5]

c) Write a client server JSP program to find the simple interest and display the result in
the client. (Refer example 4.5.1) [7]

Q.5 a) Classify data types of PHP and describe various data types. (Refer section 5.3) [4]

b) Explain how session and cookies are used for session management in PHP.
(Refer sections 5.14 and 5.15) [8]

c) What is associative arrays in PHP ? Explain it with the help of simple PHP code.
(Refer section 5.8) [6]

OR

Q.6 a) Identify and explain steps involved in connecting to MySQL with PHP.
(Refer section 5.16) [8]

b) How does ASP.NET works ? Also enlist the features of ASP.NET.


(Refer section 5.19) [5]

c) Explain the life cycle of ASP.NET application. (Refer section 5.22.1) [5]

Q.7 a) Explain the scalar types and their operations in ruby. (Refer section 6.2) [6]

b) Write a program in rails for displaying the current date and time.
(Refer section 6.12.2) [6]

c) Write a ruby program to add two numbers. (Refer section 6.3.2) [5]

OR

Q.8 a) Write a ruby program that sorts the array and searches the desired element from
array. (Refer section 6.5.3) [8]

b) Explain how to write a student class in ruby program. (Refer section 6.8.1) [9]



TECHNICAL PUBLICATIONS® - an up-thrust for knowledge


Web Technology M-4 Solved Model Question Papers

TECHNICAL PUBLICATIONS® - an up-thrust for knowledge

You might also like