扫码关注官方订阅号
看别人的防攻击代码中有这样一行:
empty($_SERVER['HTTP_VIA']) or exit('Access Denied');
有什么作用?
人生最曼妙的风景,竟是内心的淡定与从容!
楼主可能疑惑的是or的问题这种写法,是php的一种常用的程序手法or是或的意思,A or B只要AB有一个满足true,它就会立马执行后面的语句。当A不为真后,or还不能当下就立即断定,它还需要接着往下判断第二个条件B,结果B直接exit了,这样看起来要比if语句简短明了。换句话说,若A为真,那么就不会执行Access Denied了
其实,主要利用了如下几点:
or具备从左向右的结合性
or条件中,只有有一个条件为真,那么剩余的条件就不判断了,直接执行大括弧里的代码段
这种写法比if(empty(xxx)){ xxxx }更好看些
如有错误,欢迎指正
防止用户通过正确的方式运行到这段程序。
$_SERVER['HTTP_VIA'] 是代理服务器地址,也就是说,如果用户是通过代理访问的,就会直接退出,不会继续执行下去。这是保证安全的一项措施。
$_SERVER['HTTP_VIA']
代理服务器ip不为空时退出当前程序,并输出Access Denied,防止外部攻击。
Access Denied
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
楼主可能疑惑的是or的问题
这种写法,是php的一种常用的程序手法
or是或的意思,A or B只要AB有一个满足true,它就会立马执行后面的语句。
当A不为真后,or还不能当下就立即断定,它还需要接着往下判断第二个条件B,结果B直接exit了,这样看起来要比if语句简短明了。换句话说,若A为真,那么就不会执行Access Denied了
其实,主要利用了如下几点:
or具备从左向右的结合性
or条件中,只有有一个条件为真,那么剩余的条件就不判断了,直接执行大括弧里的代码段
这种写法比if(empty(xxx)){ xxxx }更好看些
如有错误,欢迎指正
防止用户通过正确的方式运行到这段程序。
$_SERVER['HTTP_VIA']是代理服务器地址,也就是说,如果用户是通过代理访问的,就会直接退出,不会继续执行下去。这是保证安全的一项措施。代理服务器ip不为空时退出当前程序,并输出
Access Denied,防止外部攻击。