Ergebnis 1 bis 7 von 7

Thema: Fatal error: Call to a member function set Attribute() on a non-objet

  1. #1
    Neuer Benutzer
    Registriert seit
    28.01.2012
    Beiträge
    6
    Thanks
    0
    Thanked 0 Times in 0 Posts

    Standard Fatal error: Call to a member function set Attribute() on a non-objet

    Hallo,

    ich brauche dringend Hilfe und habe leider von der ganzen Materie überhaupt keine Ahnung, hoffen dass ich im richtigen Forum bin Durch Google bin ich jetzt auf das Forum hier gestossen.

    Zu meinem Problem:

    Ich habe eine Hompage erstellt mit dem Programm Weblica, auf meine Domain mittels FTP in die httpdocs kopiert...
    Jetzt bekomme ich aber folgende Fehlermeldung :
    Fatal error
    : Call to a member function setAttribute() on a non-object in C:\inetpub\vhosts\...........\httpdocs\_php\Zend\D b\Adapter\Pdo\Abstract.php on line 134

    Ich habe die Datei geöffnet und bin total erschossen...

    Vielleicht kann mir ja einer von euch weiter helfen

    Danke schon im voraus für die Bemühungen!
    Gruß
    Sam




  2. #2
    Neuer Benutzer
    Registriert seit
    28.01.2012
    Beiträge
    6
    Thanks
    0
    Thanked 0 Times in 0 Posts

    Standard

    Nachfolgend die Datei :

    <?php
    /**
    * Zend Framework
    *
    * LICENSE
    *
    * This source file is subject to the new BSD license that is bundled
    * with this package in the file LICENSE.txt.
    * It is also available through the world-wide-web at this URL:
    * Zend Framework
    * If you did not receive a copy of the license and are unable to
    * obtain it through the world-wide-web, please send an email
    * to license@zend.com so we can send you a copy immediately.
    *
    * @category Zend
    * @package Zend_Db
    * @subpackage Adapter
    * @copyright Copyright (c) 2005-2009 Zend Technologies USA Inc. (PHP Web Application Server - PHP Entwicklungs-Tools - PHP Training - Zend.com)
    * @license Zend Framework New BSD License
    * @version $Id: Abstract.php 16920 2009-07-21 13:32:28Z ralph $
    */


    /**
    * @see Zend_Db_Adapter_Abstract
    */
    require_once 'Zend/Db/Adapter/Abstract.php';


    /**
    * @see Zend_Db_Statement_Pdo
    */
    require_once 'Zend/Db/Statement/Pdo.php';


    /**
    * Class for connecting to SQL databases and performing common operations using PDO.
    *
    * @category Zend
    * @package Zend_Db
    * @subpackage Adapter
    * @copyright Copyright (c) 2005-2009 Zend Technologies USA Inc. (PHP Web Application Server - PHP Entwicklungs-Tools - PHP Training - Zend.com)
    * @license Zend Framework New BSD License
    */
    abstract class Zend_Db_Adapter_Pdo_Abstract extends Zend_Db_Adapter_Abstract
    {

    /**
    * Default class name for a DB statement.
    *
    * @var string
    */
    protected $_defaultStmtClass = 'Zend_Db_Statement_Pdo';

    /**
    * Creates a PDO DSN for the adapter from $this->_config settings.
    *
    * @return string
    */
    protected function _dsn()
    {
    // baseline of DSN parts
    $dsn = $this->_config;

    // don't pass the username, password, charset, persistent and driver_options in the DSN
    unset($dsn['username']);
    unset($dsn['password']);
    unset($dsn['options']);
    unset($dsn['charset']);
    unset($dsn['persistent']);
    unset($dsn['driver_options']);

    // use all remaining parts in the DSN
    foreach ($dsn as $key => $val) {
    $dsn[$key] = "$key=$val";
    }

    return $this->_pdoType . ':' . implode(';', $dsn);
    }

    /**
    * Creates a PDO object and connects to the database.
    *
    * @return void
    * @throws Zend_Db_Adapter_Exception
    */
    protected function _connect()
    {
    // if we already have a PDO object, no need to re-connect.
    if ($this->_connection) {
    return;
    }

    // get the dsn first, because some adapters alter the $_pdoType
    $dsn = $this->_dsn();

    // check for PDO extension
    if (!extension_loaded('pdo')) {
    /**

  3. #3
    Neuer Benutzer
    Registriert seit
    28.01.2012
    Beiträge
    6
    Thanks
    0
    Thanked 0 Times in 0 Posts

    Standard

    * @see Zend_Db_Adapter_Exception
    */
    require_once 'Zend/Db/Adapter/Exception.php';
    throw new Zend_Db_Adapter_Exception('The PDO extension is required for this adapter but the extension is not loaded');
    }

    // check the PDO driver is available
    if (!in_array($this->_pdoType, PDO::getAvailableDrivers())) {
    /**
    * @see Zend_Db_Adapter_Exception
    */
    require_once 'Zend/Db/Adapter/Exception.php';
    throw new Zend_Db_Adapter_Exception('The ' . $this->_pdoType . ' driver is not currently installed');
    }

    // create PDO connection
    $q = $this->_profiler->queryStart('connect', Zend_Db_Profiler::CONNECT);

    // add the persistence flag if we find it in our config array
    if (isset($this->_config['persistent']) && ($this->_config['persistent'] == true)) {
    $this->_config['driver_options'][PDO::ATTR_PERSISTENT] = true;
    }

    try {
    $this->_connection = new PDO(
    $dsn,
    $this->_config['username'],
    $this->_config['password'],
    $this->_config['driver_options']
    );

    $this->_profiler->queryEnd($q);

    // set the PDO connection to perform case-folding on array keys, or not
    $this->_connection->setAttribute(PDO::ATTR_CASE, $this->_caseFolding);

    // always use exceptions.
    $this->_connection->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

    } catch (PDOException $e) {
    /**
    * @see Zend_Db_Adapter_Exception
    */
    require_once 'Zend/Db/Adapter/Exception.php';
    throw new Zend_Db_Adapter_Exception($e->getMessage());
    }

    }

    /**
    * Test if a connection is active
    *
    * @return boolean
    */
    public function isConnected()
    {
    return ((bool) ($this->_connection instanceof PDO));
    }

    /**
    * Force the connection to close.
    *
    * @return void
    */
    public function closeConnection()
    {
    $this->_connection = null;
    }

    /**
    * Prepares an SQL statement.
    *
    * @param string $sql The SQL statement with placeholders.
    * @param array $bind An array of data to bind to the placeholders.
    * @return PDOStatement
    */
    public function prepare($sql)
    {
    $this->_connect();
    $stmtClass = $this->_defaultStmtClass;
    if (!class_exists($stmtClass)) {
    require_once 'Zend/Loader.php';
    Zend_Loader::loadClass($stmtClass);
    }
    $stmt = new $stmtClass($this, $sql);
    $stmt->setFetchMode($this->_fetchMode);
    return $stmt;
    }

    /**
    * Gets the last ID generated automatically by an IDENTITY/AUTOINCREMENT column.
    *
    * As a convention, on RDBMS brands that support sequences
    * (e.g. Oracle, PostgreSQL, DB2), this method forms the name of a sequence
    * from the arguments and returns the last id generated by that sequence.
    * On RDBMS brands that support IDENTITY/AUTOINCREMENT columns, this method
    * returns the last value generated for such a column, and the table name
    * argument is disregarded.
    *
    * On RDBMS brands that don't support sequences, $tableName and $primaryKey
    * are ignored.
    *
    * @param string $tableName OPTIONAL Name of table.
    * @param string $primaryKey OPTIONAL Name of primary key column.

  4. #4
    Neuer Benutzer
    Registriert seit
    28.01.2012
    Beiträge
    6
    Thanks
    0
    Thanked 0 Times in 0 Posts

    Standard

    * @return string
    */
    public function lastInsertId($tableName = null, $primaryKey = null)
    {
    $this->_connect();
    return $this->_connection->lastInsertId();
    }

    /**
    * Special handling for PDO query().
    * All bind parameter names must begin with ':'
    *
    * @param string|Zend_Db_Select $sql The SQL statement with placeholders.
    * @param array $bind An array of data to bind to the placeholders.
    * @return Zend_Db_Statement_Pdo
    * @throws Zend_Db_Adapter_Exception To re-throw PDOException.
    */
    public function query($sql, $bind = array())
    {
    if (empty($bind) && $sql instanceof Zend_Db_Select) {
    $bind = $sql->getBind();
    }

    if (is_array($bind)) {
    foreach ($bind as $name => $value) {
    if (!is_int($name) && !preg_match('/^:/', $name)) {
    $newName = ":$name";
    unset($bind[$name]);
    $bind[$newName] = $value;
    }
    }
    }

    try {
    return parent::query($sql, $bind);
    } catch (PDOException $e) {
    /**
    * @see Zend_Db_Statement_Exception
    */
    require_once 'Zend/Db/Statement/Exception.php';
    throw new Zend_Db_Statement_Exception($e->getMessage());
    }
    }

    /**
    * Executes an SQL statement and return the number of affected rows
    *
    * @param mixed $sql The SQL statement with placeholders.
    * May be a string or Zend_Db_Select.
    * @return integer Number of rows that were modified
    * or deleted by the SQL statement
    */
    public function exec($sql)
    {
    if ($sql instanceof Zend_Db_Select) {
    $sql = $sql->assemble();
    }

    try {
    $affected = $this->getConnection()->exec($sql);

    if ($affected === false) {
    $errorInfo = $this->getConnection()->errorInfo();
    /**
    * @see Zend_Db_Adapter_Exception
    */
    require_once 'Zend/Db/Adapter/Exception.php';
    throw new Zend_Db_Adapter_Exception($errorInfo[2]);
    }

    return $affected;
    } catch (PDOException $e) {
    /**
    * @see Zend_Db_Adapter_Exception
    */
    require_once 'Zend/Db/Adapter/Exception.php';
    throw new Zend_Db_Adapter_Exception($e->getMessage());
    }
    }

    /**
    * Quote a raw string.
    *
    * @param string $value Raw string
    * @return string Quoted string
    */
    protected function _quote($value)
    {
    if (is_int($value) || is_float($value)) {
    return $value;
    }
    $this->_connect();
    return $this->_connection->quote($value);
    }

    /**
    * Begin a transaction.
    */
    protected function _beginTransaction()
    {
    $this->_connect();
    $this->_connection->beginTransaction();
    }

    /**
    * Commit a transaction.

  5. #5
    Neuer Benutzer
    Registriert seit
    28.01.2012
    Beiträge
    6
    Thanks
    0
    Thanked 0 Times in 0 Posts

    Standard

    */
    protected function _commit()
    {
    $this->_connect();
    $this->_connection->commit();
    }

    /**
    * Roll-back a transaction.
    */
    protected function _rollBack() {
    $this->_connect();
    $this->_connection->rollBack();
    }

    /**
    * Set the PDO fetch mode.
    *
    * @todo Support FETCH_CLASS and FETCH_INTO.
    *
    * @param int $mode A PDO fetch mode.
    * @return void
    * @throws Zend_Db_Adapter_Exception
    */
    public function setFetchMode($mode)
    {
    //check for PDO extension
    if (!extension_loaded('pdo')) {
    /**
    * @see Zend_Db_Adapter_Exception
    */
    require_once 'Zend/Db/Adapter/Exception.php';
    throw new Zend_Db_Adapter_Exception('The PDO extension is required for this adapter but the extension is not loaded');
    }
    switch ($mode) {
    case PDO::FETCH_LAZY:
    case PDO::FETCH_ASSOC:
    case PDO::FETCH_NUM:
    case PDO::FETCH_BOTH:
    case PDO::FETCH_NAMED:
    case PDO::FETCH_OBJ:
    $this->_fetchMode = $mode;
    break;
    default:
    /**
    * @see Zend_Db_Adapter_Exception
    */
    require_once 'Zend/Db/Adapter/Exception.php';
    throw new Zend_Db_Adapter_Exception("Invalid fetch mode '$mode' specified");
    break;
    }
    }

    /**
    * Check if the adapter supports real SQL parameters.
    *
    * @param string $type 'positional' or 'named'
    * @return bool
    */
    public function supportsParameters($type)
    {
    switch ($type) {
    case 'positional':
    case 'named':
    default:
    return true;
    }
    }

    /**
    * Retrieve server version in PHP style
    *
    * @return string
    */
    public function getServerVersion()
    {
    $this->_connect();
    try {
    $version = $this->_connection->getAttribute(PDO::ATTR_SERVER_VERSION);
    } catch (PDOException $e) {
    // In case of the driver doesn't support getting attributes
    return null;
    }
    $matches = null;
    if (preg_match('/((?:[0-9]{1,2}\.){1,3}[0-9]{1,2})/', $version, $matches)) {
    return $matches[1];
    } else {
    return null;
    }
    }
    }

  6. #6
    Erfahrener Benutzer Avatar von SeKrebs
    Registriert seit
    04.02.2011
    Beiträge
    1.599
    Thanks
    1
    Thanked 58 Times in 46 Posts

    Standard

    • Quelltext mit mehr als (sagen wir) 20 Zeilen NIE direkt hier posten, sondern entsprechende Dienste (pastebin und co) verwenden. Das liest doch keiner
    • Für Quelltext (im Allgemeinen) "[CODE]"-BBCode-Tags verwenden, für PHP-Code (im Speziellen) "[PHP]"-BBCode-Tags verwenden. Kann doch sonst keiner lesen.
    • Der offizielle Code vom ZF steht sowieso jeden zur Verfügung. Ihn zu posten ist zwecklos (und liest keiner)
    • Bei Problemen IMMER mit angeben, was du machst. Eine Fehlermeldung in den Raum werfen bringt wenig, solange man nicht nachvollziehen kann, was sie auslöst
    • Fehlermeldungen NIE kürzen (eventuell persönliche Daten, wie Passwörter maskieren).

    Ergo: Brauchen mehr Informationen, was DU (bzw dein Programm) eigentlich tut, bevor/währenddessen es zu der Exception kommt.

    Und könnte ein Mod mal den Quelltext entfernen? Nervt etwas :X
    "KingCrunchs kleine Welt" -- Blog
    The problem with rats leaving a sinking ship is that they usually do it by gnawing holes in the bottom.

  7. #7
    Neuer Benutzer
    Registriert seit
    28.01.2012
    Beiträge
    6
    Thanks
    0
    Thanked 0 Times in 0 Posts

    Standard

    Ok sorry aber wie gesagt ich habe null Ahnung vom programmieren...

    Also wie gesagt habe ich mit dem Programm Weblica meine komplette Hompage erstellt. Die Fehlermeldung kommt beim Publizieren der Seite. Was ich nicht weiss, liegt der Fehler an meinem Hoster, an Weblica oder sonstigem ?
    Auf meiner Domain habe ich genug Speicherplatz, alle Daten sind in der httpdocs kopiert. Ich kann auch alle Homepage Seiten in der httpdocs betrachten, nur wenn ich auf die Start Seite klicke, kommt diese Fehlermeldung !?

Ähnliche Themen

  1. GData - Picasa Anbindung member function getAlbumFeed() Problem
    Von thE_iNviNciblE im Forum Web & Webservices
    Antworten: 4
    Letzter Beitrag: 05.06.2010, 22:32
  2. Antworten: 1
    Letzter Beitrag: 23.04.2010, 12:10
  3. Antworten: 2
    Letzter Beitrag: 03.07.2009, 01:01
  4. Fatal error:
    Von pkuhne im Forum Auth
    Antworten: 5
    Letzter Beitrag: 09.01.2009, 09:15
  5. quoteType() - Fatal error
    Von DennisBecker im Forum DB
    Antworten: 2
    Letzter Beitrag: 21.12.2007, 10:12

Lesezeichen

Berechtigungen

  • Neue Themen erstellen: Nein
  • Themen beantworten: Nein
  • Anhänge hochladen: Nein
  • Beiträge bearbeiten: Nein
  •