Pregunta

Estoy trabajando en un carrito de compras (modelo de carrito). Una de sus propiedades protegidas es "_Items", que contiene una matriz de objetos de producto. Ellos (productos) se almacenan en DB para poblar la sesión (usando ZF, Zend_Session_SaveHandler_DBTable () 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();
}

En el controlador, obtengo un producto de DB con el ProductMapper y lo proporciono a "AddItem ()":

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

getProductByName() Devuelve un nuevo objeto Model_Product poblado.


Normalmente consigo el

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

Mensaje de error, un volcado de sesión obviamente muestra

['__PHP_Incomplete_Class_Name'] => 'Model_Product'


Sé sobre "declarar la clase antes de serializarla". Mi problema es este: ¿cómo puedo declarar la clase de producto en addItem(), si se inyecta (primer parámetro) en primer lugar? ¿No sería una nueva declaración (como new Model_Product()) Sobrescribir el param (objeto original) en addItem()? ¿Debo declararlo nuevamente en el modelo de carrito?

Además, seguramente obtendré un Cannot redeclare class Model_Product Si ... lo redecaré en el carrito.

¿Fue útil?

Solución

En la bootstrap de ZF, se inició la sesión antes de Autoladering.

    /**
     * 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();
    }

Cuando recibía los errores de los que estaba hablando, la declaración del método era al revés: _initSession() fue primero, entonces _initAutoloaders() - Y este era el orden exacto que ZF los estaba procesando.

Probaré un poco más, pero esto parece funcionar (y lógico). Gracias por todas sus sugerencias.

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top