php session防url攻击方法
程序员文章站
2022-05-06 14:32:13
...
session 跟踪,可以很方便地避免上述情况的发生:
session_start();
$clean = array();
$email_pattern = '/^[^@s]+@([-a-z0-9]+.)+[a-z]{2,}$/i';
if (preg_match($email_pattern, $_POST['email']))
{
$clean['email'] = $_POST['email'];
$user = $_SESSION['user'];
$new_password = md5(uniqid(rand(), TRUE));
if ($_SESSION['verified'])
{
/* Update Password */
mail($clean['email'], 'Your New Password', $new_password);
}
}
?>
http://example.org/reset.php?user=php&email=chris%40example.org
如果reset.php 信任了用户提供的这些信息,这就是一个语义URL 攻击漏洞。在此情况下,系统将会为php 帐号产生一个新密码并发送至chris@example.org,这样chris 成功地窃取了php 帐号。
推荐阅读
-
一个严格的PHP Session会话超时时间设置方法
-
对php 判断http还是https,以及获得当前url的方法详解
-
php获得url参数中具有&的值的方法
-
PHP解决URL中文GBK乱码问题的两种方法
-
深入讲解PHP Session及如何保持其不过期的方法
-
php将session放入memcached的设置方法
-
php用正则表达式匹配URL的简单方法
-
PHP实现恶意DDOS攻击避免带宽占用问题方法
-
PHP实现利用MySQL保存session的方法
-
php session_start()关于Cannot send session cache limiter - headers already sent错误解决方法