Online Cake Shop: Bachelor of Science (Information Technology)
Online Cake Shop: Bachelor of Science (Information Technology)
Online Cake Shop: Bachelor of Science (Information Technology)
A Project Report
Submitted in partial fulfillment of the
Requirements for the award of the degree
of
BY
Assistant Professor
DEPARTMENT OF INFORMATION TECHNOLOGY
This is to certify that the project entitled, ―ONLINE CAKE SHOP, is bonafide work of Shruti
S o m p r a k a s h M i s h r a bearing Seat No:( ) submitted in partial fulfillment of the
requirements for the award of degree of BACHELOR OF SCIENCE IN INFORMATION
TECHNOLOGY from University of Mumbai.
External Examiner
Online Cake Shop this site is made to help the people. It helps peoples to do Cake shop
by staying at their home. It is possible for anybody to order any cake via internet and have the goods
delivered at his/her doorsteps quick and fast. Once an order is placed customer will receive their
order under given time.
Online Cake shop is made for make peoples life easier and happy. Online Cake Shop
provides users Custom cakes with good quality. It provides user to online payment option as
well as cash on delivery. customer will be asked to fill or select shipping address, a shipping
option, and payment information such as debit card. here the peoples get fresh cakes.
ACKNOWLEDGEMENT
This project is not possible without support of my honorable teachers. Firstly, I would
like to thank my project advisor Miss. Preeti Sarode, for guiding me through each and every
step of the process with knowledge and support.
Thank you for your advice, guidance and assistance. I would also like to thank my project
committee members, who showed immense patience andunderstanding throughout the project and
provided suggestions.
Finally, I would like to dedicate this project to my parents and my friends for their love,
encouragement and help throughout the project.
DECLARATION
I hereby declare that the project entitled, ―Online Cake Shop done at place where the
project is done, has not been in any case duplicated to submit to any other university for the award of
anydegree.
To the best of my knowledge other than me, no one has submitted to any other university.
The project is done in partial fulfillment of the requirements for the award of degree of BACHELOR OF
SCIENCE (INFORMATION TECHNOLOGY) to be submitted as final semester project aspart of our
curriculum.
1 Introduction 9-12
1.1 Objective 9
1.2 Feasibility Study 9
1.3 Objective Study 10
1.4 Purpose 10
1.5 Scope 11
1.6 Advantages 11
1.7 Applicability 12
1.8 Achievements 12
2 Survey of Technology 13-14
3 Requirement and Analysis 15-20
3.1 Problem Definition 15
3.2 Requirement Specification 15
3.3 Planning and Schedule 15
3.4 Event Table 18
4 System Design 19
4.1 Basic Module 20
4.2 Data Design 21
4.3 Logic Diagram 22
4.4 Test Cases 23
5 Implementation and Testing 24-34
5.1 Testing Approach 25-29
5.2 Coding Details and Code Efficiency 30-34
6 Results 35-44
7 Conclusion and Future Work 45-54
7.1 Advantages over Current System 46-49
7.2 Future Enhancement 50-52
7.3 Conclusion 53
7.4 System Maintenance 54
8 References 55
Chapter 1
Introduction
Background
Online Cake Shop is very familiar to everyone; it has simple design that everyone can access it.
There is another option for the user that is add to cart. Where user can add multiple cake items
to cart. At checkout time, the items in the shopping cart will be presented as an order. At that
time, more information will be needed to complete the transaction. Usually, the customer will
be asked to fill or select a billing address, a shipping address, a shipping option, and payment
information such as credit card number.
Online Cake Shop this site is made to help the people. It helps peoples to do shopping by
staying at their home. It is possible for anybody to order any products via internet and have
the goods delivered at his/her doorsteps quick and fast. Once an order is placed customer will
receive their order under given time.
Online Cake Shop is made for make peoples life easier and happy. Online Cake Shop provides
users custom cakes and fresh products. It provides user to online payment option as well as cash
on delivery, here the peoples get fresh products.
Objective
Our company will provide fresh cakes and services to our customers. It will save time and
money of customers who shop by this store online
SCOPE:
Time Scope:
Scope of this project is simple and connected to future development with customers and web
development features. We can view the rapid development of computer technology in almost all
field of operation and its use in relation of information management. It is more important to
look out this development also so we designed this who meet up with the demands of the
customers. It will also help in.
Online Cake Shop one of the popular website in current time. By this time people are
so much attracted towards online shop and do online shop
This is quite beneficial for people who don’t want have enough time to go out
for cakes, especially during hectic office hours.
A local cakes may not be open always 24 *7. But in online store customers can
place their order at any time for home delivery or takeaway, irrespective of the
timings.
This booking system provides you the flexibility and the easiness to update the
product you want at any time without any compilations.
By avoiding to shop online you make your time waste, it will save time as well as
money and make more productivity.
Online Cake Shop comes with many features. One of the important feature is that
it allows you to promote to your store that can attract more customers.
The basic need of any website is efficiency and simplicity. This website very efficient as
it provides easy browsing & data entry for user. User can easily view all relatedoperation
along with all relevant data. User can view details of pricing without going anywhere.
Chapter 2
Survey of Technologies
PHP:
PHP is an acronym for "PHP: Hypertext Pre-processor‖. It is a widely-used, open source
scripting language. Its scripts are executed on the server. It is free to download and use. It
is powerful enough to be at the core of the biggest blogging system on the web
(WordPress). It is deep enough to run the largest social network (Facebook). It is also easy
enough to be a beginner's first server-side language.
PHP is compatible with almost all servers used today (Apache, IIS, etc.
PHP runs on various platforms (Windows, Linux, Unix, Mac OS X, etc.
PHP is easy to learn and runs efficiently on the server side
MYSQL: -
MySQL is a fast, easy to use relational database. It is currently the most popular open-source
database. It is very commonly used in conjunction with PHP scripts to create powerful and dynamic server-
side applications.
MySQL is used for many small and big businesses. It is developed, marketed and supported by
MySQL AB, a Swedish company. It is written in C and C++.
Reasons of Popularity:
MySQL is an open-source database so you don't have to pay a single penny to use it.
MySQL is quicker than other databases so it can work well even with the large data set.
MySQL supports many operating systems with many languages like PHP, PERL, C, C++,
JAVA, etc.
MySQL uses a standard form of the well-known SQL data language.
MySQL is very friendly with PHP, the most popular language for web development.
MYSQL features: -
Database Mirroring
Data Partitioning
Online Indexing Operations
Fast Recovery
Chapter 3
The Feasibility study is a major part of this phase, Feasibility Study means selecting thebest
systemthatmeettheperformancerequirement.
Itisthemeasureofhowbeneficialorpracticalthedevelopmentofan
Information System would be to theorganization.
Ourstudyofthefeasibledevelopment ofthesoftwareisgoingtobeinterms of
the followingaspects
Operational Feasibility: -
Economic Feasibility:-
Equipment maintenance is also minimum.
Saving of paper work and manpower reduced.
Increased customerLoyalty.
Increased customersatisfaction.
This will growveryrapidly and economicallyitwill havepositive feedbacks,
Technical Feasibility: -
software Requirement is already available in present system Then my project is technical feasible.
My project is internally feasible as work present equipment current procedure&
existing software.
Existing system is based on manual work and all the process are done manually, so they
maintain registers and files for recording all the details of the system.
They maintain several registers for recording the entry of daily transactions such as billing of the
cakes to the clients, etc.
They maintain the record for their clients so they keep each and every information
regarding their regular clients in the master file. In the similar fashion they maintain the records
of their parties so they keep each and every information regarding their parties in the party
master file.
They keep the bill book or cash book to maintain the record for each sale of
the all groceries or transaction in the ONLINE CAKE SHOP. They also maintain the personal
book for each client for their personal transactions so when the after the month or year when the
client comes for the payment they see the book and make the bill.
Similarly, they maintain the book for their parties so they can pay the money to them
after some time. Thus maintaining party information, client information , party transaction
and all the things are done manually
3.2 Proposed System
The manual system of ―ONLINE CAKE SHOP‖ is to be computerized in order toovercome
the problems which affects the existing manual system.
Computerizing the existing system with the help of some programming language,
database package eases the work of the system up to a great extent.
The main objectives of the proposed system is to help the user. The system can be handy
tothe user in the following reasons: -
To provide quick and efficient means for performing billing related activities and
to effortlessly generate report of the system.
To automate the work such as billing, Client record, etc.
To automate the different types of reports.
CHARACTERSTIC OF THE PROPOSED SYSTEM: -
Easiness in modification of data :-The proposed system provides managing of huge data
effectively and efficiently for efficient results, storing the details of the customers, employees
etc. in such a way that the database can be modified.
User friendly:-The proposed system is user friendly because the retrieval and storing of data
is fast and data is maintained efficiently. Moreover, the graphical user interface is provided
in the proposed system, which provides user to deal with the system very easily.
Reports are easily generated :-Reports can be easily generated in a proposed system. So
any type of reports can be generated in a proposed system, which helps the managers in a
decisions-making activity.
No or very few paperwork:-The proposed system either does not require paper work or
very few paper works is required. All the data is feted into the computer immediately
andvarious bills and reports can be generated through computers. Since all the data is kept
in a database no data of the organization can be destroyed. Moreover, work becomes very
easy because there is no need to keep data on papers.
Support strategic competitive advantage :-Proposed system supports strategic competitive
advantages. Since the proposed systems provide easiness in reports generating it will
provide strategic advantages among competitors.
Computer operator control :- Computer operator control will be there no errors.
Moreover storing and retrieving of information is easy. So work can be done speedily
and in time.
3.2 Functional Specification
Admin:
- Manage user, seller and admin accounts.
Add Product and Product categories.
Update Product and Product categories.
Delete Product and Product categories.
User: -
Search various CAKE items.
User can add products to cart.
User can purchase All Type of Cake.
User can select and order Cakes.
Payment option by Cash on delivery, credit card, debit card.
3.3 Requirement Analysis
Hardware Requirements:
For the application to run on computer, the device is expected to meet the following system
requirements. The system requirements were categorized into hardware and software
requirements as shown in the tables.
Table 2: Minimum Software Requirements
Software Minimum Requirement Reason
Operating system Window 10 Globally distributed and
for computer widely accessed
Database management system SQL Server 2008 Easy to use and scalable
Browser Opera, Google Chrome IE Standard browser
Planning and Scheduling:
Project Search
Finalize
Project Requirment of
Project Scheduling of
Project
Gather Information
Built Prototype
Data and program module
System
DesignAll data flow
moduleReport
Designing Project
Coding Module
Testing
system Integration
Systen Testing
Complete Documentation
Install Program
Admin has the attributes admin_id and password,name. Admin can manage products and user accounts.
Admin can add new products, delete products and update their details. Admin can user by blocking him
or can view profile of all users.
Customer has attributes Customer_id ,Contact,name,password . A Customer can view products, add
products to cart for placing the order, then the order details and order_id is generated. Customer can now
proceed for Payment once the order is placed successfully.In payment section , Payment_id and
Payment details are generated. Customer is managed by Admin.
Represent attributes.
A flow chart is a type of diagram that represents an algorithm, workflow or process. The
flow chart shows the steps as boxes of various kinds, and their order by connecting the boxes with arrows.
This diagrammatically representation illustrate a solution model to a given problem. Flow charts are used
in analyzing, designing, documentation or managing a process or program in various fields.
Chapter 4: System Design
User Login:
Customer Phone number
Customer password
Purchase a product:
Select product
Enter the delivery address
Choose Payment Method
Order Details
Order Cancellation
Payment:
Select the payment method - Credit/Debit/Online Banking/COD
Card name
CVV
Expire
4.2 Schema Design:
4.4 Logical Diagram:
The above logical diagram show activities performed by a Customer. First customer will
search for a product, if he/she found the product then they can start viewing the product related
information. If they are interested in the product, then can start buying the product.
Algorithms Design:
Step 1: Open
Website Step 2:
Signup/Login
Step 3: Search/View the
Product Step 4: Buy the Product
Step 5: Select delivery Address
Step 6: Select Payment method
Step 7: View Order Details
Step 8: Repeat.
An actor is representing a user or another system that will interact with the system you are
modeling. A use case is an external view of the system that represents some action the user might
perform in order to complete a task
4.5 Use-case Diagram
For User
For Admin:
4.7 Sequence Diagram:
4.8 Tables
Signup:
User Registration:
Name Type Null/Not Null Key
Admin Table:
Name Type Null/Not Null Key
Payment:
Order Table:
Name NULL / NOTNULL TYPE KEY
Code:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Grocery Shop | Home</title>
<link href="https://fonts.googleapis.com/icon?family=Material+Icons" rel="stylesheet">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
<link rel="stylesheet"
href="https://cdnjs.cloudflare.com/ajax/libs/materialize/1.0.0/css/materialize.min.css">
<!-- Compiled and minified JavaScript -->
<link rel="stylesheet"
href="https://cdnjs.cloudflare.com/ajax/libs/font- awesome/4.7.0/css/font-
awesome.min.css">
<script
src="https://cdnjs.cloudflare.com/ajax/libs/materialize/1.0.0/js/materialize.min.js"></scrip
t>
<link rel="stylesheet" href="style.css">
</head>
<body>
<div class="outer white-text center-align">
<?php include("header.php");?>
<h4 style="font-family:Agency FB">SWEETS, SMOOTHIES & ICE CREAM</h4>
<div>
<img src="crazy.gif" alt="" width="350px" height="200px;">
</div>
<h3 style="font-family:Script MT;">This is the one where we let<br> ourselves go
wild!</h3>
</div>
<!-- Our menu -->
Code
<?php
include("db.php");
if(isset($_GET['id']))
{
$id = $_GET['id'];
$qry = mysqli_query($conn,"select * from products where id='$id'");
$data = mysqli_fetch_assoc($qry);
}
?>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<div class="outer white-text">
<?php
include("header.php");
?>
<div style="padding:50px;">
<h2 style="font-family:Script MT;"><?php echo $data['pname']; ?></h2>
<h5 class="col l6 s12 m6" style="font-family:Agency FB"><?php echo
$data['disc']; ?></h5>
</div>
</div>
<div class="row pink-text" style="background-
image:url('form_background.jpg');margin:0;">
<div class="col l4 s12">
<img src="products/<?php echo $data['image'];?>" alt="image"
style="width:100%;">
</div>
<div class="col l5 s12">
<p style="font-family:Algerian"><?php echo $data['pcategory']; ?></p>
<h3 style="font-family:Script MT;"><?php echo $data['pname']; ?></h3>
<h5>Rs. <?php echo money($data['price']).".00"; ?></h5>
<h5 style="font-family:Agency FB"><?php echo $data['disc']; ?></h5>
<div class="row">
<form action="addtocart.php" method="post">
<input class="col qty l2 browser-default" type="number"
name="qty" min="1" max="10" value="1" id="qty">
<input type="hidden" name="id" value="<?php echo $data['id'];?>">
<input type="submit" name="cart" value="Add To Cart" class="btn custom">
</form>
</div>
<div class="row inner">
<h5 class="head" style="font-family:Script MT;">Share on</h5>
<ul style="font-family:Script MT;">
<li><a href="#"><i class="fa fa-facebook"></i></a></li>
<li><a href="#"><i class="fa fa-instagram"></i></a></li>
<li><a href="#"><i class="fa fa-twitter"></i></a></li>
<li><a href="#"><i class="fa fa-pinterest"></i></a></li>
</ul>
</div>
</div>
</div>
</body>
</html>
Login Page
Code:
<?php
session_start();
error_reporting();
?>
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="style2.css">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/materialize/1.0.0/css/
materialize.min.css">
<!-- Compiled and minified JavaScript -->
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-
awesome/4.7.0/css/font-awesome.min.css"><script
src="https://cdnjs.cloudflare.com/ajax/libs/materialize/1.0.0/js/materialize.min.js"></scrip
t>
<style>
</style>
</head>
<body>
<h4 class="center-align">Login Form</h4>
<div class="container">
<div class="input-field">
<label for="phone">Phone Number</label>
<input type="number" class="phone" name="phone" required>
</div>
<div class="input-field">
<label for="psw">Enter Password</label>
<input type="password" name="password" required>
</div>
<div class="row">
<label>
<input type="checkbox" name="admin" />
<span>Login as Admin</span>
</label>
</div>
<div>
<button type="submit" name="login" class="btn">Login</button>
</div>
</div>
</body>
</html>
<?php
include("db.php");
if(isset($_POST['login']))
{
$phone = $_POST['phone'];
$upass = $_POST['password'];
$admin =
$_POST['admin'];
if($admin=="")
{
//chechink whether the user is registered or not
$user = mysqli_query($conn,"select * from signup where phone='$phone'");
$usercount =
mysqli_num_rows($user);
if($usercount<1)
{
echo '<script>alert("User Not registered");location.href="signup.php";</script>';
}
else
{
$qry = mysqli_query($conn,"select * from signup where phone='$phone' and
upass='$upass'");
$count =
mysqli_num_rows($qry);
if($count==1)
{
$_SESSION['phone'] = $phone;
echo '<script>location.href="index.php";</script>';
}
else
{
echo '<script>alert("Invalid Login");</script>';
}
}
}
else
{
//chechink whether the user is registered or not
$user = mysqli_query($conn,"select * from login where phone='$phone'");
$usercount =
mysqli_num_rows($user);
if($usercount<1)
{
echo '<script>alert("User Not registered");location.href="signup.php";</script>';
}
else
{
$qry = mysqli_query($conn,"select * from login where phone='$phone' and
upass='$upass'");
$count =
mysqli_num_rows($qry);
if($count==1)
{
$countresult = mysqli_fetch_assoc($qry);
$_SESSION['id'] = $countresult['id'];
echo '<script>location.href="index.php";</script>';
}
else
{
echo '<script>alert("Invalid Login");</script>';
}
}
}
?>
Signup Page
Code
<?php
session_start();
error_reporting();
?>
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/materialize/1.0.0/css/
materialize.min.css">
<!-- Compiled and minified JavaScript -->
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-
awesome/4.7.0/css/font-awesome.min.css"><script
src="https://cdnjs.cloudflare.com/ajax/libs/materialize/1.0.0/js/materialize.min.js"></scrip
t>
</head>
<style>
</style>
<body>
</div>
</div>
</div>
<div class="row">
<div class="col input-field s12 m6 l6">
<label for="zcode" class="zcode">Zipcode</label>
<input type="number" max="999999" min="111111" class="option" name="zcode" required>
</div>
<div class="col input-field s12 m6 l6">
<label for="address">Address</label>
<input type="text" id="subject" name="address" required>
</div>
</div>
<div class="row">
<label>
<input type="checkbox" checked="checked" name="remember" style="margin-
bottom:15px"><span>Remember me</span>
</label>
</div>
<div class="row">
<p>By creating an account you agree to our <a href="#" style="color:dodgerblue">Terms
& Privacy</a>.</p>
</div>
<div class="row center-align">
<a href="index.php" class="btn red">Back</a>
<button type="submit" class="btn" name="signup">Sign Up</button>
</div>
<div class="row center-align">
<p style="text-align:center">Or</p>
<a href="login.php" class="btn blue" name="signup" >Login</a>
</div>
</div>
</form>
</body>
</html>
<?php
include("db.php");
if(isset($_POST['signup']))
{
$fname = $_POST['fname'];
$lname = $_POST['lname'];
$email = $_POST['email'];
$pass = $_POST['password'];
$state = $_POST['state'];
$zcode = $_POST['zcode'];
$add = $_POST['address'];
$phone = $_POST['phone'];
}
?>
My Account Page
Code:
<?php
session_start();
error_reporting();
if(!isset($_SESSION['phone']))
{
header("location:login.php");
}
else
{
include("db.php");
$phone = $_SESSION['phone'];
$qry = mysqli_query($conn,"select * from signup where phone='$phone'");
$qryresult = mysqli_fetch_assoc($qry);
}
?>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>User Account</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet"
href="https://cdnjs.cloudflare.com/ajax/libs/materialize/1.0.0/css/materialize.min.css">
<!-- Compiled and minified JavaScript -->
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-
awesome/4.7.0/css/font-awesome.min.css"><script
src="https://cdnjs.cloudflare.com/ajax/libs/materialize/1.0.0/js/materialize.min.js"></scrip
t>
<script src="main.js"></script>
</head>
<body>
<div class="row outer white-text" style="margin:0;">
<?php
include("header.php");
?>
<div style="padding:50px;">
<h2 style="font-family:Script MT;">My Account</h2>
<h5 class="col l6 s12 m6" style="font-family:Agency FB">Never share your
password with anyone.</h5>
</div>
</div>
<form action="updateuser.php" method="post" style="border:1px solid #ccc">
<div class="container">
<h4 class="center-align" style="font-family:Algerian">MY ACCOUNT</h4>
<hr>
<div class="row" style="font-family:Agency FB;font-size:20px;">
<div class="col s12 m6 l6">
<label for="fname"><b>First Name</b></label>
<input type="text" id="fname" name="fname" placeholder="Your name.." disabled
value="<?php echo $qryresult['fname']; ?>">
</div>
<div class="col s12 m6 l6">
<label for="lname"><b>Last Name</b></label>
<input type="text" id="lname" name="lname" placeholder="Your last name.." disabled
value="<?php echo $qryresult['lname']; ?>">
</div>
</div>
<div class="row">
<div class="col s12 m6 l6">
<label for="email"><b>Email</b></label>
<input type="email" placeholder="Enter Email" name="email" disabled value="<?
php echo $qryresult['email']; ?>">
</div>
<div class="col s12 m6 l6">
<label for="psw"><b>Password</b></label>
<input type="password" placeholder="Enter Password" name="password"
disabled value="<?php echo $qryresult['upass']; ?>">
</div>
</div>
<div class="row">
<div class="col s12 m6 l6">
<label for="phone"><b>Phone</b></label>
<input type="number" max="9999999999" min="1111111111" placeholder="1234567890"
class="phone" name="phone" disabled value="<?php echo $qryresult['phone']; ?>" >
</div>
<div class="col s12 m6 l6">
<label for="state"><b>State</b></label>
<input type="text" name="state" id="" disabled value="<?php echo
$qryresult['state']; ?>">
</div>
</div>
<div class="row">
<div class="col s12 m6 l6">
<label for="zcode" class="zcode"><b>Zipcode</b></label>
<input type="number" max="999999" min="111111" placeholder="123456" class="option"
name="zcode" disabled value="<?php echo $qryresult['zipcode']; ?>">
</div>
<div class="col s12 m6 l6">
<label for="address"><b>Address</b></label>
<input type="text" id="subject" name="address" placeholder="Enter Address" disabled
value="<?php echo $qryresult['address']; ?>">
</div>
</div>
<div class="row">
<label>
<input type="checkbox" checked="checked" name="remember" style="margin-
bottom:15px"><span>Remember me</span>
</label>
</div>
<div class="row">
<p>By creating an account you agree to our <a href="#" style="color:dodgerblue">Terms
& Privacy</a>.</p>
</div>
<div class="row center-align">
<a href="index.php" class="btn red"
style="text-
decoration:none;color:#fff;bottom:10px;">Back</a>
<button type="submit" class="btn" name="signup">Update</button>
</div>
</div>
</form>
</body>
</html>
My Cart Page:
Code
<?php
session_start();
include("db.php");
?>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>My Cart</title>
</head>
<body>
<div class="outer row white-text">
<?php
include("header.php");
?>
<div style="padding:50px;">
<h2 style="font-family:Script MT;">My Cart</h2>
<h5 class="col l6 s12 m6" style="font-family:Agency FB">Looking for the original
and best high-protein smoothie on the planet? You've found us! Oh, and we also sell ice
cream.</h5>
</div>
</div>
<div class="row">
<h3 class="l6 m6 s12 center-align" style="font-
family:Algerian;width:50%;padding:50px;margin:20px auto;border-bottom:1px solid
#bbb">My Cart</h3>
<?php
//user details
$phone = $_SESSION['phone'];
$details = mysqli_query($conn,"select * from signup where phone =
'$phone'"); if($details){
$detailsresult = mysqli_fetch_assoc($details);
$name = $detailsresult['fname'];
}
$qry = mysqli_query($conn,"select * from cart where phone='$phone'");
if(mysqli_num_rows($qry)>=1)
{
while($d = mysqli_fetch_assoc($qry))
{
echo '<div style="width:50%;margin:10px auto;border-bottom:1px solid #bbb;">
<div class="row">
<div class="col l3 m3 s12">
<img src="products/'.$d['image'].'" alt="first
image" class="responsive-img" style="width:100%;">
</div>
<div class="col l8 m4 s12">
<a href="view.php?id='.$d['id'].'" class="grey-
text">'.$d['pname'].'</a>
<p class="green-text">Rs. '.money($d['price']).'.00</p>
<form action="updateqty.php?id='.$d['id'].'" method="post">
<input type="submit" value="-" name="operator" class="btn">
<input type="number" value="'.$d['qty'].'" name="qty"
style="width:100px;" class="center-align">
<input type="submit" value="+" name="operator" class="btn">
</form>
<div class="row right-align">
<form action="deletecart.php?id='.$d['id'].'" method="post">
<input type="submit" value="Delete" name="delete"
class="btn">
<a href="index.php" class="btn red">Continue
Shopping</a>
</form>
</div>
</div>
</div></div>';
}
echo '<div class="row l5 right-align" style="margin:auto;width:40%;">
<a href="buy.php" class="btn green">Buy Now</a>
</div>';
}
else
{
echo '<div style="width:40%;margin:auto;">
<div class="col card-panel l12 m6 s12">
<h5 class="center-align" style="font-family:Agency FB">Cart Is Empty<h5>
<div class="right-align">
<a href="index.php" class="btn custom">Continue Shopping</a>
</div>
</div>
</div>';
}
?>
</div>
<?php
include "footer.php";
?>
</body>
</html>
Checkout Page:
Code:
<?php
session_start();
include("db.php");
if(isset($_SESSION['phone']))
{
$phone = $_SESSION['phone'];
//$id = $_GET['id'];
$qry = mysqli_query($conn,"select * from cart where
phone='$phone'"); if($qry)
{
//user details
?>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Buy</title>
</head>
<body>
<div class="row outer white-text" style="margin:0;">
<?php
include("header.php");
?>
<div style="padding:50px;">
<h2 style="font-family:Script MT;">Checkout</h2>
<h5 class="col l6 s12 m6" style="font-family:Agency FB">Baking is about multi-
tasking. If you are organized and prepared, that's half the battle.</h5>
</div>
</div>
<div class="row" style="background-image:url('form_background.jpg')">
<div class="row col l8">
<div class="col l12" style="font-family:Script MT;padding:20px 50px;">
<h4 class="center-align" style="font-family:Algerian">Delivery Address</h4>
<h6><?php echo $addresult['fname']." ".$addresult['lname'];?></h6>
<h6><?php echo $addresult['address'].", ".$addresult['state'].", ".
$addresult['zipcode'];?></h6>
<h6><?php echo $addresult['phone'];?></h6>
</div>
<div class="col l12">
<h4 class="center-align" style="font-family:Algerian;margin-bottom:20px;">My
Cart</h4>
<?php
while($d = mysqli_fetch_assoc($qry))
{
echo '<div class="row" style="font-family:Agency FB;margin:0;">
<div class="col l3 m3 s12">
<img src="products/'.$d['image'].'" alt="first
image" class="responsive-img" style="object-fit:contain;width:100%;">
</div>
<div class="col l8 m4 s12">
<a style="font-size:22px;" class="black-text"
href="view.php?id='.$d['id'].'">'.$d['pname'].'</a>
<p class="green-text">Rs. '.money($d['price']).'.00</p>
<p>Qty - '.$d['qty'].'</p>
</div>
</div>';
}
?>
</div>
</div>
<div class="col l4 s12 m4">
<table>
<thead>
<tr>
<th><h4 style="font-family:Algerian">Price Details</h4></th>
</tr>
</thead>
<tbody style="font-family:Agency FB;font-size:20px;">
<tr>
<td>Price(<?php echo $tnum; ?>)</td>
<td>Rs. <?php echo money($result).".00"; ?></td>
</tr>
<tr>
<td>Delivery Charges</td>
<td>Free</td>
</tr>
<tr>
<td>Total</td>
<td>Rs. <?php echo money($result).".00"; ?></td>
</tr>
</tbody>
</table>
<div class="col l12" style="margin:40px 0px;">
<form action="payment.php" method="post">
<input type="submit" name="submit" class="btn custom" value="Continue
Payment">
</form>
</div>
</div>
</div>
</body>
</html>
Code:
<?php
session_start();
include("db.php");
if(!isset($_SESSION['phone']))
{
header("index.php");
}
else
{
include("db.php");
//payment method variable
//$conn = mysqli_connect('localhost','root','','watch');
$pmethod = $_GET['pmethod'];
//product data
$phone = $_SESSION['phone'];
$q = mysqli_query($conn,"select * from cart where phone='$phone'");
$r = mysqli_num_rows($q);
$cp = mysqli_fetch_assoc($q);
$name = $cp['uname'];//user
name if($r<=0)
{
echo '<script>alert("You dont have any
product!!!");location.href="index.php";</script>';
}
if(isset($_POST['payment']))
{
$qforcart = mysqli_query($conn,"select * from cart where
phone='$phone'"); while($fetchdata = mysqli_fetch_assoc($qforcart))
{
$pid = $fetchdata['id'];
if($_GET['pmethod']=="Through Card")//if card payment is selected
{
$qforexistence = mysqli_query($conn,"select * from payment where phone
= '$phone'");//checking whether the details are already inserted
$card_number = $_POST['cardnumber'];//getting card number
$address = $r1['address'].','.$r1['state'].','.$r1['zipcode'];
}
else
{
header("index.php");
}
}
?>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Final Page</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" type="text/css" media="screen" href="main.css">
<link rel="stylesheet"
href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css"
integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T"
crossorigin="anonymous">
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-
q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo"
crossorigin="anonymous"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js"></
script>
<script>
//money function
<?php
function money($money){
$len = strlen($money);
$m = '';
$money =
strrev($money);
for($i=0;$i<$len;$i++){
if(( $i==3 || ($i>3 && ($i-1)%2==0) )&& $i!=$len){
$m .=',';
}
$m .=$money[$i];
}
return strrev($m);
}
?>
</script>
</head>
<body>
<h1 class="text-success text-center my-3">Thank You For Your Order!!!</h1>
<p class="text-center col-10 mx-auto my-4">Your order has been placed and is being
processed.When the item(s) are shipped,you will receive an email with the courier
Tracking ID and the link where you can track your order.Meanwhile ,you can track your
order</p>
<?php
<?php
$order = mysqli_query($conn,"select * from cart where phone = '$phone'");
while($d = mysqli_fetch_assoc($order))
{
echo "<tr>";
echo "<td>".$d['pname']."</td>";
echo "<td>By ".$presult['b_date']."</td>";
echo "<td>By ".$presult['d_date']."</td>";
echo "<td>Rs.
".money($d['price']).".00</td>";
echo "<td>".$d['qty']."</td>";
echo "<td>Rs. ".money($d['qty']*$d['price']).".00</td>";
echo "</tr>";
}
$gt = mysqli_query($conn,"select sum(qty*price) AS gt from cart where phone='$phone'");
$gtresult = mysqli_fetch_assoc($gt);
?>
<tr><th colspan="7">Grand Total = Rs.<?php echo "
".money($gtresult['gt']).".00";?></th></tr>
</table>
<div class="mx-auto text-center">
<a href="order.php" class="btn btn-info">My Orders</a>
<a href="index.php" class="btn btn-success">Continue Shopping</a>
</div>
</div>
</body>
</html>
<?php
// deleting the cart
?>
My Order Page:
Code:
<?php
session_start();
//error_reporting(0);
include("db.php");
?>
<?php
if(!isset($_SESSION['phone']))
{
echo '<script>alert("You need to login!!!");location.href="login.php";</script>';
}
else
{
$phone = $_SESSION['phone'];
$q = mysqli_query($conn,"select * from ordertable where phone='$phone' order by d_date
desc ");
$nor = mysqli_num_rows($q);
// for displaying the Address
$q1 = mysqli_query($conn,"select * from signup where phone='$phone' ");
$r1 = mysqli_fetch_assoc($q1);
$address = $r1['address'].','.$r1['state'].','.$r1['zipcode'];
}
?>
<html>
<head>
<title>My Orders</title>
<link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.0.13/css/all.css">
</head>
<body>
<div class="row outer white-text" style="margin:0;">
<?php
include("header.php");
?>
<div style="padding:50px;">
<h2 style="font-family:Script MT;">My Orders</h2>
<h5 class="col l6 s12 m6" style="font-family:Agency FB">Baking is about multi-
tasking. If you are organized and prepared, that's half the battle.</h5>
</div>
</div>
<div class="row">
<h3 class="h3 l6 m6 s12 center-align" style="font-
family:Algerian;width:50%;padding:10px;margin:20px auto;">My Orders (<?php
echo
$nor;?>)</h3>
<?php
if($nor!=0)
{
while($d = mysqli_fetch_assoc($q))
{
//date difference calculation
$day = date("j");
$month = date("n");
$year = date("Y");
$todays_date = date_create("$day-$month-$year");
$return_date = date_create($d['d_date']);
$diff = date_diff($todays_date,$return_date);
//fromating the date
$charge = $diff->format("%R%a");
echo '<div class="row product" style="font-
family:Agency FB;width:50%;margin:auto;">
<h5 class="text-center bg-danger text-white p-2">Order Details</h5>
<table>
<tr>
<td>OrderID</td>
<td>'.$d['orderid'].'</td>
</tr>
<tr>
<td>Order Date</td>
<td>'.$d['b_date'].'</td>
</tr>
<tr>
<td>Delivery Date</td>
<td>'.$d['d_date'].'</td>
</tr>
<tr>
<td>Total Amount</td>
<td>Rs. '.money($d['price']*$d['qty']).'.00 ('.$d['qty'].' item/s)</td>
</tr>
</table>
</div>';
echo '<div style="font-family:Agency FB;font-
size:20px;width:50%;padding:10px;margin:auto;border-bottom:1px solid
#bbb;" class="product"><div class="row">
<div class="col l3 m3 s12">
<img src="products/'.$d['image'].'" alt="first
image" class="responsive-img" style="width:100%;">
</div>
<div class="col l8 m4 s12">
<a href="view.php?id='.$d['id'].'" class="grey-
text">'.$d['pname'].'</a>
<p class="green-text">Rs. '.money($d['price']).'.00</p>
<p class="grey-text">Qty - '.$d['qty'].'</p>
<div class="row right-align">';
if($charge>"0")
{
echo "<a class='btn red'
href=cancelorder.php?orderid=".$d['orderid']."
id='cancel'>Cancel</a>";
}
echo "<a class='a continue btn'
href=index.php style='margin:auto 5px'>Continue Shopping</a>";
echo '</div></div>
</div>
</div>
</div>';
}
}
else
{
echo '<div style="width:50%;margin:auto;display:block">
<div class="card-panel l5 m6 s12">
<h5 class="center-align">No Orders Yet<h5>
<div class="right-align">
<a href="index.php" class="btn">Order Now</a>
</div>
</div>
</div>';
}
?>
</div>
<?php
include "footer.php";
?>
</body>
</html>
Testing Approach
Testing
Software testing is a critical element of a software quality assurance and represents the
ultimate review of specification, design and coding. Testing is the exposure of the system to trail
input to see whether it produce correct output.
Integration Testing
The first step including integration testing. It need not be the ease, the software whose modules
when run individually and showing perfect results. Will also show results when run as a whole. The
individual modules are clipped under this major module and tested again and verified the results. This is
due to poor interfacing.
Unit Testing
The second step including unit testing. Where in each module is tested to provide its correctness,
validity and also determine any missing operation and to verify whether the objectives have been met.
Errors are noted down and corrected immediately. Unit testing is the important and major part of the
project. So errors are rectified easily in particular modules and program clarity is increased.
Test Cases
A test case in software engineering is a set of conditions or variables under which a tester will
determine whether an application or software system is working correctly or not. Test cases are derived to
ensure that all statements in the program have been executed at least once during and testing and that all
logical conditions have been executed. A test cases is a detailed produced that fully tests a feature or an
aspects of a feature. Whereas the test plan described what, a test case described how to perform a particular
test.
Test Case Expected Result Actual Result Result
Signup page Insert record Insert record pass
login page Go to homepage Go to homepage pass
Homepage Go to product page Go to product page pass
Product page Go to view product page Go to view product page pass
View All page Go to All product page Go to All product page pass
Order summery page Summary of the product Summary of the product pass
Payment page Insert details in database Insert details in database pass
and generate bill and generate bill
ADMIN-SIDE-VALIDATION
category page Insert, update, delete and display Insert, update, delete and display pass
records records
TEST USING SELENIUM
Chapter 6
Results and Discussion
Test Report: - As all above test cases, we conclude that the system and all other module are properly
functioning as they are programmed to do.
User can Order any product of their choice with their choice of payment mode. Admin can
manipulate records, Insert, Update, Delete and Display all the product in database. also can view
user details and order details.
Conclusion: - The manual system of ―Online Cake Shop‖ is to be computerized in order to overcome
the problems which affects the existing manual system. Computerizing the existing system with the help
of some programming language, database package eases the work of the system up to a great extent.
The main objectives of the proposed system are to help the user. The system can be handy to the
user in the following reasons: -
To provide quick and efficient means for performing billing related activities and
to effortlessly generate report of the system.
To automate the work such as billing, Client record, etc.
To automate the different types of reports.
Conclusion
An attempt is made in all its earnest towards the successful completion of the project. This system
was verified with valid as well as with invalid data.
This system is user friendly since it has been developed in PHP, a successful GUI environment.
Since the connection can be extended to any database. The control will be more powerful.
Connecting it to any type of database extends the development control. Any suggestions for future
development of the system are welcome.
Upgrading the system can be done without affecting the proper functioning of system.
Future Enhancement:
This website has only one facility that is cart which is used for multi-product shopping where user can buy
more than one product at same time.
Further our team goal is to provide a wish list facility to the user where user can save their product for
the future action.
One more enhancement will be done by our team is that we provide feedback facility regarding the
product, where user can give feedback about the product, like is it good/bad, about their description, color
problem, service facility problem about the product etc.
Our team will make one more facility to the user/customer where they can give rating to a particular product.
BIBLIOGRAPHY:
For Database:
i. System Analysis and Design –By Sat zinger
ii. Software Engineering—By McGraw Hill 7th
Edition
iii. http://www.w3scools.com/
iv. http://www.phpmanual.com/
v. http://www.google.com/
For PHP:
i. www.google.com www.w3schools.com
ii. http://www.phpmanual.com/
a. http://www.quora.com/