-
Layout
-
Infrastructure
- Client-Server
- One Server
- Many Servers - One Database
- Many Servers - Many Databases
-
Components
- Client
-
Server
- Webserver
- Web Application Logic
- Database
-
Services (Microservices)
- Ratings
- Payments
- Registration
- Search
- Functions (Serverless)
-
Architecture
-
Presentation Layer
- Consists of UI process components that enable communication with the application and the system
-
Application Layer
- ensures that all client requests (web requests) are correctly processed
-
Data Layer
- determine exactly where the required data is stored and can be accessed
-
Back End
-
Components
-
Back End Servers
-
LAMP
- Linux, Apache, MySQL, and PHP
-
MAMP
- macOS, Apache, MySQL, and PHP
-
XAMPP
- Cross-Platform, Apache, MySQL, and PHP/PERL
-
WINS
- Windows, IIS, .NET, and SQL Server
-
WAMP
- Windows, Apache, MySQL, and PHP
-
Web Servers
- Apache
- NGINX
- IIS
-
Databases
- Relational (SQL)
- Non-relational (NoSQL)
-
Development Frameworks & APIs
-
Development Frameworks
- Laravel (PHP)
- Express (Node.JS)
- Django (Python)
- Rails (Ruby)
-
APIs
- SOAP
- shares data through XML
- REST
- shares data through the URL path
- returns the output in JSON format
-
Vulnerabilities
- Broken Authentication/Access Control
- Malicious File Upload
- Command Injection
- SQL Injection (SQLi)
-
Public Vulnerabilities
- Public CVE
- CVSS
-
Front End
-
Components
- HTML
- CSS
- JavaScript
-
Vulnerabilities
- HTML Injection
- Sensitive Data Exposure
- Cross-Site Scripting (XSS)
- Cross-Site Request Forgery (CSRF)
-
Distribution
-
open-source
- Joomla
- WordPress
- OpenCart
-
closed source
- Wix
- DotNetNuke
- Shopify