PHP: Hypertext Preprocessor (original) (raw)
fclose
(PHP 4, PHP 5, PHP 7, PHP 8)
fclose — Closes an open file pointer
Description
Parameters
stream
The file pointer must be valid, and must point to a file successfully opened by fopen() or fsockopen().
Return Values
Returns [true](reserved.constants.php#constant.true)
on success or [false](reserved.constants.php#constant.false)
on failure.
Examples
Example #1 A simple fclose() example
`<?php
$handle
= fopen('somefile.txt', 'r');fclose($handle);?>`
See Also
- fopen() - Opens file or URL
- fsockopen() - Open Internet or Unix domain socket connection
Found A Problem?
jricher at jacquesricher dot com ¶
20 years ago
`It is a GOOD_THING to check the return value from fclose(), as some operating systems only flush file output on close, and can, therefore, return an error from fclose(). You can catch severe data-eating errors by doing this.
I learned this the hard way.
`
2 years ago
`Note that from PHP 8.0 onwards, attempting to close a stream that is already closed will throw a fatal TypeError.
Prior to PHP 8, this just caused a warning (that you can silence with @).
`
daniel7 dot martinez at ps dot ge dot com ¶
23 years ago
Generally, it's always a good idea to close a file when you're done with it. It's very easy for something to go wrong and corrupt a file that hasn't been closed properly. If you're concerned about efficiency, the overhead is negligible.
12 years ago
`In case you have some trouble to properly disconnect some client streams opened with stream_socket_server / stream_select you should give a try to stream_socket_shutdown.
`
18 years ago
It is very important to make sure you clear any incoming packets out of the incoming buffer using fread() or some equivalent. Although you can call fclose() the socket does not actually shut down until the inbound packets have been cleared. This can lead to some confusion.
tom dot vom dot berg at online dot de ¶
11 years ago
`if you want to daysychain a filehandle through some functions and each function is allowed to close th file you might look in a following function first, if the handle is still valid.
Opening a file, there often will be used a code like
if (!$fh = fopen($filename, $mode)) return false;
But if you possably have closed the file and you want to check that, a smililar statement would not work.
DOES NOT WORK: if (!$fh) end_of_chain();
use beter: if (is_resource($fh)) end_of_chain();
`