php中assert和eval的详细介绍(代码示例)

yumo6667个月前 (05-21)技术文章43

本篇文章给大家带来的内容是关于php中assert和eval的详细介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

assert 判断一个表达式是否成立。返回true or false;

<?php

$s = 123;

assert("is_int($s)");

?>

从这个例子可以看到字符串参数会被执行,这跟eval()类似。

不过eval($code_str)只是执行符合php编码规范的$code_str。

eval():该函数对于在数据库文本字段中供日后计算而进行的代码存储很有用。(在生产中也建议少用)

注意:1.eval()里必须是字符串;

2.eval()里的引号必须是双引号,因为单引号不能解析字符串里的变量$str;

eval定义和用法:

(1)eval() 函数把字符串按照 PHP 代码来计算(计算=执行)。

(2)该字符串必须是合法的 PHP 代码,且必须以分号结尾。

(3)如果没有在代码字符串中调用 return 语句,则返回 NULL。如果代码中存在解析错误,则 eval() 函数返回 false

assert的用法却更详细一点。

assert_option()可以用来对assert()进行一些约束和控制;

默认值

ASSERT_ACTIVE=1 //Assert函数的开关

ASSERT_WARNING =1 //当表达式为false时,是否要输出警告性的错误提示,issue a PHP warning for each failed assertion

ASSERT_BAIL= 0 //是否要中止运行;terminate execution on failed assertions

ASSERT_QUIET_EVAL= 0 //是否关闭错误提示,在执行表达式时;disable error_reporting during assertion expression evaluation

ASSERT_CALLBACK= (NULL) // 是否启动回调函数 user function to call on failed assertions

php的官方文档里头是建议将assert用来进行debug,我们可以发现还有一个开关ASSERT_ACTIVE可以用来控制是否开启debug。

现在问题就产生了,如果程序员在开发的时候在代码中留下了很多assert(),然后在程序发布的时候关闭执行,设置assert_options(ASSERT_ACTIVE,0);这样做是否可行?有没有安全问题?

既然assert主要作用是debug,就不要在程序发布的时候还留着它。在程序中用assert来对表达进行判断是不明智的,原因上文说了, 一个是在生产环境中assert可能被disabled,所以assert不能被完全信任;二是assert()可以被继续执行;而如果在生产环境让 ASSERT_ACTIVE=1,那这个表达式字符串可以被执行本身就存在安全隐患。assert引起的代码注射

例如

<?php

function fo(){

$fp = fopen("c:/test.php",'w');

fwrite($fp,"123");

fclose($fp);

return true;

}

assert("fo()");

?>

注意:assert把整个字符串参数当php代码执行,eval把合法的php代码执行。

以上就是php中assert和eval的详细介绍(代码示例)的详细内容,更多请关注其它相关文章!

更多技巧请《转发 + 关注》哦!

相关文章

「前端开发」eval() 函数认知和学习以及注意事项

一、简单说明简单说几点吧:eval() 函数在 JavaScript 中是一个非常强大的函数,它可以将传入的字符串当作 JavaScript 代码进行执行。然而,需要明确的是,eval() 并不直接支...

干货 | 深度辨析 Python 的 eval() 与 exec()

优质文章,第一时间送达!Python 提供了很多内置的工具函数(Built-in Functions),在最新的 Python 3 官方文档中,它列出了 69 个。大部分函数是我们经常使用的,例如 p...

简单学Python——内置函数9——eval()函数

今天我们学习Python内置的eval()函数。eval()函数解析传递给该函数的表达式,并在程序中运行python表达式(代码)。听起来挺抽象,简单点说,就是eval()接收一个字符串,然后把两边的...

清华团队深度实证:RL 真能让大模型进化吗?能力边界仍被基座“锁死”!

大数据文摘出品强化学习(RL)真的能让大模型获得超越基础模型的新推理能力吗?近日,清华大学LeapLab团队联合上海交大,发布了一篇题为《Does Reinforcement Learning Rea...

GPT-4o医学知识覆盖率仅55%?大模型医疗能力“体检报告”来了

MedKGEval团队 投稿量子位 | 公众号 QbitAI医疗大模型知识覆盖度首次被精准量化!在医疗领域,大语言模型(LLM)的潜力令人振奋,但其知识储备是否足够可靠?腾讯优图实验室天衍研究中心的最...

上科大校友研发小推理模型,证明低秩自适应技术强大能力

“我们这篇论文可能是目前唯一一篇在推理模型能力上详细告诉大家到底花了多少钱的论文。”上海科技大学 95 后本科校友、美国南加州大学博士生王上上告诉 DeepTech。近日,他和所在团队打造出一系列名为...