致命错误:未捕获ArgumentCountError:函数参数太少

MKD*_*MKD 5 php oop

我知道有一些与此相关的问题,但有c ++或其他语言.我收到此错误,我不确定我的功能有什么问题.

我的错误看起来像这样:

Fatal error: Uncaught ArgumentCountError: Too few arguments to function User::register(), 2 passed in C:\xampp\htdocs\register.php on line 39 and exactly 5 expected in C:\xampp\htdocs\classes\users.php:22 Stack trace: #0 C:\xampp\htdocs\register.php(39): User->register('ds', 'dsssssss') #1 {main} thrown in C:\xampp\htdocs\classes\users.php on line 22
Run Code Online (Sandbox Code Playgroud)

我的功能是:

public function register($name, $surname, $username, $password, $email)
{
    try {
        $newPassword = password_hash($password, PASSWORD_DEFAULT);

        $stmt = $this->conn->prepare("INSERT INTO user(name, surname, username, password, email) 
                             VALUES(:name, :surname, :username, :password, :email)");

        $stmt->bindParam(":name", $name);
        $stmt->bindParam(":surname", $surname);
        $stmt->bindParam(":username", $username);   
        $stmt->bindParam(":password", $password);
        $stmt->bindParam(":password", $password);
        $stmt->bindParam(":email", $email);

        $stmt->execute();   

        return $stmt;   
}
    catch(PDOException $e) {
            echo $e->getMessage();
    }
}
Run Code Online (Sandbox Code Playgroud)

Register.php文件:

  <!DOCTYPE html>
<?php
session_start();
require_once('classes/users.php');
$user = new User();

if($user->isLoggedIn()!="") {
    $user->redirect('home.php');
}

if(isset($_POST['submit'])) {
    $name = strip_tags($_POST['name']);
    $surname = strip_tags($_POST['surname']);
    $username = strip_tags($_POST['username']);
    $password = strip_tags($_POST['password']);
    $email = strip_tags($_POST['email']);

if($name=="") {
        $error[] = "provide username !";    
} else if($surname=="") {
        $error[] = "Provide surname!";  
  } else if ($username =="") {
      $error[] = "Provide username!";
    } else if($password=="") {
        $error[] = "provide password !";
      } else if(!filter_var($email, FILTER_VALIDATE_EMAIL)) {
        $error[] = 'Please enter a valid email address !';
        } else if(strlen($password) < 6){
            $error[] = "Password must be atleast 6 characters"; 
          } else {
                try {
                    $stmt = $user->runQuery("SELECT username FROM user WHERE username=:username");
                    $stmt->execute(array(':username'=>$username));
                    $row=$stmt->fetch(PDO::FETCH_ASSOC);

                    if($row['username']==$username) {
                            $error[] = "sorry username already taken !";
                    } else {
                        if($user->register($username,$password)){   
                            $user->redirect('register.php?joined');
                        }
                    }
                }
                catch(PDOException $e) {
                    echo $e->getMessage();
                }
            }   
}
?>
<html>
<head>
    <meta charset="UTF-8">
    <title>
    </title>
</head>
<body>
    <div class="form">
        <form method ="post" action="register.php">
            <h3 class = "signup"> Sign Up </h3>
             <?php
        if(isset($error)) {
                        foreach($error as $error)
         {
                 ?>
                               <div class="alert alert-danger">
                    <i class="glyphicon glyphicon-warning-sign"></i> &nbsp; <?php echo $error; ?>
                 </div>
                 <?php
            }
        }
        else if(isset($_GET['joined']))
        {
             ?>
             <div class="alert alert-info">
                  <i class="glyphicon glyphicon-log-in"></i> &nbsp; Successfully registered <a href='index.php'>login</a> here
             </div>
             <?php
        } ?>

            Vardas:<br>
            <input type="text" name="name" id="name" placeholder="Vardas" required>
            <br>
            Pavard?:<br>
            <input type="text" name="surname" id="surname" placeholder="Pavard?" required>
            <br>
            Prisijungimo vardas:<br>
            <input type="text" name="username" id="username" placeholder="Prisijungimo vardas" required>
            <br>
            Slaptažodis:<br>
            <input type="password" name="password" id="password" placeholder="Slaptažodis" required>
            <br>
            El. pašto adresas: <br>
            <input type="email" name="email" id="email" placeholder="El. pašto adresas" required>
            <br><br>
            <div class ="div">
            <input type="submit" name="submit" id="submit" value="Registruotis">
            <br><br>
            <label>Have an account? <a href="index.php">Sign In</a></label>
            </form> 
    </div>
</body>
Run Code Online (Sandbox Code Playgroud)

感谢您的帮助!

小智 17

在PHP 7而不是:

    public function register($name, $surname, $username, $password, $email)
{
...
Run Code Online (Sandbox Code Playgroud)

使用:

public function register($name = null, $surname = null, $username = null, $password = null, $email = null)
{
...
Run Code Online (Sandbox Code Playgroud)

  • 这是一个很好的解决方法,有时即使您有可能提供参数,函数也可以在没有参数的情况下正常工作。 (2认同)

mod*_*bio 8

您的方法需要 5 个参数,您只需传递 2 个: User->register('ds', 'dsssssss')

编辑此行Register.php

$user->register($username, $password)
Run Code Online (Sandbox Code Playgroud)

$user->register($name, $surname, $username, $password, $email)
Run Code Online (Sandbox Code Playgroud)

另外你有这行两次 $stmt->bindParam(":password", $password);


Ben*_*.12 8

我的托管公司将我们的PHP版本从7.0.x更新到7.1.x后,我遇到了同样的错误.他们认为,由于它是一个小的更新,它应该与以前的版本兼容.他们错了:是迁移页面中不兼容的列表.

在这个特殊情况下,之前会抛出关于函数调用缺少参数的警告的代码现在在OP的问题中抛出致命错误.

显然,解决方案是提供其他答案所表明的适当参数.