In this digital Era where data is life, no business can survive without collecting and storing data. And all the CMS has its own database where it stores the useful information collected from their customers. Technically, we can collect data in multiple ways using PHP, XML, sessions, cookies etc. But when we want to get or pass data securely and reliably, there is no better option than using JSON. And Magento has wisely implemented JSON to minimize the number of requests & amount of data transmitted between client and server. JSON is nothing but plain text, written with JavaScript object notation which is lightweight & data-interchange format supported by Magento.
Recently working on custom development, we came across the requirement of programmatically adding store products to the shopping cart. Definitely, you have come across such requirement or having thought in mind for adding products to cart at the click of the button. To do the same, we need to create one action which passes the products data & adds products to the shopping cart on click of button. After spending some time in coding, we pop out with a small piece of code that will help to do the same. So, presenting you another blog for programmatically adding products to cart using JSON in Magento 2.
First, we need to execute add to cart functions using custom extension. For that purpose create “Addcart.php” file inside extension folder.
app\code\Vendor\Extension\Controller\Index\Addcart.php
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 |
<?php namespace Vendor\Extension\Controller\Customer; class Addcart extends \Magento\Framework\App\Action\Action { protected $messageManager; protected $_responseFactory; protected $_url; protected $_request; protected $cart; protected $formkey; protected $json; protected $formKey; protected $obj_product; public function __construct (\Magento\Framework\App\Action\Context $context, \Magento\Framework\App\ResponseFactory $responseFactory, \Magento\Framework\Serialize\Serializer\Json $json, \Magento\Framework\Data\Form\FormKey $formKey, \Magento\Catalog\Model\Product $obj_product, \Magento\Checkout\Model\Cart $cart ) { $this->_responseFactory = $responseFactory; $this->cart = $cart; $this->json = $json; $this->formKey = $formKey; $this->obj_product = $obj_product; parent::__construct($context); } public function execute() { try { $productConfigData = 'a:7:{s:4:"uenc";s:72:"aHR0cDovL2xvY2FsaG9zdC9tMjI0cy9zcHJpdGUteW9nYS1jb21wYW5pb24ta2l0Lmh0bWw,";s:7:"product";s:2:"45";s:28:"selected_configurable_option";s:0:"";s:15:"related_product";s:0:"";s:13:"bundle_option";a:4:{i:1;s:1:"1";i:2;s:1:"4";i:3;s:1:"5";i:4;s:1:"8";}s:17:"bundle_option_qty";a:4:{i:1;s:1:"1";i:2;s:1:"1";i:3;s:1:"1";i:4;s:1:"1";}s:3:"qty";s:1:"1";}'; // for e.g we use static $productId = 1; // for e.g we use static foreach ($data['selectcart'] as $quotedata) { $Configdata = $this->json->unserialize($productConfigData); array_push($Configdata, 'form_key', $this->formKey->getFormKey()); $_product = $obj_product->load($productId); $this->cart->addProduct($_product, $Configdata); $this->cart->save(); } $message = "Products have been successfully added to your Shopping Cart."; $this->messageManager->addSuccess($message); $accUrl = $this->_url->getUrl('checkout/cart/'); $this->_responseFactory->create()->setRedirect($accUrl)->sendResponse(); $this->setRefererUrl($accUrl); } catch(\Exception $e) { $this->messageManager->addError($e->getMessage()); $accUrl = $this->_url->getUrl('*/*/'); $this->_responseFactory->create()->setRedirect($accUrl)->sendResponse(); $this->setRefererUrl($accUrl); } } } |
If you want to use static JSON data & Product ID, you can place static values inside the file according to your business need. You can even use & customize this code according to your need of adding different store products to the shopping cart.
That’s it for today, Let us know if you are facing an issue while implementing using this code by commenting below.
Happy Coding!