在PHP中使用数组来比较用户名/密码

Si8*_*Si8 1 php arrays

我有以下PHP脚本,其中有一个用户名和密码:

$Username = 'user1';
$Password = 'pass1';

/******************************************************************************/
if (isset($_POST['submitform'])){

    // Clean up the input values 
    foreach($_POST as $key => $value) {  
        $_POST[$key] = stripslashes($_POST[$key]); 
        $_POST[$key] = htmlspecialchars(strip_tags($_POST[$key])); 
    }
    $user = isset($_POST['user']) ? $_POST['user'] : '';
    $pass = isset($_POST['pass']) ? $_POST['pass'] : '';
    $report = $_POST['typereport'];

    if ($pass != $Password || $user != $Username) {
        showForm("Wrong Username/Password");
        exit();     
    }
} else {
    showForm();
    exit();
}
Run Code Online (Sandbox Code Playgroud)

我想让脚本更健壮,这意味着我希望有其他用户名/密码,以便多个用户可以登录(希望它用于跟踪目的)

那么,如何修改剧本,所以我可以使用下面的$Username$Password:

$Username=array("user1","user2","user3");
$Password=array("pass1","pass2","pass3");
Run Code Online (Sandbox Code Playgroud)

因此,脚本将始终与正确的用户名和密码匹配,并允许我拥有多个用户?

lan*_*ons 9

我会用一个数据库.如果你必须硬编码,我会使用一个关联数组:

<?php
$logins = array(
    'username1' => 'password1',
    'username2' => 'password2',
    'username3' => 'password3',
);

$user = isset($_POST['user']) ? strtolower($_POST['user']) : '';
$pass = isset($_POST['pass']) ? $_POST['pass'] : '';

if ( ! isset($logins[$user]) or $logins[$user] != $pass)
{
    showForm("Wrong Username/Password");
    exit();
}
Run Code Online (Sandbox Code Playgroud)

  • +1 用于关联数组。我认为 PHP 对数组中的尾随逗号很宽容,但它不是最好的。 (2认同)
  • @SiKni8 保持数组键全部小写,然后 `strtolower` 输入 (2认同)