Bapuji Educational Association (Regd.
)
Bapuji Institute of Engineering and Technology
Department of Computer Science and Engineering
WEB TECHNOLOGY LABORATORY
WITH
MINI PROJECT (17CSL77)
VII Sem CSE
LAB MANUAL
(2020-2021)
1. Write a JavaScript to design a simple calculator to perform the following
operations: sum, product, difference and quotient
Write a JavaScript that calculates the squares and cubes of the numbers from 0 to 10
2. and outputs HTML text that displays the resulting values in an HTML table format.
Write a JavaScript code that displays text “TEXT-GROWING” with increasing font
3. size in the interval of 100ms in RED COLOR, when the font size reaches 50pt it
displays “TEXT-SHRINKING” in BLUE color. Then the font size decreases to 5pt.
Develop and demonstrate a HTML5 file that includes JavaScript script that uses
4. functions for the following problems:
a. Parameter: A string
Output: The position in the string of the left-most vowel
b. Parameter: A number
Output: The number with its digits in the reverse order
Design an XML document to store information about a student in an engineering
5. college affiliated to VTU. The information must include USN, Name, and Name of
the College, Branch, Year of Joining, and email id. Make up sample data for 3
students. Create a CSS style sheet and use it to display the document.
6. Write a PHP program to keep track of the number of visitors visiting the web page
and to display this count of visitors, with proper headings.
7. Write a PHP program to display a digital clock which displays the current time of
the server.
Write the PHP programs to do the following:
8. a. Implement simple calculator operations.
b. Find the transpose of a matrix.
c. Multiplication of two matrices.
d. Addition of two matrices.
Write a PHP program named states.py that declares a variable states with value
9. "Mississippi Alabama Texas Massachusetts Kansas". write a PHP program that does
the following:
a. Search for a word in variable states that ends in xas. Store this word in element 0 of
a list named statesList.
b. Search for a word in states that begins with k and ends in s. Perform a case
insensitive comparison. [Note: Passing re.Ias a second parameter to method compile
performs a case-insensitive comparison.] Store this word in element1 of statesList.
c. Search for a word in states that begins with M and ends in s. Store this word in
element 2 of the list.
d. Search for a word in states that ends in a. Store this word in element 3 of the list.
10. Write a PHP program to sort the student records which are stored in the database using
selection sort.
1. Write a JavaScript to design a simple calculator to perform the following operations:
sum, product, difference and quotient
Explanation:
This program demonstrates the use of embedding Javascript inside a webpage designed using
HTML. The usefulness of Java script in client-side computations for small tasks, displaying results
in its own graphical window, rendering the output to the web pages dynamically and requesting
for input from the user are illustrated through this program.
Program : HTML File (1.html)
<html>
<script type=”text/javascript” src=”1.js”>
</script>
<body>
<table border=”2pt”>
<tr >
<td colspan=4><input type=text id=res size=16 onfocus="this.blur();"></td>
</tr>
<tr>
<td><input type=button id=b1 value=0 size=2 onclick=f('0')></td>
<td><input type=button id=b2 value=1 size=2 onclick=f('1')></td>
<td><input type=button id=b3 value=2 size=2 onclick=f('2')></td>
<td><input type=button id=b4 value=+ size=2 onclick=f('+')></td>
</tr>
<tr>
<td><input type=button id=b5 value=3 size=2 onclick=f('3')></td>
<td><input type=button id=b6 value=4 size=2 onclick=f('4')></td>
<td><input type=button id=b7 value=5 size=2 onclick=f('5')></td>
<td><input type=button id=b8 value=- size=2 onclick=f('-')></td>
</tr>
<tr>
<td><input type=button id=b9 value=6 size=2 onclick=f('6')></td>
<td><input type=button id=b10 value=7 size=2 onclick=f('7')></td>
<td><input type=button id=b11 value=8 size=2 onclick=f('8')></td>
<td><input type=button id=b12 value=* size=2 onclick=f('*')></td>
</tr>
<tr>
<td><input type=button id=b13 value=9 size=2 onclick=f('9')></td>
<td><input type=button id=b14 value=+/- size=2 onclick=f('--')></td>
<td><input type=button id=b15 value='=' size=2 onclick=f('=')></td>
<td><input type=button id=b16 value='/' size=2 onclick=f('/')></td>
</tr>
<tr>
<td colspan=4 ><input type=button value=Clear size=16 onclick=f('c')></td>
</tr>
</table>
</body>
</html>
Java script Code: (1.js)
function f(d)
{
if(d=='c')
{
document.getElementById('res').value="";
return;
}
res=document.getElementById('res').value;
if(res==0 && d==0)
return;
if(d=='+' || d=='-' || d=='*' || d=='/')
{
opr=d;
num=parseFloat(res);
document.getElementById('res').value=d;
return;
}
if(d=='=')
{
num1=parseFloat(res);
switch(opr)
{
case '+': ans=num+num1; break;
case '-': ans=num-num1; break;
case '*': ans=num*num1; break;
case '/': ans=parseInt(num/num1); break;
}
document.getElementById('res').value=ans;
return;
}
if(d=='--')
{
document.getElementById('res').value*=-1;
return;
}
if(!isNaN(document.getElementById('res').value))
document.getElementById('res').value+=d;
else
document.getElementById('res').value=d;
}
Output:
2. Write a JavaScript that calculates the squares and cubes of the numbers from 0 to 10
and outputs HTML text that displays the resulting values in an HTML table format.
Explanation:
This program aims at demonstrating the usefulness of Java script in generating dynamic
web pages using Java script. Accepting user input as web page loads is also demonstrate
in this program. This script also illustrates validation using Java script.
Program: HTML File: (2.html)
<html>
<script type=text/javascript src=2.js>
</script>
<body onload=sc()>
</body>
</html>
Java script Code: (2.js)
function sc()
{
rng=prompt('Enter the range');
res=rng.split("-");
if(res.length!=2)
{
alert("invalid range ");
return;
}
first=parseInt(res[0]);
second=parseInt(res[1]);
if(first>second)
{
alert("invalid range ");
return;
}
str="<table border=2><tr><th>Number</th><th>Square</th><th>Cube</th></tr>";
for(i=first;i<=second;i++)
{
str=str+"<tr><td>"+i+"<td>"+(i*i)+"<td>"+(i*i*i);
}
document.write(str);
}
Output:
3. Write a JavaScript code that displays text “TEXT-GROWING” with increasing font size in the interval of 100ms
in RED COLOR, when the font size reaches 50pt it displays “TEXT-SHRINKING” in BLUE color. Then the font
size decreases to 5pt.
Explanation:
This program brings out the event handling capabilities of Java script. Timer event handling using Java script is
explained in this program. Further, the use of style attributes in HTML and Java script is demonstrated. This program
also brings out usefulness of Java script in handling dynamic positioning of elements in HTML page. These give the
life to a web page and make it engaging.
Program: HTML (3.html)
<html>
<script type=text/javascript src=3.js>
</script>
<body onload=fnts()>
<p id="p1" style="font-size:12pt;color=black"> TEXT-GROWING </p>
</body>
</html>
Java script code (3.js)
var grow=true;
function fnts()
{
fntsize=document.getElementById("p1").style.fontSize;
document.getElementById("p1").style.color="red";
ifntsize=parseInt(fntsize);
window.setTimeout(fntGS,100,ifntsize);
}
function fntGS(ifs)
{
if(grow)
{
ifs=ifs+1;
if(ifs<=50)
{
document.getElementById("p1").style.fontSize=ifs+"pt";
}
else
{
grow=false;
document.getElementById("p1").style.color="blue";
document.getElementById("p1").innerHTML="TEXT-
SHRINKING"; }
}
else
{
ifs=ifs-1;
if(ifs<5)
return;
document.getElementById("p1").style.fontSize=ifs+"pt";
}
window.setTimeout(fntGS,100,ifs); }
4. Develop and demonstrate a HTML5 file that includes JavaScript script that uses
functions for the following problems:
a. Parameter: A string
Output: The position in the string of the left-most vowel
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Demonstrating Java script
functions</title> </head>
<script type=text/javascript src=4a.js>
</script>
<body>
<section>
<h1>Finding left most vowel</h1>
<p>Enter a string: <input type=text id=t1></p>
<input type=button value=Find onclick = alert( leftv(document.getElementById('t1').value ))>
</section>
</body>
</html>
Java script (4a.js)
function leftv(str)
{
for(i=0;i<str.length;i++)
{
if(str.charAt(i)=='a' || str.charAt(i)=='e' || str.charAt(i)=='i' ||str.charAt(i)=='o' ||
str.charAt(i)=='u' )
return ("Left most vowel of " + str + " is at location " + (i+1) );
}
return ("No vowels found for string "+ str);
}
Output:
b. Parameter: A number
Output: The number with its digits in the reverse order
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Demonstrating Java script
functions</title> </head>
<script type=text/javascript src=4b.js>
</script>
<body>
<section>
<h1>Reverse a Number</h1>
<p>Enter a string: <input type=text id=t2></p>
<input type=button value=reverse onclick = alert( rev(document.getElementById('t2').value
))> </section>
Java script (4b.js)
function rev(num)
{
rnum=0;
temp=num;
if(isNaN(num))
{
return "invalid number";
}
while(num!=0)
{
rnum *= 10;
rnum+= num % 10;
num -= num % 10;
num = Math.floor(num/10);
}
return "Reverse of num "+ temp + " is " + rnum;
}
5. Design an XML document to store information about a student in an engineering college
affiliated to VTU. The information must include USN, Name, and Name of the College,
Branch, Year of Joining, and email id. Make up sample data for 3 students. Create a CSS
style sheet and use it to display the document.
Stu.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE student[
<!ELEMENT ad (usn,name,collegename,branch,year,email)>
<!ELEMENT usn (#PCDATA)> <!ELEMENT name
(#PCDATA)>
<!ELEMENT collegename (#PCDATA)>
<!ELEMENT branch (#PCDATA)>
<!ELEMENT year (#PCDATA)>
<!ELEMENT email (#PCDATA)>
<!ELEMENT label (#PCDATA|email|year|branch|collegename|usn)*>
<!ELEMENT h3 (#PCDATA)>
<!ELEMENT h2 (#PCDATA)>
]>
<?xml-stylesheet type="text/css" href="5.css"?>
<stud_info>
<h3> Student-Information</h3>
<h2>Student 1</h2>
<ad><label>USN:<usn>4bd06499</usn></label></ad>
<ad><label>Name:<name>AAA</name></label></ad>
<ad><label>College:<college>BIET,Dvg</college></label></ad>
<ad><label>Branch:<branch>CSE</branch></label></ad>
<ad><label>Year of Joining:<year>2007</year></label></ad>
<ad><label>Email-ID:<email>aaa@gmail.com</email></label></ad>
<h2> Student 2</h2>
<ad><label>USN:<usn>4bd06499</usn></label></ad>
<ad><label>Name:<name>BBB</name></label></ad>
<ad><label>College:<college>BIET,Dvg</college></label></ad>
<ad><label>Branch:<branch>CSE</branch></label></ad>
<ad><label>Year of Joining:<year>2007</year></label></ad>
<ad><label>Email-ID:<email>bbb@gmail.com</email></label></ad>
</stud_info>
5.css
ad {display:block; margin-top:15px; color:blue; font-
size:13pt;} usn {color:red; font-size:12pt; margin-left:15px;}
name {color:red; font-size:12pt; margin-left:15px;}
college {color:red; font-size:12pt; margin-left:15px;}
branch {color:red; font-size:12pt; margin-left:15px;}
year {color:red; font-size:12pt; margin-left:15px;}
email {color:red; font-size:12pt; margin-left:15px;}
h3 {margin-center:15px; color:red; font size:18py;}
h2 {display:block; color:black; font-size:18pt;}
6. Write a PHP program to keep track of the number of visitors visiting the web page and to
display this count of visitors, with proper headings.
Explanation:
With server side technologies, server executes the program (PHP) and sends output to browser.
This program using PHP gives the most commonly used script in web-site design i.e keeping
track of the number of visitors of a web page. File handling capabilities of PHP is also
demonstrated.
PHP program (6.php)
<?php
$handle = fopen("counter.txt", "r");
if(!$handle){
echo "could not open the file" ;
}
else {
$counter = ( int ) fread ($handle,20) ;
fclose ($handle) ;
$counter++ ;
echo" <strong> you are visitor no ". $counter . " < /strong > " ; $handle =
fopen("counter.txt", "w" ) ;
fwrite($handle,$counter) ;
fclose ($handle) ;
}
?>
Note: Create counter.txt file. (give permission to both the files php and the .txt file)
Output:
7. Write a PHP program to display a digital clock which displays the current time of the server.
Explanation
This program fetches the current time from the server. The automatic page refreshing ability of
PHP programs based on timers is demonstrated. This feature can be exploited in any online exam
scenarios which are time bound and server time should be shown continuously .
PHP program (7.php)
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="refresh" content="1"/>
<style>
p{
color:white;
font-size:90px;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
body{background-color:black;}
</style>
<p> <?php echo date(" h: i : s A");?> </p>
</head>
Output:
8. Write the PHP programs to do the following:
a. Implement simple calculator operations.
Program8a.php
<html>
<head>
<style>
table, td, th
{
border: 1px solid black;
width: 35%;
text-align: center;
background-color: Gray;
}
table { margin: auto; }
input,p { text-align:right; }
</style>
</head>
<body>
<form method="post">
<table>
<caption><h2> SIMPLE CALCULATOR </h2></caption>>
<tr><td>First Number:</td><td><input type="text" name="num1" /></td>
<td rowspan="2"><input type="submit" name="submit" value="calculate"></td></tr>
<tr><td>Second Number:</td><td><input type="text" name="num2"/></td></tr>
</form>
<?php
if(isset($_POST['submit'])) // it checks if the input submit is filled
{
$num1 = $_POST['num1'];
$num2 = $_POST['num2'];
if(is_numeric($num1) andis_numeric($num1) )
{
echo "<tr><td> Addition :</td><td><p>".($num1+$num2)."</p></td>";
echo "<tr><td> Subtraction :</td><td><p> ".($num1-$num2)."</p></td>";
echo "<tr><td> Multiplication :</td><td><p>".($num1*$num2)."</p></td>";
echo "<tr><td>Division :</td><td><p> ".($num1/$num2)."</p></td>";
echo "</table>";
}
else
{
echo"<script type='text/javascript' > alert(' ENTER VALID NUMBER');</script>";
}
} ?> </body> </html>
b. Find the transpose of a matrix.
c. Multiplication of two matrices.
d. Addition of two matrices.
<?php
$a = array(array(1,2,3),array(4,5,6),array(7,8,9));
$b = array(array(7,8,9),array(4,5,6),array(1,2,3));
$m=count($a);
$n=count($a[2]);
$p=count($b);
$q=count($b[2]);
echo "the first matrix :"."<br/>";
for ($row = 0; $row < $m; $row++) {
for ($col = 0; $col < $n; $col++)
echo " ".$a[$row][$col];
echo "<br/>";
}
echo "the second matrix :"."<br/>";
for ($row = 0; $row < $p; $row++) {
for ($col = 0; $col < $q; $col++)
echo " ".$b[$row][$col];
echo "<br/>";
}
echo "the transpose for the first matrix
is:"."<br/>"; for ($row = 0; $row < $m; $row++) {
for ($col = 0; $col < $n; $col++)
echo " ".$a[$col][$row];
echo "<br/>";
}
if(($m= =$p) and ($n= =$q)) {
echo "the addition of matrices is:"."<br/>";
for ($row = 0; $row < 3; $row++) {
for ($col = 0; $col < 3; $col++)
echo " ".$a[$row][$col]+$b[$row][$col]." ";
echo "<br/>";
}
}
if($n= =$p){
echo " The multiplication of matrices:
<br/>"; $result=array();
for ($i=0; $i < $m; $i++) {
for($j=0; $j < $q; $j++){
$result[$i][$j] = 0;
for($k=0; $k < $n; $k++)
$result[$i][$j] += $a[$i][$k] * $b[$k][$j];
}
}
for ($row = 0; $row < $m; $row++) {
for ($col = 0; $col < $q; $col++)
echo " ".$result[$row][$col];
echo "<br/>";
}
}
?>
Output:
9. Write a PHP program named states.py that declares a variable states with
value "Mississippi Alabama Texas Massachusetts Kansas". write a PHP
program that does the following:
a) Search for a word in variable states that ends in xas. Store this word in element 0 of a list
named statesList.
b) Search for a word in states that begins with k and ends in s. Perform a case-insensitive
comparison. [Note: Passing re.Ias a second parameter to method compile performs a case-
insensitive comparison.] Store this word in element1 of statesList.
c) Search for a word in states that begins with M and ends in s. Store this word in element 2
of the list.
<?php
$states = "Mississippi Alabama Texas Massachusetts
Kansas"; $statesArray = [];
$states1 = explode(' ',$states);
echo "Original Array :<br>";
foreach ( $states1 as $i => $value )
print("STATES[$i]=$value<br>");
foreach($states1 as $state) {
if(preg_match( '/xas$/', ($state)))
$statesArray[0] = ($state);
}
foreach($states1 as $state) {
if(preg_match('/^k.*s$/i', ($state)))
$statesArray[1] = ($state);
}
foreach($states1 as $state) {
if(preg_match('/^M.*s$/', ($state)))
$statesArray[2] = ($state);
}
foreach($states1 as $state){
if(preg_match('/a$/', ($state)))
$statesArray[3] = ($state);
}
echo "<br><br>Resultant Array :<br>";
foreach ( $statesArray as $array => $value )
print("STATES[$array]=$value<br>");
?>
Output:
10. Write a PHP program to sort the student records which are stored in the
database using selection sort.
This program brings out the use of PHP in developing dynamic web pages. The web-application
required follows 3-tier architecture as shown in the figure below. Three tiers include Presentation
logic (HTML with CSS), Business logic (PHP) and Data access (MySQL). The choice of MySQL is
because its open source, light weight and platform independent.
PHP Program:
<?php
function selection_sort($data,$pos)
{
for($i=0; $i<count($data)-1; $i++) {
$min = $i;
for($j=$i+1; $j<count($data); $j++) {
if ($data[$j][$pos]<$data[$min][$pos]) {
$min = $j;
}
}
$data = swap_positions($data, $i, $min);
}
return $data;
}
function swap_positions($data1, $left, $right) {
for($j=0;$j<3;$j++)
{
$backup_old_data_right_value = $data1[$right][$j];
$data1[$right][$j] = $data1[$left][$j];
$data1[$left][$j] = $backup_old_data_right_value;
}
return $data1;
}
echo <<<END
<form action=10.php method=POST>
Student USN: <input type=text name=t1 size=15 maxlen=10><br>
Student Name:<input type=text name=t2 size=25><br>
Student CGPA::<input type=text name=t3 size=5><br>
<input type=submit name=ins value=Insert>
<input type=submit name=sname value=SortByName>
<input type=submit name=smarks value=SortByMarks>
</form>
END;
if (isset($_POST['ins']))
{
try{
$con="mysql:host=localhost;dbname=studentdb";
$pdo=new PDO($con,"root","");
$usn=$_POST['t1'];
$name=$_POST['t2'];
$marks=$_POST['t3'];
$sql="INSERT into student values('$usn','$name','$marks')";
$result=$pdo->query($sql);
echo "inserted...";
}
catch(Exception $e)
{
echo "DB Error"." ". $e;
}
}
if (isset($_POST['sname']))
{
try{
$student_data=array();
$con="mysql:host=localhost;dbname=studentdb";
$pdo=new PDO($con,"root",""); $sql="SELECT *
from student"; $result=$pdo->query($sql);
$cnt=0;
while(($row=$result->fetch()))
{
$student_data[$cnt][0]=$row['usn'];
$student_data[$cnt][1]=$row['name'];
$student_data[$cnt][2]=$row['cgpa'];
++$cnt;
}
$student_data=selection_sort($student_data,1);
echo "<table border><tr><th>USN<th>Name<th>CGPA</tr>";
for($j=0;$j<$cnt;$j++)
{
$usn=$student_data[$j][0];
$name=$student_data[$j][1];
$marks=$student_data[$j][2];
echo "<tr><td>$usn<td>$name<td>$marks";
}
}
catch(Exception $e)
{
echo "DB Error";
}
}
if (isset($_POST['smarks']))
{
try{
$student_data=array();
$con="mysql:host=localhost;dbname=studentdb";
$pdo=new PDO($con,"root",""); $sql="SELECT *
from student"; $result=$pdo->query($sql);
$cnt=0;
while(($row=$result->fetch()))
{
$student_data[$cnt][0]=$row['usn'];
$student_data[$cnt][1]=$row['name'];
$student_data[$cnt][2]=$row['cgpa'];
++$cnt;
}
$student_data=selection_sort($student_data,2);
echo "<table border><tr><th>USN<th>Name<th>CGPA</tr>";
for($j=0;$j<$cnt;$j++)
{
$usn=$student_data[$j][0];
$name=$student_data[$j][1];
$marks=$student_data[$j][2];
echo "<tr><td>$usn<td>$name<td>$marks";
}
}
catch(Exception $e)
{
echo "DB Error";
}
}
?>
Output: