回调函数callback
我们都知道在js中经常处理异步请求的时候,如果使用普通的函数,可能无法保证异步请求完成后调用。所以就存在了callback函数,特别是在文件处理和ajax处理的时候,回调函数的作用就非常的大了。
函数call_user_func()
mixed call_user_func ( callable $callback [, mixed $parameter [, mixed $… ]] )
return 返回一个复合类型的值,实际上是callback函数返回的值
callable $callback 回调函数 可以是函数名,可以是数组,可以是字符串
mixed $parameter 函数的参数,以顺序的方式显示
下面来介绍一下使用demo
demo1:回调php函数 字符串形式
<?php $data = array("name"=>"callback" , "value"=>"test"); $rs1 = http_build_query($data); //直接调用php函数 $rs2 = call_user_func("http_build_query",$data); //使用回调函数 echo $rs1; //name=callback&value=test echo "<br />"; echo $rs2; //name=callback&value=test // 这里需要注意的是,参数1必须是可使用的函数可以通过function_exists()返回true的函数,这里提醒isset,empty,is_null 等认为的常用函数实际上是一个操作符.并不能算函数。
相关推荐:《PHP入门教程》
demo2:回调php函数 函数名变量形式
<?php //自定义函数 function myUrldecode($str){ return urldecode($str); } $data = array("name"=>"callback" , "value"=>"天才"); $str = http_build_query($data); $rs1 = urldecode($str); //urlencode编码 $rs2 = call_user_func(myUrldecode,$str); echo $rs1; //name=callback&value=天才 echo "<br />"; echo $rs2; //name=callback&value=天才 //这里我们可以看到,我们直接使用函数的名称也是可以的,不需要带引号字符串。 ?>
demo3:回调 类方法 数组格式
<?php class MyClass{ private $demo = "test"; function myUrldecode($str){ return urldecode($str); } static function myUrlencode($str){ return urlencode($str) ; } } $str = "?query=/test/demo1"; $encode = call_user_func(array(MyClass,"myUrlencode"),$str); //直接使用类的静态方法 将字符串进行url编码 不再是字符串或者函数名,而是一个数组格式,第一个项表示类名,第二个项则表示方 法名。 第一项可以为类的引用地址,第二项为静态方法名称 $decode = call_user_func(array("MyClass","myUrlencode"),$encode); //同样是使用类的方法,不过调用的是普通方法名称。 echo $encode; //%3Fquery%3D%2Ftest%2Fdemo1 echo "<br />"; //?query=/test/demo1 echo $decode; //注意 使用方法名也具有作用域的概念,即private protected 和 public,通常回调类方法都只能调用publi 和默认作用域的 方法。 //同时如果是普通方法,并且内部使用了$this变量,那么进行调用是无法成功的. ?>
demo4:回调类方法 字符串格式
<?php class MyClass{ private $demo = "test"; function myUrldecode($str){ return urldecode($str); } private function myUrldecode2($str){ return urldecode($str); } static function myUrlencode($str){ return urlencode($str) ; } } $str = "?query=/test/demo1"; $encode = call_user_func("MyClass::myUrlencode",$str); $decode = call_user_func("MyClass::myUrldecode",$encode); echo $encode; // %3Fquery%3D%2Ftest%2Fdemo1 echo "<br />"; echo $decode; // ?query=/test/demo1 $encode2 = call_user_func("MyClass::myUrlencode2",$str); var_dump($encode2); // null //如果直接使用字符串的方法的话,那么必须在类和方法名中添加::作为分割。 //这里我们发现不是静态方法也可以用::进行调用 //这里进行了一个测试,发现调用private 作用域的方法返回的是一个null值,说明确实存在作用域的关系 ?>
demo5:回调对象方法 数组格式
<?php class MyClass{ private $demo = "test"; function myUrldecode($str){ return urldecode($str) ."-" .$this->demo ; //调用内部的this作用域 } static function myUrlencode($str){ return urlencode($str); } } $str = "?query=/test/demo1"; $class = new MyClass(); $encode = call_user_func(array($class,"myUrlencode"),$str); $decode = call_user_func(array($class,"myUrldecode"),$str); echo $encode; //%3Fquery%3D%2Ftest%2Fdemo1 echo "<br />"; echo $decode; //?query=/test/demo1-test //很明显,如果使用对象做为回调函数,内部的private 属性和方法也可以使用,但是对外的方法必须为默认或者 public类型 //对象数组方式第一个选项必须为一个对象 ?>
有时候我们发现传递的参数可能并不是固定的,那么使用call_user_func()会给人带来一定的麻烦,这时候可以使用call_user_func_array()方法了,大部分的使用方式是一样的,只是参数上的使用会有些不同。
函数call_user_func_array()
demo1:回调php函数 不定参数
<?php $record1 = array( 'id' => 2135, ); $record2 = array( 'first_name' => 'Sally', ); $record3 = array( 'last_name' => 'Jones', ); $return = array_merge($record1,$record2,$record3); //如果使用回调函数,则如下 $return = call_user_func_array("array_merge", array($record1,$record2,$record3)); print_r($return); //Array ( [id] => 2135 [first_name] => Sally [last_name] => Jones ) //一些特别的函数允许你有不固定的参数,如果你还将它作为回调函数,则可以使用这个方法进行调用. ?>
tips1 如何判断是否为可回调函数
bool is_callable ( callable $name [, bool $syntax_only = false [, string &$callable_name ]] )
name
要检查的回调函数。
syntax_only
如果设置为 TRUE,这个函数仅仅验证 name 可能是函数或方法。
callable_name
接受“可调用的名称”。
return
如果 name 可调用则返回 TRUE,否则返回 FALSE。
<?php // is_callable(); $bool = is_callable(urlencode); // true $bool = is_callable(urlencode,false); // true $bool = is_callable(urlencode,true); // true $bool = is_callable("urlencode",false,$callable_name1); // string urlencode $bool = is_callable("urldecode",true,$callable_name2); // string urldecode 即使不存在回调函数也会返回true ?>
tips2 获取函数的参数 类似于js中的arguments
<?php //这里指的是非客户端php脚本 function sum($first,$second){ $args = func_get_args(); //获取列表 //func_get_arg($index) 则获取指定的位置的参数 $len = func_num_args(); //获取长度 $sum = 0 ; foreach($args as $key=>$val){ $sum += (int) $val; } return $sum; } $rs = sum(1,2,3,4,5); var_dump($rs); // int 15 //注意: 在sum函数中修改了$first,$second的变量,同时又不是引用对象 变量的话,则不会修改 ?>
以上是怎么理解php的回调的详细内容。更多信息请关注PHP中文网其他相关文章!

本文比较了酸和基本数据库模型,详细介绍了它们的特征和适当的用例。酸优先确定数据完整性和一致性,适合财务和电子商务应用程序,而基础则侧重于可用性和

本文讨论了确保PHP文件上传的确保,以防止诸如代码注入之类的漏洞。它专注于文件类型验证,安全存储和错误处理以增强应用程序安全性。

本文讨论了在PHP中实施API速率限制的策略,包括诸如令牌桶和漏水桶等算法,以及使用Symfony/Rate-limimiter之类的库。它还涵盖监视,动态调整速率限制和手

本文讨论了使用password_hash和pyspasswify在PHP中使用密码的好处。主要论点是,这些功能通过自动盐,强大的哈希算法和SECH来增强密码保护

本文讨论了OWASP在PHP和缓解策略中的十大漏洞。关键问题包括注射,验证损坏和XSS,并提供用于监视和保护PHP应用程序的推荐工具。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

Dreamweaver CS6
视觉化网页开发工具

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能