MaplePHP/Http is a powerful and easy-to-use PHP library that fully supports the PSR-7 HTTP message interfaces. It simplifies handling HTTP requests, responses, streams, URIs, and uploaded files, making it an excellent choice for developers who want to build robust and interoperable web applications.
With MaplePHP, you can effortlessly work with HTTP messages while adhering to modern PHP standards, ensuring compatibility with other PSR-7 compliant libraries.
- Full PSR-7 Compliance: Seamlessly integrates with other PSR-7 compatible libraries and frameworks.
- User-Friendly API: Designed with developers in mind for an intuitive and straightforward experience.
- Comprehensive Functionality: Handles all aspects of HTTP messaging, including requests, responses, streams, URIs, and file uploads.
- Flexible and Extensible: Easily adapts to projects of any size and complexity.
Install MaplePHP via Composer:
composer require maplephp/http
To create a server request, use the ServerRequest
class:
use MaplePHP\Http\ServerRequest;
use MaplePHP\Http\Uri;
use MaplePHP\Http\Environment;
// Create an environment instance (wraps $_SERVER)
$env = new Environment();
// Create a URI instance from the environment
$uri = new Uri($env->getUriParts());
// Create the server request
$request = new ServerRequest($uri, $env);
You can easily access various parts of the request:
// Get the HTTP method
$method = $request->getMethod(); // e.g., GET, POST
// Get request headers
$headers = $request->getHeaders();
// Get a specific header
$userAgent = $request->getHeaderLine('User-Agent');
// Get query parameters
$queryParams = $request->getQueryParams();
// Get parsed body (for POST requests)
$parsedBody = $request->getParsedBody();
// Get uploaded files
$uploadedFiles = $request->getUploadedFiles();
// Get server attributes
$attributes = $request->getAttributes();
Requests are immutable; methods that modify the request return a new instance:
// Add a new header
$newRequest = $request->withHeader('X-Custom-Header', 'MyValue');
// Change the request method
$newRequest = $request->withMethod('POST');
// Add an attribute
$newRequest = $request->withAttribute('user_id', 123);
Create a response using the Response
class:
use MaplePHP\Http\Response;
use MaplePHP\Http\Stream;
// Create a stream for the response body
$body = new Stream('php://temp', 'rw');
// Write content to the body
$body->write('Hello, world!');
$body->rewind();
// Create the response with the body
$response = new Response($body);
You can set the HTTP status code and headers:
// Set the status code to 200 OK
$response = $response->withStatus(200);
// Add headers
$response = $response->withHeader('Content-Type', 'text/plain');
// Add multiple headers
$response = $response->withAddedHeader('X-Powered-By', 'MaplePHP');
To send the response to the client:
// Output headers
foreach ($response->getHeaders() as $name => $values) {
foreach ($values as $value) {
header(sprintf('%s: %s', $name, $value), false);
}
}
// Output status line
header(sprintf(
'HTTP/%s %s %s',
$response->getProtocolVersion(),
$response->getStatusCode(),
$response->getReasonPhrase()
));
// Output body
echo $response->getBody();
Streams are used for the message body in requests and responses.
Reading and Writing with stream
use MaplePHP\Http\Stream;
// Create a stream from a file
//$fileStream = new Stream('/path/to/file.txt', 'r');
// Create a stream from a string
$memoryStream = new Stream(Stream::MEMORY);
//$memoryStream = new Stream('php://memory', 'r+'); // Same as above
$memoryStream->write('Stream content');
// Write to the stream
$memoryStream->write(' More content');
// Read from the stream
$memoryStream->rewind();
echo $memoryStream->getContents();
// Result: 'Stream content More content'
// Set stream as the body of a response
$response = $response->withBody($memoryStream);
URIs are used to represent resource identifiers.
// Create a URI instance
$uri = new Uri('http://example.com:8000/path?query=value#fragment');
// Modify the URI
$uri = $uri->withScheme('https')
->withUserInfo('guest', 'password123')
->withHost('example.org')
->withPort(8080)
->withPath('/new-path')
->withQuery('query=newvalue')
->withFragment('section1');
// Convert URI to string
echo $uri; // Outputs the full URI
//Result: https://guest:password123@example.org:8080/new-path?query=newvalue#section1
echo $uri->getScheme(); // 'http'
echo $uri->getUserInfo(); // 'guest:password123'
echo $uri->getHost(); // 'example.org'
echo $uri->getPath(); // '/new-path'
echo $uri->getQuery(); // 'key=newvalue'
echo $uri->getFragment(); // 'section1'
echo $uri->getAuthority(); // 'guest:password123@example.org:8080'
Manage file uploads with ease using the UploadedFile
class.
// Get uploaded files from the request
$uploadedFiles = $request->getUploadedFiles();
// Access a specific uploaded file
$uploadedFile = $uploadedFiles['file_upload'];
// Get file details
$clientFilename = $uploadedFile->getClientFilename();
$clientMediaType = $uploadedFile->getClientMediaType();
// Move the uploaded file to a new location
$uploadedFile->moveTo('/path/to/uploads/' . $clientFilename);
Send HTTP requests using the built-in HTTP client.
use MaplePHP\Http\Client;
use MaplePHP\Http\Request;
// Init request client
$client = new Client([CURLOPT_HTTPAUTH => CURLAUTH_DIGEST]); // Pass on Curl options
// Create request data
$request = new Request(
"POST", // The HTTP Method (GET, POST, PUT, DELETE, PATCH)
"https://admin:mypass@example.com:443/test.php", // The Request URI
["customHeader" => "lorem"], // Add Headers, empty array is allowed
["email" => "john.doe@example.com"] // Post data
);
// Pass request data to client and POST
$response = $client->sendRequest($request);
if ($response->getStatusCode() === 200) {
// Parse the response body
$data = json_decode($response->getBody()->getContents(), true);
// Use the data
echo 'User Name: ' . $data['name'];
} else {
echo 'Error: ' . $response->getReasonPhrase();
}
MaplePHP/Http is a comprehensive library that makes working with HTTP in PHP a breeze. Its full PSR-7 compliance ensures that your applications are built on solid, modern standards, promoting interoperability and maintainability.
Whether you're handling incoming requests, crafting responses, manipulating URIs, working with streams, or managing file uploads, MaplePHP provides a clean and intuitive API that simplifies your development process.
Get started today and enhance your PHP applications with MaplePHP!