Question

Je travaille sur un panier (modèle de panier). L'une de ses propriétés protégées est "_items", qui contient un tableau d'objets de produit. Ils (les produits) sont tous stockés en DB pour remplir la session (en utilisant ZF, zend_session_savehandler_dbable () etc.).

public function addItem(Model_Product $product, $qty)
{
    $qty = (int) $qty;
    $pId = $product->getId();

    if ($qty > 0) {
        $this->_items[$pId] = array('product' => $product, 'qty' => $qty);
    } else {
        // if the quantity is zero (or less), remove item from stack
        unset($this->_items[$pId]);
    }

    // add new info to session
    $this->persist();
}

Dans le contrôleur, je prends un produit OBJ de DB avec le ProductMapper et je le fournis à "Additem ()":

    $product1 = $prodMapper->getProductByName('cap');
    $this->_cart->addItem($product1, 2);

getProductByName() Renvoie un nouvel objet Model_Product peuplé.


J'obtiens habituellement le

Please ensure that the class definition "Model_Product" of the object you are trying to operate on was loaded _before_ ...

Message d'erreur, un vidage de session affiche évidemment

['__PHP_Incomplete_Class_Name'] => 'Model_Product'


Je connais la "déclaration de la classe avant de la sérialiser". Mon problème est le suivant: comment puis-je déclarer la classe de produits en addItem(), s'il est injecté (premier param) en premier lieu? Ne serait pas une nouvelle déclaration (comme new Model_Product()) écraser le param (objet d'origine) dans addItem()? Dois-je le déclarer à nouveau dans le modèle CART?

De plus, j'obtiendrai sûrement un Cannot redeclare class Model_Product Si je ... le redécrassez-le dans le panier.

Était-ce utile?

La solution

Dans le bootstrap de ZF, la session a été lancée avant de automatiquement.

    /**
     * Make XXX_* classes available
     */
    protected function _initAutoloaders()
    {
        $loader = new Zend_Application_Module_Autoloader(array(
                    'namespace' => 'XXX',
                    'basePath' => APPLICATION_PATH
                ));
    }

    public function _initSession()
    {
        $config = $this->_config->custom->session;

        /**
         * For other settings, see the link below:
         * http://framework.zend.com/manual/en/zend.session.global_session_management.html
         */
        $sessionOptions = array(
            'name'             => $config->name,
            'gc_maxlifetime'   => $config->ttl,
            'use_only_cookies' => $config->onlyCookies,
//            'strict'           => true,
//            'path'             => '/',
        );

        // store session info in DB
        $sessDbConfig = array(
            'name'           => 'xxx_session',
            'primary'        => 'id',
            'modifiedColumn' => 'modified',
            'dataColumn'     => 'data',
            'lifetimeColumn' => 'lifetime'
        );

        Zend_Session::setOptions($sessionOptions);
        Zend_Session::setSaveHandler(new Zend_Session_SaveHandler_DbTable($sessDbConfig));
        Zend_Session::start();
    }

Quand je recevais les erreurs dont je parlais, la déclaration de la méthode était l'inverse: _initSession() était d'abord, alors _initAutoloaders() - Et c'était l'ordre exact que ZF les traitait.

Je vais en tester plus, mais cela semble fonctionner (et logique). Merci pour toutes vos suggestions.

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top