PHP fread Function: How to Read Files in PHP

In some cases, you need to handle a lot of data or simply try to open a file, or read its contents. The fread function in PHP can help you manage file data, whether it’s in small chunks or all at once.

In the following sections, you will learn how to make fread work for you, with practical steps, examples, and tips for every stage. Let’s get into it!

What is the PHP “fread” Function?

The fread is a built-in function that lets you read specific amounts of data from a file. It is a tool that allows you to pull data in controlled, manageable chunks, especially useful when dealing with large files.

So, whether you are reading small text files or handling bigger data like JSON or logs.

let’s write its syntax:

fread(resource $handle, int $length): string|false
  • $handle: This is the file pointer resource. You get this from fopen, which tells fread what file to read from.
  • $length: This is the maximum number of bytes you want to read in one go.

Now, let’s break down how to open and read files and get this pointer resource.

Using “fopen” to Open a File and “fread” to Read Its Contents

Before you use fread, you need to open the file. PHP provides “fopen” for this purpose, which returns a file pointer required for fread to do its job.

Once your file is open, you can use fread to pull data from it. Here is an example:

$handle = fopen("example.txt", "r");
$contents = fread($handle, filesize("example.txt"));
fclose($handle);
echo $contents;
  • filesize("example.txt") tells fread to read the entire file size. This approach works well for small files.
  • fclose($handle) is important to free up resources after you are done reading.

Now, let’s dive into a situation where you don’t need to read the whole file at once.

Reading Large Files in Chunks

Reading in chunks is a great way for larger files. So, when you use fread, you can read part of the file, process it, and then move to the next part. Here is how that looks in an example:

$handle = fopen("largefile.txt", "r");
while (!feof($handle)) {
    $chunk = fread($handle, 1024); // Reads 1024 bytes (or 1KB) at a time
    echo $chunk;
}
fclose($handle);

Take a look at the feof($handle) function, it checks if we have reached the end of the file. As long as there is data, fread will keep pulling in 1KB chunks. This helps us with big files and also avoids memory overload.

Anyway, we can do the same job but with a JSON file, let’s move on to the below section to see how it works.

Reading JSON Files in Chunks

PHP fread also handles JSON files. Let’s see another example of reading a JSON file in 4KB chunks:

$handle = fopen("data.json", "r");
$data = "";
while (!feof($handle)) {
    $data .= fread($handle, 4096); // Reads 4KB at a time
}
fclose($handle);

$jsonArray = json_decode($data, true);
print_r($jsonArray);

Let’s see more examples.

PHP “fread” Examples

Here is an example for reading a small text file:

$handle = fopen("textfile.txt", "r");
echo fread($handle, filesize("textfile.txt"));
fclose($handle);

Reading a large log file in chunks:

$handle = fopen("logfile.log", "r");
while (!feof($handle)) {
    // Read the file in 2KB chunks
    echo fread($handle, 2048);  
}

// Close the file after reading
fclose($handle);

If you’re handling JSON data, here’s a small example to make it feel more complete:

$handle = fopen("data.json", "r");
$data = "";
while (!feof($handle)) {
    $data .= fread($handle, 4096); // Reads 4KB at a time
}
fclose($handle);
$jsonArray = json_decode($data, true);
print_r($jsonArray);

Let’s summarize it.

Wrapping Up

The PHP fread function gives us a reliable way to handle file reading, suitable for everything from small text files to larger datasets like logs or JSON. Here’s a quick recap:

  • Syntax: fread(resource $handle, int $length).
  • Opening Files: Start by opening files with fopen to create a file pointer.
  • Reading Modes: Use fread to read either the entire file or specific chunks based on your needs.
  • Close Files: Always close your files with fclose to free up resources.

    Similar Reads

    PHP Switch | How the Switch Statement Works in PHP

    The PHP switch statement is multiple conditions to only execute one block if its condition generating a true boolean value.…

    PHP $_SESSION: Secure Your Web Applications in PHP

    It’s very important to remember user data for each session when building web applications. This enables a high level of…

    PHP Integers Guide: Types, Limits, and Conversions

    You use integers (int) in PHP to count items, set page numbers, handle IDs, and manage loop counters. In this…

    PHP filter_id Function: How to Retrieve PHP Filter IDs

    Before PHP 5.2, there was no built-in filter extension in PHP. You had to manually handle and sanitize input. PHP…

    PHP strict_types: How the Strict Mode Works

    If you want to write good PHP code, strict mode should be on your radar. Strict mode—activated by the command declare(strict_types=1); at…

    How to Install PHP on a Raspberry Pi

    You can use your Raspberry Pi as a personal web server or tool that runs in your home. You do…

    OOP Interface PHP: How to Set Rules for Classes

    PHP developers relied on class inheritance to share functionality before the OOP interface, but this approach had limits. It solves…

    PHP SimpleXML: Work with XML in Examples

    PHP SimpleXML - invented for you to work with XML. Way leaner, quicker to get up. it's already integrated directly…

    PHP List MongoDB Collections

    Sometimes, you may need to list collections with MongoDB in a PHP environment to manage or analyze your database structure.…

    Understanding the Increment and decrement operators in PHP

    The increment and decrement are operators that can be used to increase or decrease the variable values which have a…

    Previous Article

    PHP mail() Function: A Complete Guide

    Next Article

    PHP fwrite: How to Write Data to Files in PHP

    Write a Comment

    Leave a Comment

    Your email address will not be published. Required fields are marked *


    Subscribe to Get Updates

    Get the latest updates on Coding, Database, and Algorithms straight to your inbox.
    No spam. Unsubscribe anytime.