Classe PHP incomplète lors de la sérialisation de l'objet en sessions
-
29-10-2019 - |
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.
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.