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

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.

`

Glenn S

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.

jgotti

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.

`

mark at markvange * com

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();

`