Php check if class function exist

How to check if a class method exists in PHP

Last week I looked at how to see if a function exists in PHP and this time will look at how to check if a class method exists in PHP.

Let’s say we have the following example PHP class:

Use the method_exists() function to check to see if a method exists like so (the (int) part casts it as an integer so it will display 0 if false and 1 if true):

echo (int)method_exists('foo', 'bar'); echo (int)method_exists('foo', 'baz');

The first line will echo 1 (true) because the ‘bar’ method does exists in the ‘foo’ class. The second line will echo 0 (false) because the ‘baz’ method does not exist.

You can also pass an object itself to the method_exists() function:

$foo = new foo; echo (int)method_exists($myfoo, 'bar'); echo (int)method_exists($myfoo, 'baz');

Again, the first line will echo 1 and the second line 0.

Note that if a method is declared as private or protected, the function will still return true if it exists, even though you will not be able to call it (although of course you can call a protected method if it’s a child class).

For example, a modified version of the above class:

class foo < function bar() < >protected function x() < >public function y() < >private function z() < >>

And checking if the x, y, z methods exist:

echo (int)method_exists('foo', 'x'); echo (int)method_exists('foo', 'y'); echo (int)method_exists('foo', 'z');

Each of these will echo 1 because they do exist, although you may not be able to call them all. So use with caution!

In one of next week’s PHP posts I’ll look at the is_callable() function. Make sure to sign up to my RSS feed (see details below) so you don’t miss out.

Источник

method_exists

Checks if the class method exists in the given object_or_class .

Parameters

An object instance or a class name

Return Values

Returns true if the method given by method has been defined for the given object_or_class , false otherwise.

Examples

Example #1 method_exists() example

The above example will output:

Example #2 Static method_exists() example

The above example will output:

Notes

Note:

Using this function will use any registered autoloaders if the class is not already known.

See Also

  • function_exists() — Return true if the given function has been defined
  • is_callable() — Verify that a value can be called as a function from the current scope.
  • class_exists() — Checks if the class has been defined

User Contributed Notes 21 notes

As noted [elsewhere] method_exists() does not care about the existence of __call(), whereas is_callable() does:

public function __call ( $meth , $args ) <
// .
>
>

var_export ( method_exists ( $Tester , ‘anything’ )); // false
var_export ( is_callable (array( $Tester , ‘anything’ ))); // true
?>

Undocumented change since 7.4.0 is released:

class Foo
<
private function privateMethodTest ()

var_dump ( method_exists ( Bar ::class, ‘privateMethodTest’ ));
// PHP 7.4: bool(false)
// PHP 7.3: bool(true)

var_dump ( is_callable ( Bar ::class, ‘privateMethodTest’ ));
// PHP 7.3: bool(true)
// PHP 7.4: bool(true)

