「\r」 代表的含义是:
在 Linux、Unix 中表示返回到当行的最开始位置,在 Mac OS 中表示换行且返回到下一行的最开始位置,相当于 Windows 里的 \n 的效果。
「\n」代表的含义是:
在 Windows 中表示换行且回到下一行的最开始位置。相当于 Mac OS 里的 \r 的效果,在 Linux、Unix 中只表示换行,但不会回到下一行的开始位置。
「\t」所代表的含义是:
键盘上的「TAB」键,跳格(移至下一列)。
「\x20」所代表的含义是:是 32 在 ASCII 表中 16 进制的表示。
$a = 3;
echo "$a",'$a',"\\\$a","${a}","$a"."$a","$a"+"$a";
得到的结果是:3$a\$a3336
setcookie("a","value");
print $_COOKIE['a'];
得到的结果是:
会提示 Notice: Undefined index: a,第一次访问时,HTTP 请求未携带任何数据,响应头告诉浏览器缓存 set-cookie:a=value,浏览器将数据保存到缓存。第二次访问时,HTTP 请求才会携带 Cookie 信息,PHP 将请求头中的 Cookie 数据读取出来,输出 value。
header("Location://blog.ilaoniu.cn");
parent::方法名
$_GET,$_POST,$_FILES
ip2long($_SERVER["REMOTE_ADDR"]);
引用文件的两种方式:
require - 出现错误后直接终止退出,程序不再执行
include - 包含一个不存在的文件,会提示警告程序会继续执行
类的继承
@test() 的作用是屏蔽 test() 方法中警告的作用
&test() 引用 test() 方法
二者之间的区别是:
键名为数字时,array_merge() 不会覆盖掉原来的值,但 + 合并数组则会把最先出现的值作为最终结果返回,而把后面的数组拥有相同键名的那些值「抛弃」掉(不是覆盖)
键名为字符时,+ 仍然把最先出现的值作为最终结果返回,而把后面的数组拥有相同键名的那些值「抛弃」掉,但 array_merge() 此时会覆盖掉前面相同键名的值
构造方法: __construct()
析构方法: __destruct()
__get() 控制私有的受保护的未定义的成员属性的访问
__set() 对私有的受保护的未定义的成员属性进行赋值控制
__isset() 对私有的受保护的未定义成员属性进行 isset 和 empty 的判断控制
FastCGI Process Manager:FastCGI 进程管理器
SQL注入:
解决这个问题的办法是,将 PHP 的内置 mysqli_real_escape_string() 函数用作任何用户输入的包装器。这个函数对字符串中的字符进行转义,使字符串不可能传递撇号等特殊字符并让 MySQL 根据特殊字符进行操作。
跨站点脚本攻击(XSS):
strip_tags() 函数,这个函数可以清除任何包围在 HTML 标记中的内容
或者使用htmlspecialchars() 函数。
原因就是浮点数精度的问题。
简单的十进制分数如同 0.1 或 0.7 不能在不丢失一点点精度的情况下转换为内部二进制的格式。这就会造成混乱的结果:例如,floor((0.1+0.7)*10) 通常会返回 7 而不是预期中的 8,因为该结果内部的表示其实是类似 7.9999999999…。这和一个事实有关,那就是不可能精确的用有限位数表达某些十进制分数。例如,十进制的 1/3 变成了 0.3333333…。所以永远不要相信浮点数结果精确到了最后一位,也永远不要比较两个浮点数是否相等。如果确实需要更高的精度,应该使用任意精度数学函数或者 gmp 函数。