PHP 保护 $_GET

标签 php mysql

我不知道为什么这不起作用。如果 ?Session=2 不是您发出的,那么您将返回您的帐户。

这是我的代码:

<?php
$hosts = $mysql->query("SELECT * FROM user_host WHERE uid = '" . $_SESSION['id'] . "'");
$hostsFetch = $hosts->fetch_assoc();

$userq = $mysql->query("SELECT * FROM users WHERE id = '" . $_SESSION['id'] . "'");
$userf = $userq->fetch_assoc();

if (isset($_GET['session'])) {
    $_SESSION['siteid'] = $mysql->real_escape_string($_GET['session']);
    header('Location: ./home');
}

if (trim($_SESSION['siteid']) == '') {
    $_SESSION['siteid'] = $userf['default'];
}

$hosts2 = $mysql->query("SELECT * FROM user_host WHERE id = '" . $hostsFetch['id'] . "'");
$hosts2Fetch = $hosts2->fetch_assoc();

这就是问题/它不起作用

我仍然可以转到?session=2,但它不是我的

if ($hosts2Fetch['uid'] != $_SESSION['id']) {
    $_SESSION['siteid'] = $userf['default'];
}


$host = $mysql->query("SELECT * FROM user_host WHERE uid = '" . $_SESSION['id'] . "'");
while ($item = $host->fetch_assoc()) {
    ?>
    <option
        value="./home?session=<?php echo $item['id']; ?>" <?php echo($_SESSION['siteid'] == $item['id'] ? 'selected' : '') ?>><?php echo $item['name'] . ' - ' . $item['domein']; ?></option>
<?php

}
?>

谢谢。

最佳答案

请记住,PHP 中的所有内容都区分大小写。您使用查询字符串 Session,但在代码中您无法引用 session,必须使用 Session

您提到使用了?Session=2,但在代码中您引用了$_GET['session']。这两者的大小写应该匹配。

关于PHP 保护 $_GET,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24018787/

相关文章:

php - 一个变量的多个比较运算符?

php - 拉维尔 4 : No hint path defined

mysql - 创建数据库表错误150

php - MySQL多对多分组

PHP MySQL 登录示例错误

php - 列出第二列的所有公共(public)值,后跟 mysql 中第一个值中的唯一名称

php - 在 MySQL 数据库中搜索全名或名字或姓氏,名字和姓氏在单独的列中

php - 使用 Api 平台,自动将用户分配给对象 (OneToMany)

php - 是否可以将上传和移动的文件转换为 symfony 中的 UploadedFile() 对象?

mysql - 250选择对1