Web Phishing Detection Report
Web Phishing Detection Report
Team ID PNT2022TMID40431
Project Name Web Phishing Detection
S.NO PAGE NO
TOPIC
1. INTRODUCTION
3
1.1 Project Overview
1.2 Purpose
2. LITERATURE SURVEY
5
2.1 Existing problem
2.2 References
2.3 Problem statement Definition
3. IDEATION & PROPOSED SOLUTION
10
3.1 Empathy Map canvas
3.2 Ideation & brainstorming
3.3 Proposed solution
3.4 Problem solution Fit
4. REQUIREMENT ANALYSIS
14
4.1 Functional requirement
4.2 Non Functional requirement
5. PROJECT DESIGN
17
5.1 Data flow Diagram
5.2 Solution & Technical Architecture.
5.3 User Stories
6. PROJECT PLANNING & SCHEDULING
21
6.1 Sprint Planning & Estimation
6.2 Sprint Delivery Schedule
1
TESTING
8. 33
8.1 Test Cases
8.2 User Acceptance Testing
RESULTS
9. 36
9.1 Performance Metrics
CONCLUSION
11. 37
FUTURE SCOPE
12. 37
APPENDIX
13. 38
2
1. INTRODUCTION
1.1 PROJECT OVERVIEW
There are number of users who purchase products online and make
payment through various websites. There are multiple websites who ask user to
provide sensitive data such as username, password or credit card details etc. often for
malicious reasons. This type of websites is known as phishing website. In order to
detect and predict phishing website, we proposed an intelligent, flexible and effective
system that is based on using classification Data mining algorithm. The phishing
website can be detected based on some important characteristics like URL and
Domain Identity, and security and encryption criteria in the final phishing detection
rate. Once user makes transaction through online when he makes payment through
the website our system will use data mining algorithm to detect whether the website
is phishing website or not. This application can be used by many E-commerce
enterprises in order to make the whole transaction process secure. Data mining
algorithm used in this system provides better performance as compared to other
traditional classifications algorithms. With the help of this system user can also
purchase products online without any hesitation. Admin can add phishing website
URL or fake website URL into system where system could access and scan the
phishing website and by using algorithm, it will add new suspicious keywords to
database. System uses machine learning technique to add new keywords into
database.
We have developed our project using a website as a platform for all the users.
This is an interactive and responsive website that will be used to detect whether a
website is legitimate or phishing. This website is made using different web designing
languages which include HTML, CSS, Java Script.
3
The basic structure of the website is made with the help of HTML. CSS is used to
add effects to the website and make it more attractive and user-friendly. It must be
noted that the website is created for all users, hence it must be easy to operate with
and no user should face any difficulty while making its use. Every person must be
able to use this website and avail maximum benefits from it.
The website shows information regarding the services provided by us. It also
contains information regarding ill- practices occurring in today technological world.
The website is created with an opinion such that people are not only able to
distinguish between legitimate and fraudulent website, but also become aware of the
mal-practices occurring in current world. They can stay away from the people trying
to exploit one’s personal information, like email address, password, debit card
numbers, credit card details, CVV, bank account numbers, and the list goes on.
1.2 PURPOSE
The main purpose of the project is to detect the fake or phishing websites who are
trying to get access to the sensitive data or by creating the fake websites and trying to
get access of the user personal credentials. We are using machine learning algorithms
to safeguard the sensitive data and to detect the phishing websites who are trying to
gain access on sensitive data
4
2. LITERATURE SURVEY
In the year (2020) anamoly detection solutions are readily available, are
deployed quickly and immediately and automatically protect all account holders
against all types of fraud attack with minimal Disruption to legitimate online banking
activity. Limitation of this project is there was no facility of displaying pop-up and
email notification once user had access blacklisted website
5
2.1.2 TITLE: DETECTION OF PHISHING WEBSITES USING AN
EFFICIENT FEATURE-BASED MACHINE LEARNING FRAMEWORK
In the year of 2018. In this, they have classified features into three categories such as
URL Obfuscation features, Third-Party-based features, Hyperlink-based features.
Moreover, the proposed technique gives 99.55% accuracy. Drawback of this is that
as this model uses third party features, classification of websites depends on the
speed of third-party services.
6
2.1.4 TITLE: DETECTING OF E-BANKING PHISHING WEBSITE -USING
MACHINE LEARNING APPROACH
There had been several strategies given within the literature to locate phishing
assaults. In this segment, we gift an overview of detection approaches towards
phishing attacks. In well-known, phishing detection techniques can be classified as
either user education or software-based anti-phishing techniques. Software program-
based totally strategies may be further categorized as listing-based totally, heuristic-
based totally, and visual similarity-primarily based strategies. List-primarily based
anti-phishing strategies maintain a black-list, white-list, or mixture of both. In black-
list-based anti-phishing approach, a black-list is maintained which contains
suspicious domains and ip addresses. Black-lists are regularly up to date; but, the
maximum of the black-list-primarily based strategies are not effective in coping with
zero- hour phishing assaults conclude that forty-seven % to eighty three % of
phishing domain names replace inside the black-list after 12 h. A number of the
processes utilizing black-lists are google safe surfing api, dns-primarily based black-
lists, and predictive black-list. However, maintaining a black-list calls for a first-rate
deal of sources for reporting and affirmation of the suspicious websites. As heaps of
phishing webpages are created every day, updating each phishing website within the
black-list is a hard venture.
7
2.2 REFERENCES
10. A. Desai, J. Jatakia, R. Naik, and N. Raul, Malicious web content detection
using machine leaning, RTEICT 2017 – 2nd IEEE Int. Conf. Recent Trends
Electron. Inf. Commun. Technol. Proc., vol. 2018Janua, pp. 14321436,
2018.
Phishing is one of the techniques which are used by the intruders to get
access to the user credentials or to gain access to the sensitive data. This type of
accessing the is done by creating the replica of the websites which looks same as the
original websites which we use on our daily basis but when a user click on the link
he will see the website and think its original and try to provide his credentials .
To overcome this problem we are using some of the machine learning algorithms in
which it will help us to identify the phishing websites based on the features present in
the algorithm. By using these algorithms we can be able to keep the user personal
credentials or the sensitive data safe from the intruders
9
3.IDEATION & PROPOSED SOLUTION
10
3.2 IDEATION & BRAINSTORMING:
1. Problem Statement
(Problem to be Phishing has become one of the biggest and most
solved) effective cyber threats causing hundreds of Million
of dollars in losses and millions of data breaches
every years .Attackers fool the users by presenting
the marked webpage as legitimate or trustworthy to
retrieve their essential data such as username,
password and credit card details etc., often for
malicious reasons.
11
2. Idea / Solution
description In order to detect and predict phishing website, we
proposed an intelligent, flexible and effective system
that is based on using classification, data mining
algorithm. We implemented classification algorithm
and techniques to extract the phishing data sets
criteria to analyse their legitimacy. The solution
should be useful in preventing online frauds leading
to leakage of important and private user data. The
mechanisms deals in order to ensure high security.
3. Novelty /
Uniqueness We have evaluated the performance of our proposed
phishing detection approach on various classification
algorithm. Our system will use a datamining
technique approach whether e-banking website is a
phishing website or not. The system detect the
phishing website and alert the user beforehand by
giving signals as to prohibit the users from getting
their misused credentials.
12
6. Scalability of the The system analyses all e-banking websites and
Solution check against past phishing patterns to detect and
classify e-banking sites as genuine or phishing. This
technology has maximum accuracy.
13
3.4 PROBLEM SOLUTION FIT
vvvv
14
4.REQUIREMENT ANALYSIS
SUB REQUIREMENT
FR. NO FUNCTIONAL REQUIREMENT ( STORY/ SUB TASK)
(EPIC)
Registration
through online
USER REGISTRATION form.
FR-1
Registration
through Gmail.\
Registration
through linked in.
Confirmation via
email.
FR-2 USER CONFIRMATION
Confirmation via
OTP
Verifying
URL(uniform
FR-3 INPUT VERIFICATION resource locator)
and pay close
attention to the web
address and display
if the website is
malicious
Or not.
Extracting efficient
features from the
FR-4 WEBSITE EVALUATION URL and html of
the given webpages
without relying on
Third party services.
Providing the
warning message to
FR-5 ALERT MESSAGE the customer by
alerting from being
Victim.
15
4.2 NON-FUNCTIONAL REQUIREMENTS:
Third party
independent.
URL filtering
Provide multi-
vector phishing
NRF-2 SECURITY protection.
Data loss
prevention.
User can make
online payment
securely and
Trustworthy.
This machine
learning
technology is
completely
signature-less and
automatically
adapts to ever-
NRF-3 changing fake and
REALIABILITY phishing sites.
It does not rely on
signatures and
blocklists like anti-
16
phishing tools.
Real world phishing
campaign
Simulations.
High performance.
Advanced threat
analysis. Data
NRF-4 PERFORMANCE mining algorithm
used in this system
provides better
User-friendly and
transparent.
this system can be
NRF-5 AVAILABILITY used by many e-
commerce or other
websites in order to
have good customer
Relationship.
Increase user
alertness to
phishing risks.
NFR-6 SCALABILITY Eliminate the cyber
threat risk level.
Measures the
degree of
corporate and
employee
vulnerability.
17
5. PROJECT DESIGN
18
CLASSIFY
USER
FEATURE
DATABASE SELECTION
COLLECTION SEARCH
FEATURE D
EXTRACTION E
T
Training set
TRAINING E
C
DATASET FEATURE T
EVALUATION I
Testing set O
N
TESTING
DATASET
MACHINE LEARNING
ALGORITHM
P
H
A
MACHINE LEARNING S
CLASSIFIER E
OUTPUT CLASSIFIER
URL
DETECTION MODULE
19
PHISHING ALERTING THE USERS LEGITIMATE
THROUGH REGISTERED
EMAILS
20
5.3 USER STORIES
21
6.PROJECT PLANNING & SCHEDULING
6.1 SPRINT PLANNING & ESTIMATION
22
6.2SPRINT DELIVERY SCHEDULE
23
7. CODING & SOLUTIONING
7.1 FEATURE 1
Code
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="stylesheet" type="text/css" href="../static/end.css">
<title>Phishing Website</title>
</head>
<body>
24
<div class="wrapper">
<header>
<div class="container">
<img src="../static/images/menu.png" class="menu">
<img src="../static/images/qc.png" class="quick">
<a href="#section1" class="about-btn">About</a>
</div>
</header>
<div class="content">
<div class="text">
<p>Real-Time URL and Website Checking<br>
To create a more secure digital world through this tool for protecting
not only can help you to quickly & easily access.</p>
<div class="input-group-append">
<a href="/index.html" class="input-group-text btn">Click Here to
Predict</a>
</div>
</div>
</div>
<div class="img">
<div class="social-icons">
<img src="../static/images/social-icon1.png" alt="">
25
<img src="../static/images/social-icon2.png" alt="">
<img src="../static/images/social-icon3.png" alt="">
<img src="../static/images/social-icon4.png" alt="">
<img src="../static/images/social-icon5.png" alt="">
</div>
<img class="email-icon" src="../static/images/email-icon.png" alt="">
</div>
</div>
<div class="wave">
<img src="../static/images/wave.svg" alt="">
</div>
</div>
<section class="features">
<div class="container" id="section1">
<h1>INFO</h1>
<div class="row">
<div class="col-md-4">
<div class="feature-box">
<div class="feature-img">
<img src="../static/images/a.gif">
<img src="../static/images/7zon.gif">
26
<div class="detail">
<p>Phishing is an attack that attempts to steal your money,
or your identity, by getting you to reveal personal information -- such as credit
card numbers, bank information, or passwords -- on websites that pretend to be
legitimate.</p>
</div>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-md-4">
<div class="info">
<p>A measurement for phishing detection is the
number of suspicious e-mails reported to the security team. This measurement
is designed to evaluate the number of employees who followed the proper
procedure for reporting suspicious messages.</p>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
27
</section>
<hr>
<section class="FAQ">
<div class="create">
<h2>FAQ & Answers</h2>
<div class="v1">
<h4>Do you know what is phishing?</h4>
<p>This is the type of virtual threat has become increasingly
common.Its aims to obtain this information through bait.</p>
</div>
<br>
<div class="v2">
<h4>What is QuickCheck?</h4>
<p>QuickCheck uses advanced machine learning techniques to quickly
detect scam websites and determine whether a website is legit or not.</p>
</div>
<br>
<div class="v3">
<h4>What are the benefits of using QuickCheck?</h4>
<p>Often, you want to visit a website for various reasons, but you are
unsure whether to trust the website.<br>
28
You are asking yourself questions such as “is this website legit?” or “is
it a scam website?” or “is this a safe website?” or “is this site real?” and so
many similar questions.<br>
QuickCheck is an intelligent scam detector which analyses website link
characteristics and allows finding out proactively and swiftly whether by
clicking on the link you will land on an unsafe website or a website that is
safe. It helps with website credibility check and verifying whether a company
is legit.</p>
</div>
<br>
<div class="v4">
<h4>How to use QuickCheck??</h4>
<p>Using QuickCheck for fraudulent websites check or to check whether
a website is safe is very easy.<br>
Just enter the link in the search box and click the Search icon.<br>
QuickCheck will check the website link a0nd quickly displays its
results as whether this is a scam website or a safe website.</p>
</div>
<br>
<div class="v5">
<h4>How QuickCheck works?</h4>
<p>URL Checker is a safe link checker which uses advanced machine
learning algorithms and natural language processing techniques to analyze
website link characteristics and check the credibility of the users owning
it.</p>
</div>
29
<br>
<div class="v6">
<h4>Features</h4>
<p>1. Advanced threat protection.<br>
2. Thread intelligence.<br>
3. Advanced threat analysis.<br>
4. Threat mitigation.<br>
5. Data loss protection.<br>
</p>
</div>
</section>
</body>
</html>
30
7.2 FEATURE 2
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<link rel="stylesheet" href="../static/style.css">
<link rel="preconnect" href="https://fonts.gstatic.com">
<link rel="preconnect" href="https://fonts.gstatic.com">
31
<link
href="https://fonts.googleapis.com/css2?family=Raleway:wght@100&family=
Roboto+Mono&display=swap"
rel="stylesheet">
<link rel="preconnect" href="https://fonts.gstatic.com">
<link
href="https://fonts.googleapis.com/css2?family=Raleway:wght@100;700&fa
mily=Roboto+Mono&display=swap"
rel="stylesheet">
<link rel="preconnect" href="https://fonts.gstatic.com">
</head>
<body>
<br><br><br><br>
<div class="welcome ">
<h2 style="color: azure;">Phishinig Site Prediction</h2>
</div>
<div class="userinput">
<h2>Enter URL </h2>
<br>
<form action='/predict' method="post">
<div class="input">
32
<input id="url" name="z1" type="text" width="48" height="48"
size="50" required><br>
<button class="button" type="Summarize">Predict</button>
</div>
</form>
<br>
<br>
<div id='result'>
{{ prediction_text }}
</div>
</div>
</body>
</html>
33
8. TESTING
8.1 TEST CASES
A test case has components that describe input, actionand an expected
response, in order to determine if a feature of an application is working
correctly. A set case is a set of instructions on “HOW” to validate a particular
test objective/target, which when followed will tell us if the expected
behaviour of the system is satisfied or not.
34
8.2 USER ACCEPTANCE TESTING
35
36
9. RESULTS
9.1 PERFORMANCE METRICS
DISADVANTAGES
• If Internet connection fails, this system won’t work.
37
12. CONCLUSION
38
13. APPENDIX
SOURCE CODE
Start.html
<!DOCTYPE html>
<html>
<head>
<title> PHISHING DETECTION WEBSITE-QUICKCHECK</title>
<link rel="stylesheet" href="../static/start.css">
</head>
<body>
<div class="hero"
<nav>
<img src="../static/images/menu.png" class="menu-png" id="bird">
<img src="../static/images/Black, White and Triangle Data Chase
Games Logo.png" class="logo-png" >
<ul>
<li><a href="">HOME</a></li>
<li><a href="">MODE</a></li>
</ul>
<buttontype="button"onclick="toggleBtn()" id="btn"><span></span></button>
</nav>
<div class="lamp-container">
<img src="../staticimages/lamp.png" class="lamp">
<img src="../static/images/light.png" class="light" id="light">
39
</div>
<div class="hacker">
<img src="../static/images/hack.jpg" class="hack" id="hack">
</div>
</nav>
<div class="text-container">
<h1> Real time URL & Website Sandbox</h1><br><br>
<p> Free URL scanner and Website checker to detect phishing, scam
sites & fradulent sites.<br>
<br>QUICKCHECK is a free tool to detect malicious URLs including
malware, scams and phishing links.<br>
<br>Safe links checker scans URLs for malware, viruses,scam and
phishing links
</p>
<a href="/end.html" class="get-started-btn scrollto">Get Started</a>
<div class="control">
<p>04</p>
<div class="line"><span></span></div>
<p>05</p>
</div>
</div>
<script>
var btn=document.getElementById("btn");
var light=document.getElementById("light");
40
function toggleBtn(){
btn.classList.toggle("active");
light.classList.toggle("on");
}
</script>
<script src=".../static/main.js"></script>
</body>
</html>
</body>
</html>
Start.css
*{
margin: 0;
padding: 0;
font-family:'poppins',sans-serif;
box-sizing: border-box;
}
.hero{
background:black;
min-height: 100vh;
width: 100%;
41
color: #fff;
position: relative;
}
nav{
display: flex;
align-items: center;
padding: 20px 8%;
}
nav .menu-png{
width: 200px;
margin-right: 55px;
position: absolute;
height: 100px;
left: 20px;
}
nav .logo-png{
width: 200px;
margin-left: 93px;
}
nav ul{
flex: 1;
text-align: right;
42
}
nav ul li{
display: inline-block;
list-style: none;
margin: 0 20px;
}
nav ul li a{
text-decoration: none;
color: #fff;
background: none;
}
button{
cursor: pointer;
transition: background 0.5s;
background:red;
height: 30px;
width: 60px;
border-radius: 20px;
border: 0;
outline: 0;
}
button span{
display: block;
background: #999;
height: 26px;
width: 26px;
border-radius: 50%;
43
margin-left: 2px;
transition: background 0.5s,margin-left 0.5s;
}
.lamp-container{
position: absolute;
top: -20px;
left: 22%;
width: 200px;
}
.hack{
width: 300px;
height: 300px;
position: absolute;
left: 272px;
border-radius: 50%;
z-index: 0;
bottom: 50px;
.lamp{
width: 100%;
}
44
.light{
position: absolute;
top: 97%;
left: 50%;
transform: translateX(-50%);
width: 700px;
margin-left: -10px;
opacity: 0;
transition: opacity 0.5s;
}
.text-container{
max-width: 600px;
margin-top: 7%;
margin-left: 50%;
color:#fff;
}
.text-container h1{
font-size: 50px;
font-weight: 400;
color:rgba(38, 177, 23, 0.927);
color:transparent;
-webkit-text-stroke: 3px rgba(38, 177, 23, 0.927);
animation: back 10s linear infinite;
background-position: 0 0;
45
background: url(images/back.png);
}
@keyframes back {
100%{
background-position: 1000px 0;
}
}
.text-container p{
font-style: Palatino;
}
.text-container a{
text-decoration: none;
background-color: rgba(42, 214, 59, 0.856);
padding: 14px 40px;
display: inline-block;
color: #fff;
font-size: 18px;
margin-top: 30px;
border-radius: 30px;
}.control{
display: flex;
align-items:center;
justify-content: flex-end;
margin-top: 150px;
46
}
.control .line{
width: 250px;
height: 4px;
background: #fff;
margin: 0 20px;
border-radius: 2px;
}
.control .line span{
width: 50%;
height: 8px;
margin-top: -2px;
border-radius: 4px;
background: rgba(38, 177, 23, 0.927);
display: block;
}
.active {
background: rgba(38, 177, 23, 0.927);
}
.active span{
background: #fff;
margin-left: 31px;
}
.on{
opacity: 3;
47
}
end.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="stylesheet" type="text/css" href="../static/end.css">
<title>Phishing Website</title>
</head>
<body>
<div class="wrapper">
<header>
<div class="container">
<img src="../static/images/menu.png" class="menu">
<img src="../static/images/qc.png" class="quick">
<a href="#section1" class="about-btn">About</a>
</div>
</header>
<div class="content">
<div class="text">
<p>Real-Time URL and Website Checking<br>
To create a more secure digital world through this tool for protecting
not only can help you to quickly & easily access.</p>
<div class="input-group-append">
48
<a href="/index.html" class="input-group-text btn">Click Here to
Predict</a>
</div>
</div>
</div>
<div class="img">
<div class="social-icons">
<img src="../static/images/social-icon1.png" alt="">
<img src="../static/images/social-icon2.png" alt="">
<img src="../static/images/social-icon3.png" alt="">
<img src="../static/images/social-icon4.png" alt="">
<img src="../static/images/social-icon5.png" alt="">
</div>
<img class="email-icon" src="../static/images/email-icon.png" alt="">
</div>
</div>
<div class="wave">
<img src="../static/images/wave.svg" alt="">
</div>
</div>
<section class="features">
<div class="container" id="section1">
<h1>INFO</h1>
<div class="row">
<div class="col-md-4">
<div class="feature-box">
49
<div class="feature-img">
<img src="../static/images/a.gif">
<img src="../static/images/7zon.gif">
<div class="detail">
<p>Phishing is an attack that attempts to steal your money, or
your identity, by getting you to reveal personal information -- such as credit
card numbers, bank information, or passwords -- on websites that pretend to be
legitimate.</p>
</div>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-md-4">
<div class="info">
<p>A measurement for phishing detection is the
number of suspicious e-mails reported to the security team. This measurement is
designed to evaluate the number of employees who followed the proper
procedure for reporting suspicious messages.</p>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</section>
50
<hr>
<section class="FAQ">
<div class="create">
<h2>FAQ & Answers</h2>
<div class="v1">
<h4>Do you know what is phishing?</h4>
<p>This is the type of virtual threat has become increasingly
common.Its aims to obtain this information through bait.</p>
</div>
<br>
<div class="v2">
<h4>What is QuickCheck?</h4>
<p>QuickCheck uses advanced machine learning techniques to quickly
detect scam websites and determine whether a website is legit or not.</p>
</div>
<br>
<div class="v3">
<h4>What are the benefits of using QuickCheck?</h4>
<p>Often, you want to visit a website for various reasons, but you are
unsure whether to trust the website.<br>
You are asking yourself questions such as “is this website legit?” or “is
it a scam website?” or “is this a safe website?” or “is this site real?” and so
many similar questions.<br>
QuickCheck is an intelligent scam detector which analyses website link
characteristics and allows finding out proactively and swiftly whether by
clicking on the link you will land on an unsafe website or a website that is safe.
51
It helps with website credibility check and verifying whether a company is
legit.</p>
</div>
<br>
<div class="v4">
<h4>How to use QuickCheck??</h4>
<p>Using QuickCheck for fraudulent websites check or to check whether a
website is safe is very easy.<br>
Just enter the link in the search box and click the Search icon.<br>
QuickCheck will check the website link a0nd quickly displays its
results as whether this is a scam website or a safe website.</p>
</div>
<br>
<div class="v5">
<h4>How QuickCheck works?</h4>
<p>URL Checker is a safe link checker which uses advanced machine
learning algorithms and natural language processing techniques to analyze
website link characteristics and check the credibility of the users owning it.</p>
</div>
<br>
<div class="v6">
<h4>Features</h4>
<p>1. Advanced threat protection.<br>
2. Thread intelligence.<br>
3. Advanced threat analysis.<br>
4. Threat mitigation.<br>
5. Data loss protection.<br>
</p>
52
</div>
</section>
</body>
</html>
End.css
*{
margin: 0;
outline: none;
box-sizing: border-box;
}
body{
font-family: Space Grotesk;
background-color: black;
overflow-x: hidden;
}
.wrapper{
position: relative;
height: 100vh;
overflow: hidden;
}
header{
padding: 50px 100px;
display: flex;
53
align-items: center;
justify-content: space-between;
}
.menu{
width: 150px;
height: 70px;
float: left;
left: 130px;
margin-top: -20px;
margin-left: -90px;
}
.quick{
width: 150px;
height: 70px;
margin-left: 1px;
float: left;
margin-top: -20px;
margin-left: -20px;
}
.about-btn{
width: 100px;
padding: 8px 0;
outline: none !important;
border: 2px solid #fff;
border-radius: 50px;
background: transparent;
54
color: #fff;
float: left;
margin-left: 1000px;
margin-top: -40px;
}
.content{
display: flex;
flex-wrap: wrap;
justify-content: space-between;
padding: 20px 100px 0;
font-size: 60px;
font-weight: 100;
font-style: serif;
margin-bottom: 200px;
}
.text{
width: 50%;
padding-right: 100px;
}
.text p{
font-family:didot;
font-size: 30px;
font-weight: 400;
line-height: 46px;
color: #fff;
margin-left: -20px;
55
}
.text p span{
color: #01b3fa;
}
.input-group-text{
width: 100px;
height: 70px;
font-size: 40px;
background-image: linear-gradient(#00ff7e,#1f3d90);
border: 0 !important;
border-radius: 50px 50px 50px 50px !important;
color: #fff !important;
padding: 0 20px !important;
box-sizing: none !important;
margin-left: 50px;
margin-top: 10px;
}
.img{
position: relative;
width: 500px;
height: 500px;
background: radial-gradient(520px, #60f0538c, transparent 50%);
margin-top: -490px;
float: right;
}
.email-icon{
56
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
.social-icons{
height: 100%;
animation: rotation 60s linear infinite;
}
@keyframes rotation {
100%{
transform: rotate(360deg);
}
}
.social-icons img{
position: absolute;
}
.social-icons img:nth-child(1){
top: 0;
left: 42%;
}
.social-icons img:nth-child(2){
top: 25%;
right: 0;
}
.social-icons img:nth-child(3){
top: 70%;
57
left: 70%;
}
.social-icons img:nth-child(4){
top: 25%;
left: 0;
}
.social-icons img:nth-child(5){
top: 70%;
left: 10%;
}
.wave{
position: absolute;
bottom: 0;
left: 0;
width: 100%;
line-height: 0;
}
.wave:before{
content: '';
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: 100%;
background: url(images/wave.svg) repeat-x;
58
background-size: cover;
background-position: -1000px 0;
opacity: .2;
animation: waveOne 60s linear infinite;
}
@keyframes waveOne {
50%{
background-position: 0 0;
}
}
.wave:after{
content: '';
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: 100%;
background: url(images/wave.svg) repeat-x;
background-size: cover;
background-position: 2732px 0;
opacity: .3;
animation: waveOne 120s linear infinite;
}
/*SUBMENU*/
ul ul{
59
max-width: 250px;
position: absolute;
padding: 10px 0;
opacity: 0;
z-index: -9999;
transition: all ease 0.5s;
}
ul li:hover ul{
opacity: 1;
z-index: 9;
padding: 30px 0;
}
ul ul li{
margin: 0;
width: 100%;
}
ul ul li a{
width: 100%;
display: inline-block;
padding: 20px;
background-color: #383a58;
color: #fff;
}
ul ul li:first-child a{
border-top-left-radius: 10px;
border-top-right-radius: 10px;
}
60
ul ul li:last-child a{
border-bottom-left-radius: 10px;
border-bottom-right-radius: 10px;
}
ul ul li a:hover{
background-color: #7ff053;
color: #fff;
}
/*features*/
.features{
padding: 100px 0;
background-color:black;
height: 700px;
}
h1{
text-align: center;
padding-bottom: 30px;
}
.feature-img img{
width: 40%;
height: 250px;
border: 30%;
margin-left: 40px;
margin-right: 90px;
}
.detail{
font-style: italic;
61
font-size: 25px;
width: 500px;
height: 170px;
position: relative;
float: left;
border-radius: 30%;
margin-left: 40px;
margin-top: 20px;
padding-top: 40px;
padding-left: 40px;
padding-right: 10px;
padding-bottom: 20px;
background-color: #00ff7e;
animation-name: slidein;
animation-duration: 3s;
animation-iteration-count: infinite;
box-sizing: content-box;
}
@keyframes slidein {
0%{background-color: skyblue;}
25%{background-color: rgb(119, 0, 255);}
50%{background-color: rgb(233, 37, 70);}
75%{background-color: lightpink;}
100%{background-color: orange;}
}
.info{
62
font-style: italic;
font-size: 25px;
width: 500px;
height: 170px;
position: relative;
float: left;
border-radius: 30%;
margin-left: 225px;
margin-top: 20px;
padding-top: 40px;
padding-left: 45px;
padding-right: 10px;
padding-bottom: 30px;
background-color: #00ff7e;
animation-name: ani;
animation-duration: 3s;
animation-iteration-count: infinite;
box-sizing: content-box;
}
@keyframes ani{
0%{background-color: skyblue;}
25%{background-color: rgb(119, 0, 255);}
50%{background-color: rgb(233, 37, 70);}
75%{background-color: lightpink;}
100%{background-color: orange;}
}
63
/*FAQ*/
.create{
padding: 0;
margin: 0;
width: 1520px;
height: 1600px;
animation-name: nam;
animation-duration: 3s;
animation-iteration-count: infinite;
}
@keyframes nam{
0%{background-color: #ee0f22c0;}
25%{background-color: #f1db12ef;}
50%{background-color: limegreen;}
75%{background-color: hotpink;}
100%{background-color: aquamarine;}
}
.create h2{
font-weight: 600;
width: 1520px;
height: 70px;
text-align: center;
border-radius: 10px;
box-shadow: none;
background-color: #fff;
}
64
.v1 h4{
font-weight: 600;
font-size: 25px;
text-align: center;
}
.v1 p{
font-weight: 600;
font-size: 20px;
width: 500px;
height: 150px;
background-color: #fff;
border-radius: 10px;
margin-top: 20px;
margin-left: 500px;
padding-left: 20px;
padding-right: 20px;
padding-top: 10px;
animation-duration: 5s;
animation-name: v1slidein;
}
@keyframes v1slidein {
from {
margin-left: 100%;
width: 300%;
}
to {
65
margin-left: 0%;
width: 100%;
}
}
.v2 h4{
font-weight: 600;
font-size: 25px;
text-align: center;
}
.v2 p{
font-weight: 600;
font-size: 20px;
width: 500px;
height: 200px;
background-color: #fff;
border-radius: 10px;
margin-top: 20px;
margin-left: 500px;
padding-left: 20px;
padding-right: 20px;
padding-top: 10px;
animation-duration: 5s;
animation-name: v2slidein;
}
@keyframes v2slidein {
from {
margin-left: 100%;
66
width: 300%;
}
to {
margin-left: 0%;
width: 100%;
}
}
.v3 h4{
font-weight: 600;
font-size: 25px;
text-align: center;
}
.v3 p{
font-weight: 600;
font-size: 20px;
width: 500px;
height: 310px;
background-color: #fff;
border-radius: 10px;
margin-top: 20px;
margin-left: 500px;
padding-left: 20px;
padding-right: 20px;
padding-top: 10px;
animation-duration: 5s;
animation-name: v3slidein;
67
}
@keyframes v3slidein {
from {
margin-left: 100%;
width: 300%;
}
to {
margin-left: 0%;
width: 100%;
}
}
.v4 h4{
font-weight: 600;
font-size: 25px;
text-align: center;
}
.v4 p{
font-weight: 600;
font-size: 20px;
width: 500px;
height: 190px;
background-color: #fff;
border-radius: 10px;
margin-top: 20px;
margin-left: 500px;
padding-left: 20px;
68
padding-right: 20px;
padding-top: 10px;
animation-duration: 5s;
animation-name: v4slidein;
}
@keyframes v4slidein {
from {
margin-left: 100%;
width: 300%;
}
to {
margin-left: 0%;
width: 100%;
}
}
.v5 h4{
font-weight: 600;
font-size: 25px;
text-align: center;
}
.v5 p{
font-weight: 600;
font-size: 20px;
width: 500px;
height: 150px;
background-color: #fff;
69
border-radius: 10px;
margin-top: 20px;
margin-left: 500px;
padding-left: 20px;
padding-right: 20px;
padding-top: 10px;
animation-duration: 5s;
animation-name: v5slidein;
}
@keyframes v5slidein {
from {
margin-left: 100%;
width: 300%;
}
to {
margin-left: 0%;
width: 100%;
}
}
.v6 h4{
font-weight: 600;
font-size: 25px;
text-align: center;
}
.v6 p{
font-weight: 600;
70
font-size: 20px;
width: 500px;
height: 150px;
background-color: #fff;
border-radius: 10px;
margin-top: 20px;
margin-left: 500px;
padding-left: 20px;
padding-right: 20px;
padding-top: 10px;
animation-duration: 5s;
animation-name: v6slidein;
}
@keyframes v6slidein {
from {
margin-left: 100%;
width: 300%;
}
to {
margin-left: 0%;
width: 100%;
}
}
Index.html
<!DOCTYPE html>
<html lang="en">
71
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<link rel="stylesheet" href="../static/style.css">
<link rel="preconnect" href="https://fonts.gstatic.com">
<link rel="preconnect" href="https://fonts.gstatic.com">
<link
href="https://fonts.googleapis.com/css2?family=Raleway:wght@100&family=
Roboto+Mono&display=swap"
rel="stylesheet">
<link rel="preconnect" href="https://fonts.gstatic.com">
<link
href="https://fonts.googleapis.com/css2?family=Raleway:wght@100;700&fami
ly=Roboto+Mono&display=swap"
rel="stylesheet">
<link rel="preconnect" href="https://fonts.gstatic.com">
</head>
<body>
<br><br><br><br>
<div class="welcome ">
<h2 style="color: azure;">Phishinig Site Prediction</h2>
</div>
72
<div class="userinput">
<h2>Enter URL </h2>
<br>
<form action='/predict' method="post">
<div class="input">
<input id="url" name="z1" type="text" width="48" height="48" size="50"
required><br>
<button class="button" type="Summarize">Predict</button>
</div>
</form>
<br>
<br>
<div id='result'>
{{ prediction_text }}
</div>
</div>
</body>
</html>
style.css
*{
margin: 0px;
73
padding: 0px;
/* box-sizing:border-box; */
}
body{
/* background-image: linear-gradient(to right top, #051937, #004d7a,
#008793, #00bf72, #a8eb12); */
background: rgb(2,0,36);
background: linear-gradient(90deg, rgba(2,0,36,1) 0%, rgba(9,9,121,1)
35%, rgba(0,212,255,1) 100%);
/* background-image: linear-gradient( 63.1deg, rgba(5,23,111,1) 16.4%,
rgba(24,95,240,1) 64.5% ); */
height: 100vh;
font-family: 'Comfortaa', cursive;
@keyframes typing {
from {
width: 0%
}
to {
width: 100%
}
}
@keyframes blink {
from, to {
border-color: transparent
74
}
50% {
border-color: orange;
}
}
#url
{
height:90px;
font-size:14pt;
}
.welcome{
margin:auto;
width: 100%;
font-family: 'Raleway', sans-serif;
color:azure;
font-size: 50px;
font-weight: bold;
text-align:center;
padding: 24px;
}
.userinput{
padding-top: 3px;
/* width: 850px; */
width: 100%;
/* border: 5px solid gray; */
margin:auto;
/* border-collapse: collapse; */
75
font-family: Calibri;
font-style: normal;
font-weight: bold;
text-align:center;
font-family: 'Raleway', sans-serif;
border-collapse: collapse;
color:azure;
/* border-style:green; */
}
.output{
padding-top: 3px;
/* width: 850px; */
width: 100%;
/* border: 5px solid gray; */
margin:auto;
/* border-collapse: collapse; */
font-family: Calibri;
font-style: normal;
font-weight: bold;
text-align:center;
font-family: 'Raleway', sans-serif;
border-collapse: collapse;
/* border-style:green; */
}
.input-text{
/* padding-bottom: 5px; */
font-size: 20px;
76
border: none;
/* background-color:#A5D9EF; */
}
.button{
margin-top: 25px;
border-radius: 5px;
font-family: 'Roboto Mono', monospace;
padding: 12px;
}
button{
margin-top:50pt;
margin-bottom:20pt;
border: none;
color:black;
font-weight: bold;
padding: 15px 32px;
text-align: center;
text-decoration: none;
display: inline-block;
font-size: 16px;
margin: 4px 2px;
cursor: pointer;
}
#result{
margin:auto;
width: 100%;
77
font-family: 'Raleway', sans-serif;
color:azure;
font-size: 50px;
font-weight: bold;
text-align:center;
padding: 24px;
78
79
80
81
82
GITHUB LINK:
https://github.com/IBM-EPBL/IBM-Project-1835-1658417104
https://drive.google.com/file/d/1GuFHqKrZEXMVdTR1y8Jruxi
wsP4B3U0Y/view?usp=drivesdk
83