PSR-7 is a PHP Standard Recommendation (PSR) that focuses on HTTP messages in PHP. It was developed by the PHP-FIG (Framework Interoperability Group) and defines interfaces for working with HTTP messages, as used by web servers and clients.
Request and Response:
PSR-7 standardizes how HTTP requests and responses are represented in PHP. It provides interfaces for:
Immutability:
All objects are immutable, meaning that any modification to an HTTP object creates a new object rather than altering the existing one. This improves predictability and makes debugging easier.
Streams:
PSR-7 uses stream objects to handle HTTP message bodies. The StreamInterface defines methods for interacting with streams (e.g., read()
, write()
, seek()
).
ServerRequest:
The ServerRequestInterface extends the RequestInterface to handle additional data such as cookies, server parameters, and uploaded files.
Middleware Compatibility:
PSR-7 serves as the foundation for middleware architectures in PHP. It simplifies the creation of middleware components that process HTTP requests and manipulate responses.
PSR-7 is widely used in modern PHP frameworks and libraries, including:
The goal of PSR-7 is to improve interoperability between different PHP libraries and frameworks by defining a common standard for HTTP messages.
PSR-6 is a PHP-FIG (PHP Framework Interoperability Group) standard that defines a common interface for caching in PHP applications. This specification, titled "Caching Interface," aims to promote interoperability between caching libraries by providing a standardized API.
Key components of PSR-6 are:
Cache Pool Interface (CacheItemPoolInterface
): Represents a collection of cache items. It's responsible for managing, fetching, saving, and deleting cached data.
Cache Item Interface (CacheItemInterface
): Represents individual cache items within the pool. Each cache item contains a unique key and stored value and can be set to expire after a specific duration.
Standardized Methods: PSR-6 defines methods like getItem()
, hasItem()
, save()
, and deleteItem()
in the pool, and get()
, set()
, and expiresAt()
in the item interface, to streamline caching operations and ensure consistency.
By defining these interfaces, PSR-6 allows developers to easily switch caching libraries or integrate different caching solutions without modifying the application's core logic, making it an essential part of PHP application development for caching standardization.
PSR-4 is a PHP standard recommendation that provides guidelines for autoloading classes from file paths. It is managed by the PHP-FIG (PHP Framework Interop Group) and defines a way to map the fully qualified class names to the corresponding file paths. This standard helps streamline class loading, especially in larger projects and frameworks.
Namespace Mapping: PSR-4 requires that the namespace and class name match the directory structure and file name. Each namespace prefix is associated with a base directory, and within that directory, the namespace hierarchy corresponds directly to the directory structure.
Base Directory: For each namespace prefix, a base directory is defined. Classes within that namespace are located in subdirectories of the base directory according to their namespace structure. For example:
App\Controllers
, the file would be located in a folder like /path/to/project/src/Controllers
.File Naming: The class name must match the filename exactly, including case sensitivity, and end with .php
.
Autoloader Compatibility: Implementing PSR-4 ensures compatibility with modern autoloaders like Composer’s, allowing PHP to locate and include classes automatically without manual require
or include
statements.
Suppose you have the namespace App\Controllers\UserController
. According to PSR-4, the directory structure would look like:
/path/to/project/src/Controllers/UserController.php
In Composer’s composer.json
, this mapping is specified like so:
{
"autoload": {
"psr-4": {
"App\\": "src/"
}
}
}
This configuration tells Composer to load classes in the App
namespace from the src/
directory. When you run composer dump-autoload
, it sets up the autoloading structure to follow PSR-4 standards.
PSR-4 has replaced the older PSR-0 standard, which had more restrictive rules on directory structure, making PSR-4 the preferred autoloading standard for modern PHP projects.
Monolog is a popular PHP logging library that implements the PSR-3 logging interface standard, making it compatible with PSR-3-compliant frameworks and applications. Monolog provides a flexible and structured way to log messages in PHP applications, which is essential for debugging and application maintenance.
Logger Instance: The core of Monolog is the Logger
class, which provides different log levels (e.g., debug
, info
, warning
, error
). Developers use these levels to capture log messages of varying severity in their PHP applications.
Handlers: Handlers are central to Monolog’s functionality and determine where and how log entries are stored. Monolog supports a variety of handlers, including:
Formatters: Handlers can be paired with Formatters to customize the log output. Monolog includes formatters for JSON output, simple text formatting, and others to suit specific logging needs.
Processors: In addition to handlers and formatters, Monolog provides Processors, which attach additional contextual information (e.g., user data, IP address) to each log entry.
Here is a basic example of initializing and using a Monolog logger:
use Monolog\Logger;
use Monolog\Handler\StreamHandler;
$logger = new Logger('name');
$logger->pushHandler(new StreamHandler(__DIR__.'/app.log', Logger::WARNING));
// Creating a log message
$logger->warning('This is a warning');
$logger->error('This is an error');
Monolog is widely adopted in the PHP ecosystem and is especially popular with frameworks like Symfony and Laravel.
PSR-3 is a PHP-FIG (PHP Framework Interoperability Group) recommendation that establishes a standardized interface for logging libraries in PHP applications. This interface defines methods and rules that allow developers to work with logs consistently across different frameworks and libraries, making it easier to replace or change logging libraries within a project without changing the codebase that calls the logger.
Standardized Logger Interface: PSR-3 defines a Psr\Log\LoggerInterface
with a set of methods corresponding to different log levels, such as emergency()
, alert()
, critical()
, error()
, warning()
, notice()
, info()
, and debug()
.
Log Levels: The standard specifies eight log levels (emergency, alert, critical, error, warning, notice, info, and debug), which follow an escalating level of severity. These are based on the widely used RFC 5424 Syslog protocol, ensuring compatibility with many logging systems.
Message Interpolation: PSR-3 includes a basic formatting mechanism known as message interpolation, where placeholders (like {placeholder}
) within log messages are replaced with actual values. For instance:$logger->error("User {username} not found", ['username' => 'johndoe']);
This allows for consistent, readable logs without requiring complex string manipulation.
Flexible Implementation: Any logging library that implements LoggerInterface
can be used in PSR-3 compatible code, such as Monolog, which is widely used in the PHP ecosystem.
Error Handling: PSR-3 also allows the log()
method to be used to log at any severity level dynamically, by passing the severity level as a parameter.
Here’s a basic example of how a PSR-3 compliant logger might be used:
use Psr\Log\LoggerInterface;
class UserService
{
private $logger;
public function __construct(LoggerInterface $logger)
{
$this->logger = $logger;
}
public function findUser($username)
{
$this->logger->info("Searching for user {username}", ['username' => $username]);
// ...
}
}
For more details, you can check the official PHP-FIG documentation for PSR-3.
PSR-2 is a coding style guideline for PHP developed by the PHP-FIG (Framework Interop Group) to make code more readable and consistent, allowing development teams to collaborate more easily. The abbreviation “PSR” stands for “PHP Standards Recommendation”.
{
for classes and methods should be on the next line, whereas braces for control structures (like if
, for
) should be on the same line.=
, +
).Here’s a simple example following these guidelines:
<?php
namespace Vendor\Package;
class ExampleClass
{
public function exampleMethod($arg1, $arg2 = null)
{
if ($arg1 === $arg2) {
throw new \Exception('Arguments cannot be equal');
}
return $arg1;
}
}
PSR-2 has since been expanded and replaced by PSR-12, which includes additional rules to further improve code consistency.
PSR-1 is a PHP Standards Recommendation created by the PHP-FIG (Framework Interop Group) that defines basic coding standards for PHP code style and structure to ensure interoperability between different PHP projects and frameworks. Its main purpose is to establish a consistent baseline for PHP code, making it easier to understand and collaborate on projects across the PHP ecosystem. PSR-1, also known as the Basic Coding Standard, includes several key guidelines:
File Formatting:
<?php
or <?=
tags.Namespace and Class Names:
StudlyCaps
(PascalCase).Constants, Properties, and Method Naming:
CONST_VALUE
).camelCase
.Autoloading:
include
or require
statements.PSR-1 is considered a foundational standard, and it works in tandem with PSR-2 and PSR-12, which define more detailed code formatting guidelines. Together, these standards help improve code readability and consistency across PHP projects.
"Lines of Code" (LOC) is a software development metric that measures the number of lines written in a program or application. This metric is often used to gauge the size, complexity, and effort required for a project. LOC is applied in several ways:
Code Complexity and Maintainability: A high LOC count can suggest that a project is more complex or harder to maintain. Developers often aim to keep code minimal and efficient, as fewer lines typically mean fewer potential bugs and easier maintenance.
Productivity Measurement: Some organizations use LOC to evaluate developer productivity, though the quality of the code—rather than just quantity—is essential. A high number of lines could also result from inefficient solutions or redundancies.
Project Progress and Estimations: LOC can help in assessing project progress or in making rough estimates of the development effort for future projects.
While LOC is a simple and widely used metric, it has limitations since it doesn’t reflect code efficiency, readability, or quality.
Churn PHP is a tool that helps identify potentially risky or high-maintenance pieces of code in a PHP codebase. It does this by analyzing how often classes or functions are modified (churn rate) and how complex they are (cyclomatic complexity). The main goal is to find parts of the code that change frequently and are difficult to maintain, indicating that they might benefit from refactoring or closer attention.
In essence, Churn PHP helps developers manage technical debt by flagging problematic areas that could potentially cause issues in the future. It integrates well with Git repositories and can be run as part of a CI/CD pipeline.
PHPmetrics is a static analysis tool designed for PHP code, providing insights into the code’s complexity, maintainability, and overall quality. It helps developers by analyzing various aspects of their PHP projects and generating reports that visualize metrics. This is especially useful for evaluating large codebases and identifying technical debt.
It’s commonly integrated into continuous integration workflows to maintain high code quality throughout the development lifecycle.
By using PHPmetrics, teams can better understand and manage their code's long-term maintainability and overall health.