mysql冷门函数_php的冷门函数之——call_user_func_array,func_get_args,func_num_args

昨天帮同学研究php对mysql进行封装操作的时候,无意中看到了call_user_func_array这个函数,好歹我php也用了一年多了,竟然还有这么多我不知道的功能函数,因此我们的原则是宁肯多学,不能放过,下面我会举几个例子给大家介绍一下这几个冷门的php函数。话不多说,gogogogo

第一个函数,func_num_args,我们先来看一下php的manual对这个函数的解释

func_num_args

(PHP 4, PHP 5)

func_num_args—Returns the number of arguments passed to the function

顾名思义了,这个函数的功能就是返回传递给这个函数参数的多少,我们写一个简单的函数来验证一下

function TestPhpFunction1() {

$number = func_num_args ();

echo "传递给该函数参数数目为: " . $number . "
";

}

TestPhpFunction1 ( 3, 4, 5, 6, 7 );

?>

输出结果:传递给该函数参数数目为: 5

第二个函数,func_get_arg,func_get_args我们也来看一下php的manual对这个函数的解释

func_get_arg

(PHP 4, PHP 5)

func_get_arg—Return an item from the argument list

继续英文翻译,返回指定参数列表中的一项

func_get_args

(PHP 4, PHP 5)

func_get_args—Returns an array comprising a function's argument list

翻译一下,应该是返回参数列表数组,写个函数验证一下

function TestPhpFunction2() {

$parameter_nums = func_num_args ();

for($i = 0; $i < $parameter_nums; $i ++) {

echo "第" . $i . "个参数为" . func_get_arg ( $i ) . "
";

}

echo "传递的参数数组为:
";

$parameters = func_get_args ();

print_r ( $parameters );

}

TestPhpFunction2 ( 3, 4, 5, 6, 7 );

?>

输出结果为:

第0个参数为3第1个参数为4第2个参数为5第3个参数为6第4个参数为7传递的参数数组为:Array ( [0] => 3 [1] => 4 [2] => 5 [3] => 6 [4] => 7 )

刚才同学又跟我讨论了一个php操作mysql预编译的指令,有点使用上的问题,跟大家分享一下,照例贴出来php manual的解释

mysqli_stmt::bind_param

mysqli_stmt_bind_param

(PHP 5)

mysqli_stmt::bind_param--mysqli_stmt_bind_param—Binds variables to a prepared statement as parameters

这个mysql->prepared是防止客户端sql注入最常用的手段之一,而这个函数正是对客户端的输入进行参数绑定

boolmysqli_stmt::bind_param(string$types,&$var1[,&$...]

)

其中type分为4种类型:

i:整型

b:浮点型

s:字符串类型

d:blob类型

后面的var表示客户端输入的具体变量,今天偶然发现每个变量前都加入了取地址运算符&,很诡异啊,我之前操作mysql的时候没加,为什么还没出问题呢?

具体操作了一下,也就是值传递和引用传递的关系,因为再绑定参数之后,在$stmt->execute之前,我不会再进行其它对绑定参数大小修改的操作了,所以之前的都不会有问题

分享到:

18e900b8666ce6f233d25ec02f95ee59.png

72dd548719f0ace4d5f9bca64e1d7715.png

2012-09-13 10:02

浏览 615

评论

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值