为什么我在设置php以显示所有错误之后仍然得到WSOD?

为什么我在设置php以显示所有错误之后仍然得到WSOD?,php,oop,wsod,Php,Oop,Wsod,我正在学习PHP中的OOP。我得到了一些关于创建一个小型剧院预订系统的作业。我从一个简单的数据库开始,它只能够插入一个名称来进行预订 为什么这会给我带来一个完全空白的页面?我假设我有不止一个错误,因为这是从零开始的第一次尝试,但为什么我没有得到任何东西。。。到底是什么 <?php error_reporting(E_ALL); ini_set('display_errors', 1); /* Sistema de reserva de asientos en un complejo co

我正在学习PHP中的OOP。我得到了一些关于创建一个小型剧院预订系统的作业。我从一个简单的数据库开始,它只能够插入一个名称来进行预订

为什么这会给我带来一个完全空白的页面?我假设我有不止一个错误,因为这是从零开始的第一次尝试,但为什么我没有得到任何东西。。。到底是什么

<?php
error_reporting(E_ALL);
ini_set('display_errors', 1);

/* Sistema de reserva de asientos en un complejo con 2 salas donde
se pueden reservar asientos para cada espectáculo que ofrezca la sala, 
individualmente considerado.
Se puede 'reservar' o 'cancelar reserva' un asiento cuidando que la reserva no supere 
las butacas disponibles y que no quede en número negativo.
Usar PDO y PDO::rollback para cancelar las reservas
*/

//genero la clase sala
class Sala{
    protected $cantButacas;
    protected $pdo; //acá guardamos el objeto conexión

    function __construct($butacas) {
        $host='localhost';
        $user='root';
        $pass='123456';
        $dbname='cine';

        $this->cantButacas = $butacas;
        $this->pdo = $pdo;

        try { //conectamos a la base
            $pdo = new PDO("mysql:host=$host;dbname=$dbname", $user, $pass);
            if ($pdo) {
                echo 'Conexión a la base exitosa<br>.';
            } else { //si no nos conectamos...
                trow new Exception()
            }
        } catch(Exception $e) { //Mostrar datos del error
            echo 'No se pudo conectar a la base: '. $e->getCode() . ' ' . $e->getLine() . ' ' .$e->getFile() . ' ' .$e->getTrace();
          }
    }

    function getButacas() {
        $pdo->query('SELECT id FROM usuarios');
        $butacasOcupadas = mysqli_num_rows($pdo);
        echo "Hay <b>$butacasOcupadas</b> butacas ocupadas.<br>";
        $butacasLibres = $this->cantButacas - $butacasOcupadas;
        echo "Quedan <b>$butacasLibres</b> butacas libres.<br>";
    }

    function addUsuario($usuario) {
        $usuario = $_POST['usuario'];
        try {
            $nuevoUsuario = $pdo->query('INSERT INTO usuarios (id, nombre) VALUES ('', '$usuario')');
            if ($nuevoUsuario) {echo 'Se guardó la reserva.';} 
            else {trow new Exception();}
            } 
        catch(Exception $e) {
            echo 'No se pudo guardar la reserva! '. $e->getCode() . ' ' . $e->getLine() . ' ' .$e->getFile() . ' ' .$e->getTrace();
            }

    }

    function __destruct(){
        $this->pdo = null;
    }
}

//creamos el objeto sala
$x = new Sala(10);
$x->getButacas();
echo '<br><br>';

?>
<form action="" method="POST">
    <h2>Nueva reserva</h2>
    Nombre: <input type="text" name="usuario"><br>
    <input type="submit" name="submit">
</form>

<?php

if($_SERVER['REQUEST_METHOD'] == 'POST') {
    if ($_POST['usuario']) {$x->addUsuario($_POST['usuario']);} 
    else {echo 'Debe ingresar un nombre';}
}

谢谢你的洞察力

因为阻止脚本编译的致命错误仍然会导致WSOD。检查您的日志,注意trow新异常很可能就是那个致命错误。。。。扔,不要扔,汉克斯!我没有看到那个错误!在阅读了/var/log/apache2/error.log上的日志之后,我发现有很多打字错误!解决了的!谢谢