PHP/resource: Difference between revisions

from HTYP, the free directory anyone can edit if they can prove to me that they're not a spambot
No edit summary
No edit summary
Line 1: Line 1:
==About==
==About==
In [[PHP]], a "resource" value is an opaque internal pointer for handling certain types of I/O-ish operations. As of PHP 8.5, although "resource" is "[https://www.php.net/manual/en/reserved.other-reserved-words.php soft-reserved] and is used as a documentation pseudotype,  there is no actual "resource" type; the only type which is currently known to be compatible with resource variables is "[https://www.php.net/manual/en/language.types.mixed.php <code>mixed</code>]". PHP currently interprets invocation of "<code>resource</code>" as a type as a reference to an unknown class named "{{fmt/arg|current namespace}}<code>\resource</code>".
In [[PHP]], a "resource" value is an opaque internal pointer for handling certain types of I/O-ish operations.
 
===Syntax===
Note that additional [https://www.php.net/manual/en/book.stream.php stream] resource types can be defined in code with [https://www.php.net/manual/en/function.stream-wrapper-register.php <code>stream_wrapper_register()</code>].
As of PHP 8.5, although "resource" is "[https://www.php.net/manual/en/reserved.other-reserved-words.php soft-reserved] and is used as a documentation pseudotype,  there is no actual "resource" type; the only type which is currently known to be compatible with resource variables is "[https://www.php.net/manual/en/language.types.mixed.php <code>mixed</code>]". PHP currently interprets invocation of "<code>resource</code>" as a type as a reference to an unknown class named "{{fmt/arg|current namespace}}<code>\resource</code>".
===Types===
There are many specialty resource-types defined by extensions, and a handful of more general types:
{| class=wikitable
! type || subtype || functions
{{!-!}} curl || cURL handle
{{!-!}} process || || <code>[https://www.php.net/manual/en/function.proc-open.php proc_open()], [https://www.php.net/manual/en/function.proc-get-status.php proc_get_status()], [https://www.php.net/manual/en/function.proc-terminate.php proc_terminate()], [https://www.php.net/manual/en/function.proc-close.php proc_close()]</code>
{{!-!}} stream || dir handle
{{!-!}} stream || file handle
{{!-!}} stream || process handle
{{!-!}} socket || file handle
{{!-!}} ssh2 session
{{!-!}} ssh2 listener
{{!-!}} ssh2 SFTP
{{!-!}} ssh2 publickey system
|}
Source: [https://www.php.net/manual/en/resource.php List of Resource Types]
===Advanced===
New [https://www.php.net/manual/en/book.stream.php stream] resource types can be defined in code with [https://www.php.net/manual/en/function.stream-wrapper-register.php <code>stream_wrapper_register()</code>].
==Functions==
==Functions==
These are just the general functions that apply to all resources; there are many others that do things with specific types of resources. In general, this is all not very well documented (there is plenty of documentation, but very little of it explains how things work).
* [https://www.php.net/manual/en/function.get-resource-id.php <code>get_resource_id()</code>]
* [https://www.php.net/manual/en/function.get-resource-id.php <code>get_resource_id()</code>]
* [https://www.php.net/manual/en/function.get-resource-type.php <code>get_resource_type()</code>]
* [https://www.php.net/manual/en/function.get-resource-type.php <code>get_resource_type()</code>]
* [https://www.php.net/manual/en/function.is-resource.php <code>is_resource()</code>]
* [https://www.php.net/manual/en/function.is-resource.php <code>is_resource()</code>]
* If passed a resource variable, [https://www.php.net/manual/en/function.get-debug-type.php <code>get_debug_type()</code>] will indicate whether it is open or closed. (Surely there is some more rigorous way to get this information, however.)
==Links==
==Links==
===Reference===
===Reference===
* [https://www.php.net/manual/en/language.types.resource.php Resources]
* [https://www.php.net/manual/en/language.types.resource.php Resources]
** [https://www.php.net/manual/en/resource.php List of Resource Types]
** [https://www.php.net/manual/en/resource.php List of Resource Types]

Revision as of 15:17, 16 January 2026

About

In PHP, a "resource" value is an opaque internal pointer for handling certain types of I/O-ish operations.

Syntax

As of PHP 8.5, although "resource" is "soft-reserved and is used as a documentation pseudotype, there is no actual "resource" type; the only type which is currently known to be compatible with resource variables is "mixed". PHP currently interprets invocation of "resource" as a type as a reference to an unknown class named "Template:Fmt/arg\resource".

Types

There are many specialty resource-types defined by extensions, and a handful of more general types:

type subtype functions
curl cURL handle
process proc_open(), proc_get_status(), proc_terminate(), proc_close()
stream dir handle
stream file handle
stream process handle
socket file handle
ssh2 session
ssh2 listener
ssh2 SFTP
ssh2 publickey system

Source: List of Resource Types

Advanced

New stream resource types can be defined in code with stream_wrapper_register().

Functions

These are just the general functions that apply to all resources; there are many others that do things with specific types of resources. In general, this is all not very well documented (there is plenty of documentation, but very little of it explains how things work).

Reference