Ihr Problem ist hier:
$query = mysqli_query("SELECT * FROM users WHERE Username = ? AND Password = ?");
$userParam = array($_POST["Uname"], $_POST["Pass"]);
$st = $database->prepare($query);
$st->execute($userParam);
prepare
erwartet einen String, mysqli_query
ist eine prozedurale Funktion, die die Abfrage ausführt. Entfernen Sie das. Außerdem müssen Sie bei mysqli die Parameter zuerst binden und nicht an execute()
übergeben .
$query = "SELECT * FROM users WHERE Username = ? AND Password = ?";
$st = $database->prepare($query);
$st->bindParam("ss",$_POST["Uname"], $_POST["Pass"]);
$st->execute();
Hier sind die relevanten Abschnitte des Handbuchs:
http://php.net/manual/en/mysqli.prepare.php
http://php.net/manual/en/mysqli-stmt .bind-param.php
http://php.net/manual/en/mysqli-stmt.execute .php