You can also find all 100 answers here π Devinterview.io - PHP
PHP originally represented "Personal Home Page," signifying its early focus on web development. It has since evolved to suggest "PHP: Hypertext Preprocessor," emphasizing its role in server-side scripting and building dynamic web content.
- Generating Dynamic Content: PHP is adept at generating dynamic web content, web pages, images, and more.
- Handling Form Data: It efficiently processes form data from HTML input fields.
- Accessing Databases: PHP can interact with databases, empowering dynamic content storage and management.
- Session Management: It enables web state management, crucial for maintaining user context across multiple requests.
- File System Interaction: PHP can manipulate files on the server filesystem.
- Email Sending: It provides the capability to send emails directly from the server.
- User Authentication: PHP can authenticate users and manage their access within web applications.
- Server-Side Scripting Language: PHP excels in orchestrating server operations, including complex storage and retrieval tasks.
- HTML Embedding Compatibility: Its syntax within web documents is reminiscent of HTML, interleaving with the content for seamless integration.
- Not Purely Object-Oriented: While it now supports object-oriented programming paradigms, it continues to offer primarily procedural constructs.
- Text Pre-Processor and Interpreter: PHP initially parses embedded code within text via the pre-processor, swiftly executing it to yield HTML or other output.
Executing a PHP script from the command line involves using the php
CLI tool.
To run a PHP script, use the following command:
php your_script.php
- Input: The
-f
option allows you to provide a file. - Output: Use
-i
to see the configuration, and-r
to run a snippet without a script. - When Installed:
--run
is an alternative for Unix systems without a shebang line. - PHP Version: Use
-v
to check the installed PHP version.
-
Running a File:
php -f script.php
-
Displaying PHP Info:
php -i
-
Running a Single Command:
php -r 'echo "Hello, PHP!";'
You can configure PHP-specific environment variables, allowing for script customization or convenience. For example:
- Using a different configuration file:
php -c <custom-config>.ini -f script.php
- Customizing extensions' path:
PHP_INI_SCAN_DIR=/path/to/extensions php -f script.php
By default, PHP's CLI environment allows input from the terminal or using pipes. It prints output to the terminal.
Redirections and Pipelines, such as >
or |
, can be leveraged for customizing how input and output are handled.
- Sending output to a file:
php script.php > output.txt
- Appending to a file:
php script.php >> output.txt
- Reading from a file:
php script.php < input.txt
Pipelines can be used for more complex I/O operations. The following example involves running script.php
, which produces a list of URLs, and then the crawler.php
script visits each of those URLs:
php script.php | php crawler.php
On certain platforms, you might need to use php-cgi
or specify the .exe
extension. For instance:
- Windows:
php-cgi.exe your_script.php
- macOS:
/usr/bin/php your_script.php
It's also common to need to add PHP to your system's path or reference PHP from an absolute path.
Migrating from PHP 5 to PHP 7/8 provides significant improvements in performance, security, and features. However, this transition involves several changes that need to be navigated.
- PHP 5: Lacked strict scalar typing.
- PHP 7/8: Supports both
declare(strict_types=1);
for individual files and scalar type hints (int, float, bool, string) in function/method signatures.
- PHP 5: Couldn't specify return types.
- PHP 7/8: Enables declaring specific return types using inline notations.
- PHP 5: Absent.
- PHP 7/8: Introduced the
??
operator, streamlining null checks.
- PHP 5: Lacked support.
- PHP 7/8: Introduced the
<=>
operator for clearer comparisons.
- PHP 5: Limited to defined constants.
- PHP 7/8: Allows defining arrays and objects with the
define
keyword.
- PHP 5: Lacked support for on-the-fly class definition.
- PHP 7/8: Introduced classes without explicit declarations.
- PHP 5: No specific hint for iterable types.
- PHP 7/8: Offers the
iterable
type hint, providing a generic type for traversable data structures.
- PHP 5: Weaker random number generation.
- PHP 7/8: Provides stronger cryptographic random number functions like
random_bytes
andrandom_int
.
- PHP 5: Required the
use
keyword for accessing outer scope. - PHP 7/8: They are now able to automatically capture variables from the outer scope, which eases the syntax.
- PHP 7.1: Introduced the
?Type
notation to indicate that a function can return either the specified type ornull
.
- PHP 7.4: The
typed_properties=1
directive for strict typing at the class level. - PHP 8: Introduced
::class
constant that returns the class name.
- PHP 8: Ability to specify union types in method/function signatures, defining multiple possible return types separated by vertical bars. Example:
function foo(): int|bool
. - Initial PHP 7.1 Support: The
iterable
type hint was introduced in PHP 7.1.
- PHP 8: Offers the
match
/case
expression as a more precise and powerful variant ofswitch
statements.
- PHP 8: Allows passing arguments to functions based on their parameter names rather than positions, enhancing clarity.
While there are several ways to embed PHP within HTML, the <?php
tag, which encloses PHP code, is the most widely used. It's important to note that the choice of method should align with the practical needs of your project.
- Advantages: More concise and readable.
- Drawbacks: Not always enabled; deprecated after PHP v7.0.
- Advantages: Familiar to ASP developers.
- Drawbacks: Not default behavior; must be enabled.
- Advantages: Can be useful in very specific cases.
- Drawbacks: phpBB and Bugs.
- Advantages: No need for PHP module.
- Drawbacks: Integration concerns.
These tags are always a safe choice and offer the highest compatibility across platforms.
<?php
// Your PHP code here
?>
It's worth noting that <?=
is a shortcut equivalent to <?php echo
, available in all versions beyond PHP v5.4.
- Standardized, cross-platform approach.
- Compatible with all PHP builds and hosting environments.
- Enhanced readability and maintainability.
Here is the PHP code:
<!DOCTYPE html>
<html>
<head>
<title>PHP in HTML</title>
</head>
<body>
<?php
$name = "John";
echo "<h1>Welcome, $name!</h1>";
?>
</body>
</html>
PHP variables have diverse scopes, from being accessible globally by all scripts to being confined to defined functions or methods. They can be local, global, and static.
Variables defined within a function are locally scoped and inaccessible outside its body.
Here is the PHP code:
function myFunc() {
$localVar = "I am local";
echo $localVar; // Outputs: I am local
}
myFunc();
echo $localVar; // Throws an error
Global variables can be accessed across the entire PHP script, including from within functions.
Here is the PHP code:
$globalVar = "I am global";
function myFunc() {
echo $globalVar; // Outputs: I am global
}
myFunc();
echo $globalVar; // Outputs: I am global
Variables declared within a function or method are limited in scope to that block.
Here is the PHP code:
function myFunc() {
$functionVar = "I am function-scoped";
echo $functionVar; // Outputs: I am function-scoped
}
myFunc();
echo $functionVar; // Throws an error
Static variables retain their values between function calls. They are still function-scoped.
Here is the PHP code:
function counter() {
static $count = 0;
$count++;
echo $count;
}
counter(); // Outputs: 1
counter(); // Outputs: 2
counter(); // Outputs: 3
In PHP, some special predefined arrays, such as $_POST
and $_GET
, are super global and have a global scope. They are accessible from any part of the code, including within functions and methods.
PHP supports various data types, each serving a distinct role.
-
Integer (
int
in PHP 7,integer
in earlier versions): Represents whole numbers, both positive and negative.- Example:
$age = 30;
- Example:
-
Floating-Point Number (
float
): Represents decimal numbers, also known as floats or doubles.- Example:
$price = 9.99;
- Example:
-
String (
string
): Signifies sequences of characters, enclosed within single or double quotes.- Example:
$name = "John";
- Example:
-
Boolean (
bool
): Represents logical states -true
orfalse
.- Example:
$isStudent = true;
- Example:
-
Resource: Placeholder for external resources, such as database connections.
-
Null: Denotes the absence of a value.
-
Array: A flexible and indexed data structure that can hold multiple values of different data types.
-
Object: Instances of defined classes that encapsulate data and behavior.
-
Callable: Ensures that a variable is a valid function or method.
-
Iterable: Introduced in PHP 7.1. Any data type that can be looped via
foreach
.- Example:
array
andTraversable
(interface implemented by arrays and classes that are loop-able).
- Example:
PHP has two special types:
-
Pseudotype: These are not actual data types but are considered basic types in PHP.
-
Literal: Introduced in PHP 8, such as
mixed
, that can accept multiple primitive types.
Here is the PHP code:
// Create associative array
$person = [
'name' => 'Alice',
'age' => 25,
'isStudent' => true
];
// Define class
class Car {
public $make;
public $model;
public function __construct($make, $model) {
$this->make = $make;
$this->model = $model;
}
}
// Instantiate Car object
$myCar = new Car('Toyota', 'Corolla');
// Define function that takes callable parameter
function testFunction(callable $callback) {
$callback();
}
// Call function and pass an anonymous function
testFunction(function() {
echo "Callback executed!";
});
In PHP, Error Handling can be configured using either .ini
settings, programmatic functions, or a combination of both, offering developers great flexibility.
- Local (File-Specific): Adjusts settings for a specific PHP file using
ini_set()
. - Global: Modifies global PHP settings via
php.ini
orini_set()
.
-
Using Functions:
error_reporting(E_ALL)
enables all types of errors. To target specific error types, bitwise operators come in handy. -
Using php.ini: Directly edit the
php.ini
file. Settingerror_reporting
toE_ALL
enables comprehensive reporting. -
Using ini_set(): For finer control, use
ini_set('error_reporting', E_ALL)
when you need to adjust settings on a per-file basis.
Or direct the errors to a display or a log:
- To display errors on the screen, configure
display_errors
asOn
. - To log errors to a file, enable them by setting
log_errors
toOn
and define the log file witherror_log
.
-
E_NOTICE: Informs about non-critical discrepancies.
-
E_WARNING: Alerts about more critical problems.
-
E_ERROR: Indicates serious faults that halt script execution.
-
E_PARSE: Arises from parse errors, such as syntax mistakes.
-
E_STRICT: Suggests updates to code for better interoperability.
-
E_DEPRECATED: Flags features that are outdated and might be removed in future versions.
-
E_RECOVERABLE_ERROR: Major issues that still allow script execution.
Developers can use error_reporting()
in conjunction with bitwise operators to set multiple flags. For example:
error_reporting(E_ALL & ~E_DEPRECATED)
reports all errors except deprecation notices.error_reporting(E_ERROR | E_WARNING | E_PARSE)
reports only errors, warnings, and parse errors.
Here is the PHP code:
// Enable error reporting
error_reporting(E_ALL);
ini_set('display_errors', 1);
// Generate a warning
$totalCost = 100;
$availableFunds = 50;
if ($totalCost > $availableFunds) {
trigger_error("Insufficient funds!", E_USER_WARNING);
}
// Generate a fatal error
require 'non_existent_file.php';
// Will not reach this point due to the fatal error above
echo "This will never be displayed.";
The php.ini file is the configuration center for PHP settings, governing a range of operational aspects. It is an essential tool for managing a server's PHP environment.
-
Settings Management: The file allows for the configuration of PHP settings, offering granular control over key directives such as memory_limit and error_reporting.
-
Environment Tailoring: By modifying php.ini, developers can fine-tune PHP to best suit their specific applications and environments.
-
Error and Security Settings: The file provides a centralized location to manage error reporting, display, and log settings, alongside various security-related configurations.
-
It's important to note that \foo` variable.
-
The file can have different variations across PHP versions, and its absence can pose a problem when troubleshooting.
- Per-Directory Basis: Some servers permit PHP settings to be defined locally within directories via .htaccess or lighttpd.conf files.
- Run-Time Editing: Certain settings can be reconfigured dynamically via ini_set during script execution.
-
Runtime Security: Encrypt or protect the php.ini file to prevent unauthorized access, particularly in environments involving shared hosting.
-
Centralized Management: Utilize Version Control Systems (VCS) or configuration management tools to maintain and track changes in the php.ini file.
-
Regular Audits: Review the php.ini file periodically to ensure it aligns with security best practices and application requirements.
In PHP, a constant is a named identifier whose value remains consistent during the execution of a script.
- Case-Sensitivity: Constants are not case-sensitive by default.
- Global Scope: Constants can be accessed from any part of the code without additional requirements.
- Value Types: Constants can hold values like integers, floats, strings, or arrays.
- NAME: The designated constant name (specific naming rules apply).
- value: The constant's assigned literal value or expression.
- case-insensitive (Optional): A boolean flag (
true
for case-insensitive) determining if the constant's name is case-sensitive.
Here is the PHP code:
// Case-sensitive constant
define("GREETING", "Hello, World!");
// Case-insensitive constant
define("SITE_NAME", "MySite", true);
// Accessing constants
echo GREETING; // Output: "Hello, World!"
echo SITE_NAME; // Output: "MySite" or "MYSITE"
- Unique Names: Use distinct, self-explanatory names to avoid unintended overwrites or misinterpretations.
- Error Reporting: Pay attention to constant re-declarations or undefined constants to ensure script reliability.
- Initialization: Ideally, constants should be defined within the script's beginning to ensure consistent values across the application.
- Code Clarity: Employ uppercase letters and underscores to boost constant visibility and readability.
- Constants Beyond Strings: While strings are frequently used, note that constants can store various data types like integers, floats, and arrays.
Understanding the detailed lifecycle of a PHP request will help you optimize your web applications for better performance.
-
Bootstrap
- Code in your
index.php
file initializes the PHP environment.
- Code in your
-
Pre-Processing
- PHP compiles the requested file into opcode, if necessary.
- The Zend Engine, which powers PHP, loads necessary extensions and sets up internal structures.
-
Request Processing
- PHP scripts execute from top to bottom, unless there's a redirect, error, or exit.
-
Output Buffering
- The
ob_
family of functions handles application output buffering.
- The
-
Response
- When execution completes, the built-up output is sent back to the webserver for final delivery to the client.
- httpd: Apache and Nginx are popular HTTP servers that manage incoming requests.
- PHP Parser: Translates human-readable PHP code into machine-readable instructions.
- When a web server, such as Apache or Nginx, processes an incoming HTTP request, it detects PHP as the handler for
.php
files and launches the PHP parser.
One of the stumbling blocks for new PHP developers to get to grips with is that setting local redirects will halt script execution:
header('Location: /new_page.php');
exit;
One notable example of this behavior, especially in one-page (or one-script) applications, is the usage of the exit
construct right after setting a location header. This abrupt exit can sometimes become problematic in larger projects or if not carefully managed. It is often more advisable to architect your applications with a more streamlined version of redirects and exits; consider using the "inverted if" approach to reduce nested levels.
Sessions enable secure storage and retrieval of user information throughout their interaction with a web application.
- Session Creation: Starts when a user accesses a web page and initializes a session, providing a unique session ID for that user.
- Data Persistence: Allows data to persist across different pages, often using session cookies.
- Data Lifetime: Information remains accessible during the user's visit and can be configured to extend over multiple visits.
Starting a session in PHP is straightforward, and many frameworks handle this process automatically. Simply call session_start()
at the beginning of each PHP script.
// Initialize session
session_start();
You can then use super-global variable $_SESSION
to store and retrieve data.
- Automatic: Set
session.auto_start
to 1 inphp.ini
, and the session begins for all pages. - Manual: Starts when a PHP script calls
session_start()
explicitly.
You can control session behavior and security using session_start()
and session_set_cookie_params()
. Here's the breakdown:
- Session timeout: Set the session lifetime using
session.gc_maxlifetime
. Sessions might be deleted by the PHP garbage collector if not accessed within this time. - Cookie parameters: Configure session cookies for secure, HTTP-only, and domain-specific behavior.
- Token-based protection: Use CSRF tokens to safeguard against Cross-Site Request Forgery.
Sessions are highly valuable but require vigilance for security. Here are some best practices:
- SSL/TLS Encryption: Secure the entire session with a proper SSL/TLS certificate.
- Session Fixation Prevention: Generate a fresh session ID upon user authentication to deter session fixation attacks.
- Session Hijacking Prevention: Regularly switch session IDs and restrict sessions to the user's IP address or user agent if feasible.
Cookies are HTTP headers that help websites remember users. In PHP, you can achieve seamless cookie management using built-in functions.
-
setcookie: Creates a new cookie or modifies an existing one.
-
$_COOKIE: A global associative array that holds all set cookies, accessible from any script.
-
$_COOKIE[ 'cookieName' ]: Particularly useful for reading cookie values.
-
Example of Setcookie: Take a look!
// Set cookie with a value that expires in 24 hours
setcookie('username', 'JohnDoe', time()+86400, '/', '.example.com', true);
- Name: The cookie's unique identifier.
- Value: Data associated with the cookie.
- Expiration: Time when the cookie should expire.
- Path: The directory for which the cookie is valid.
- Domain: The domain for which the cookie is valid.
- Secure: Specifies if the cookie should be sent only over secure (HTTPS) connections.
- HttpOnly: When set to
true
, the cookie is accessible only through HTTP protocols.
Each of these superglobal arrays in PHP helps manage input data, but they have distinct characteristics and use-cases.
-
$_GET is URL-based. It extracts data from the query string. In other words, data is visible in the URL.
-
$_POST is form-based. It's suitable for handling sensitive or large data as it's not visible in the URL.
-
$_REQUEST is a combination of $_GET, $_POST, and $_COOKIE. If a parameter is accessible in multiple arrays, $_REQUEST uses the one with the highest precedence. However, its use is largely depreciated because it makes debugging and code maintenance more difficult. It's better to be specific by using $_GET or $_POST where applicable.
To prevent cross-site scripting (XSS) attacks on your website, it is crucial to validate and sanitize any data submitted through forms.
Escape form data using htmlspecialchars
to convert special characters to HTML entities.
echo htmlspecialchars($_POST['input']);
To prevent execution of JavaScript code, you can use:
-
JavaScript replace method: Replace the less-than and greater-than characters with their HTML entities.
$sanitized = str_replace(['<', '>'], ['<', '>'], $_POST['input']);
-
JSON encoding for non-text data in hidden fields.
$jsonEncoded = json_encode($_POST['data']);
Always perform thorough server-side validation and ensure only intended actions are executed in response to form submissions:
- Database Prepared Statements: Use prepared statements alongside parameterized queries when interfacing with the database.
- Strict Input Validation: Enforce strict criteria for input data. For instance, use
filter_var
for emails or regex for defined patterns. - Context-Aware Processing: Differentiate how the input will be used (e.g., in an email, as file content), and process accordingly.
Frameworks and libraries often provide dedicated modules to fortify against XSS threats. For instance, Laravel supports various middlewares such as VerifyCsrfToken, which especially help in guarding against CSRF attacks.
Here is the PHP code:
// Using htmlspecialchars for basic output
echo htmlspecialchars($_POST['input']);
// Using JSON to encode data going into hidden fields
$jsonEncoded = json_encode($_POST['data']);
// Using prepared statements for database queries
$stmt = $dbh->prepare("SELECT * FROM users WHERE username=?");
$stmt->execute([$_POST['username']]);
// Context-aware input verification
$filterOptions = [
"email" => [
"filter" => FILTER_VALIDATE_EMAIL,
"flags" => FILTER_FLAG_EMAIL_UNICODE
]
];
$email = filter_input(INPUT_POST, 'email', FILTER_VALIDATE_EMAIL, $filterOptions);
Both htmlspecialchars and strip_tags are crucial PHP functions that enhance security by mitigating Cross-Site Scripting (XSS) risks. They play specialized roles, catering to different requirements within web applications.
The primary purpose of htmlspecialchars
is to sanitize user input to render it harmless when displaying it on a web page. It achieves this by converting special characters into their respective HTML entities. By doing so, it prevents the accidental or unauthorized execution of HTML, JavaScript, or CSS, maintaining data integrity.
For instance, '<' is converted to "<"
, '>' to ">"
, '&' to "&"
, and quotes to their respective entity representations.
The comparative task of strip_tags
is somewhat more brute-force. It's designed to remove any HTML and PHP tags from the input. This is a potential security risk and is often discouraged, but it might be suitable when an application needs bare-bones, text-only input.
Developers can further refine strip_tags
by specifying allowable tags or attributes. However, it's still a less precise method compared to htmlspecialchars
with its exact handling of special characters.
For optimal data and user security, utilizing both functions is often the most recommended approach. This multi-layered strategy ensures that dangerous input goes through extensive sanitation measures.
When integrating user-generated content, especially in HTML contexts, it's crucial never to solely rely on strip_tags
. Balancing both subtlety and thoroughness, htmlspecialchars
is the more suitable choice in such scenarios.
Here is the PHP code:
$input = "<a href='#'>Malicious Link</a><script>alert('You have been hacked!')</script>";
$clean_html = htmlspecialchars($input, ENT_QUOTES, 'UTF-8');
$clean_text = strip_tags($input);
echo "Clean HTML: $clean_html\n"; // Outputs: <a href='#'>Malicious Link</a><script>alert('You have been hacked!')</script>
echo "Clean Text: $clean_text\n"; // Outputs: Malicious Linkalert('You have been hacked!')