Требуется один раз остановить скрипт - PullRequest
2 голосов
/ 18 июля 2011

У меня есть php-скрипт test.php с содержимым

<?php
     require_once("classes/user.php");
     echo "test";
?>

, а вот содержимое user.php

<?php 
class User {
    private $data = array();

    public function __set($name, $value) {
        $this->data[$name] = $value;
    }

    public function __get($name) {
        if (array_key_exists($name, $this->data)) {
            return $this->data[$name];
        }

        $trace = debug_backtrace();
        trigger_error(
            'Undefined property via __get(): ' . $name .
            ' in ' . $trace[0]['file'] .
            ' on line ' . $trace[0]['line'],
            E_USER_NOTICE);
        return null;
    }

    public function __isset($name) {
        return isset($this->data[$name]);
    }

    public function __unset($name) {
        unset($this->data[$name]);
    }

    public __construct($param) {
        if(is_array($param)) $this->create($param);
        else $this->id($param);
    }

    private id($id) { //select from database
        require_once('config.php');

        $pdo = new PDOConfig();

        $sql = "SELECT * FROM users WHERE `id` = :id";

        $q = $pdo->prepare($sql);
        $q->execute(array(":id"=>$id));
        $resp = $q->fetchAll();

        foreach ($resp as $row) {
            foreach ($row as $key=>$value) {
                if(!is_int($key))
                    $this->data[$key] = html_entity_decode($value, ENT_QUOTES);
            }
        }

        $pdo = null;
        unset($pdo);
    }

    private create($arr) { //create new item from values in array and insert to db

    }

    public delete() {
        $this->life = 0;
        //update database "life" here
    }   

    /* ##################################### */
    /* !Functions                            */
    /* ##################################### */

    public projects($extra = null) {
        $projects = array();
        require_once('project.php');

        $pdo = new PDOConfig();

        $sql = "SELECT * FROM ---- WHERE `000` = :aaa";

        if($extra) $sql .= " " . $extra;

        $q = $pdo->prepare($sql);
        $q->execute(array(":aaa"=>$this->id));
        $resp = $q->fetchAll();

        foreach ($resp as $row) {
                $project = new Project($row['id']);
                $projects[] = $project;

                $project = null;
                unset($project);
        }

        return $projects;
    }

}
?>

, а test никогда не печатается, ив chrome страница вообще не загружается

На веб-сайте обнаружена ошибка при получении http://example.com/test.php. Возможно, он недоступен для обслуживания или настроен неправильно.

Я не могу понять это для моей жизни.Спасибо, заранее

1 Ответ

7 голосов
/ 18 июля 2011

У вас есть синтаксическая ошибка в объявлении вашего __construct() метода:

public __construct($param) {
    if(is_array($param)) $this->create($param);
    else $this->id($param);
}

Вам необходимо использовать ключевое слово function, например:

public function __construct($param) {
    if(is_array($param)) $this->create($param);
    else $this->id($param);
}


Чтобы помочь найти эти ошибки, на вашем компьютере разработчика вы должны включить:

На самом деле, я просто скопировал ваш код в .php файл и запустил его - и получил

Parse error: syntax error, unexpected T_STRING, expecting T_VARIABLE 
    in /home/.../temp/temp.php on line 39
...