A couple of the older comments (specifically «jp at function dot fi» and «spam at majiclab dot com») state that is_callable() does not respect a methods visibility when checked outside of that class. ie. That private/protected methods are seen as callable when tested publicly. However, this was a bug (#29210) in early versions of PHP 5 and was fixed (according to the changelog) in PHP 5.0.5 (and/or PHP 5.1.0).

Bug #29210 — Function: is_callable — no support for private and protected classes
http://bugs.php.net/29210

Changelog — Fixed bug #29210 (Function: is_callable — no support for private and protected classes). (Dmitry)
http://php.net/ChangeLog-5.php#5.1.0

The function does not care about class existance, so you can use it to check an existance of a method even when class was not declared e.g.
if( method_exists ( ‘THIS_WAS_NOT_DECLARED’ , ‘some_method’ ) )
echo «it does exist!» ;
else
echo «nope, it is not there. » ;
?>
. raises no errors/warnings. outputs «nope, it is not there. » if class does not exist at all or if it does but the method doesn’t.

Just to mention it: both method_exists() and is_callable() return true for inherited methods:

class ChildClass extends ParentClass

$p = new ParentClass ();
$c = new ChildClass ();

// all return true
var_dump ( method_exists ( $p , ‘doParent’ ));
var_dump ( method_exists ( $c , ‘doParent’ ));

var_dump ( is_callable (array( $p , ‘doParent’ )));
var_dump ( is_callable (array( $c , ‘doParent’ )));
?>

if you want to check for a method «inside» of a class use:

i was a bit confused ’cause i thought i’m only able to check for a method when i got an object like $object_name = new class_name() with:

small example for those who didn’t understood what i mean ( maybe caused by bad english 🙂 ):

if( method_exists ( $this , ‘test’ ))
echo ‘a::test() exists!’ ;
else
echo ‘a::test() doesn\’t exists’ ;

?>

the output will be: a::test() exists!

maybe this will help someone

This function is case-insensitive (as is PHP) and here is the proof:
class A public function FUNC () < echo '*****' ; >
>

$a = new A ();
$a -> func (); // *****
var_dump ( method_exists ( $a , ‘func’ )); // bool(true)
?>

Note that prepending the namespace (if any) is required even if the calling class is in the same namespace:

namespace test ;
class foo public function lookup () // will return false
return method_exists ( ‘bar’ , ‘nonsense_method’ );
>
>

class bar public function nonsense_method () // will return true
return method_exists ( ‘test\foo’ , ‘lookup’ );
>
>
?>

Note that in PHP5, method_exists() will sucessfully find *private* methods. This has some OO/data-hiding ramifications.

If you want to check in a class itself if a method is known you may do so with magic variable __CLASS__

class A __construct ( $method ) return method_exists ( __CLASS__ , $method );
>

$test = new A ( ‘foo’ );
//should return true

?>

You might also use the method describe below with trick but I consider this one here easier and more readable and well, the way it is intended toi be done 😉

to find a method of an object (instance of a class)

if ( method_exists ( $myinstance , ‘themethod’ ))
echo ‘ok’ ;
?>

to find a method of a class (using the class name, not the instance of the class!)

if ( is_callable (array( ‘theclassname’ , ‘themethod’ )))
echo ‘ok’ ;
?>

It wasn’t spelled out but could be inferred: method_exists() also works on interfaces.

var_dump ( method_exists ( «Iterator» , «current» ));
// bool(true)

Here is a useful function that you can use to check classes methods access e.g whether it is public, private or static or both..

// Example class
class myClass

private static function privstatic ()

public static function publstatic ()

// The function uses the reflection class that is built into PHP.
// The purpose is to determine the type of a certain method that exi
function is_class_method ( $type = «public» , $method , $class ) <
// $type = mb_strtolower($type);
$refl = new ReflectionMethod ( $class , $method );
switch( $type ) <
case «static» :
return $refl -> isStatic ();
break;
case «public» :
return $refl -> isPublic ();
break;
case «private» :
return $refl -> isPrivate ();
break;
>
>
var_dump ( is_class_method ( «static» , «privstatic» , «myClass» )); // true — the method is private and also static..
var_dump ( is_class_method ( «private» , «privstatic» , «myClass» )); // true — the method is private and also static..
var_dump ( is_class_method ( «private» , «publstatic» , «myClass» )); // False the methos is public and also static not private
// you get the idea.. I hope this helps someone..
?>

call_user_method uses the same mechanism as a normal method call. So you can get the returned values as well in this way.

All information is then in $pagetext.

Using method_exists inside an object’s __call() method can be very usefull if you want to avoid to get a fatal error because of a limit in function nesting or if you are calling methods that dont exist but need to continue in your application:

/**
* Call a method dynamically
*
* @param string $method
* @param array $args
* @return mixed
*/
public function __call ( $method , $args )
<
if( method_exists ( $this , $method )) <
return call_user_func_array (array( $this , $method ), $args );
>else <
throw new Exception ( sprintf ( ‘The required method «%s» does not exist for %s’ , $method , get_class ( $this )));
>
>

I was wondering if caching the the methods in an array would have a faster lookup. So I ran a very simple benchmark using xdebug_time_index() with 10000 iterations on each statement.

// using an actual instance of an object shows 0.10398316383362 secs
method_exist ( $object , $method );
?>

// using a string shows 0.12779307365417 secs
method_exist ( ‘ClassName’ , $method );
?>

$array = array( /*method names with numeric index*/ );
// shows 0.10288906097412 secs
in_array ( $method , $array );
?>

$assoc = array( /*method name as key and value*/ );
// shows 0.017536878585815 secs
isset( $assoc [ $method ] );
?>

From the looks of the results, there is very little difference in method_exist and in_array. Isset seems to the fastest and using a string as the first parameter is the slowest.

Please note that the test was done on multiple methods, not just one, the code presented above is to show the results, not the actual test code that ran. Also, this was tested just out of curiosity and I didn’t set up a specific environment or used any profiling tools, and it was not meant to be an official benchmark in anyway.

Though, as Bejamin noted, it’s not possible to use the class name in method_exists within the class definition, get_class_methods delivers the method names for a given class name even inside the class. Thus another workaround for the mentioned problem is to use in_array(, get_class_methods())

Both method_exists() and is_callable() return private and protected functions, which, as mentioned below, causes problems for PHP5/OO programming. You can use get_class_methods() with either an $instance of a class or the ‘ClassName’ to get only public functions.

As mentioned before, is_callable and method_exists report all methods callable even if they are private/protected and thus actually not callable. So instead of those functions you may use following work-around which reports methods as supposed to.

class Foo1 public function bar () echo «I’m private Foo1::bar()» ;
>
>

class Foo2 private function bar () echo «I’m public Foo2::bar()» ;
>
>

if( is_callable (array( $f1 , «bar» ))) echo «Foo1::bar() is callable» ;
> else echo «Foo1::bar() isn’t callable» ;
>
if( is_callable (array( $f2 , «bar» ))) echo «Foo2::bar() is callable» ;
> else echo «Foo2::bar() isn’t callable» ;
>
if( in_array ( «bar» , get_class_methods ( $f1 ))) echo «Foo1::bar() is callable» ;
> else echo «Foo1::bar() isn’t callable» ;
>
if( in_array ( «bar» , get_class_methods ( $f2 ))) echo «Foo2::bar() is callable» ;
> else echo «Foo2::bar() isn’t callable» ;
>

?>

output
Foo1::bar() is callable (correct)
Foo2::bar() is callable (incorrect)
Foo1::bar() is callable (correct)
Foo2::bar() isn’t callable (correct)

Just a note that the behaviour of this function changed between version 5.0.x and 5.1.x when using static member functions

Using this code:
class a static function test ()
>
if( method_exists ( ‘a’ , ‘test’ ))
print call_user_func (array( ‘a’ , ‘test’ ));
else
print «Nothing» ;
?>
PHP 5.1.x returns «A»
PHP 5.0.x returns «Nothing»

Im not sure of a workaround for PHP 5.0.x yet.

if u want to use «method_exit» function in diffrent file after including this class , then u can’t use it directly by «method_exit»

so for this u have to use call_user_func_array to a base function which is available in class already.

then call function in the following way=>

Оцените статью