Magento 2: redirige al usuario a una página específica si no ha iniciado sesión


9

Necesito redirigir al usuario a una página de destino si no está conectado. Encuentro un trabajo similar en este enlace . ¿Hay una solución para Magento 2?

Respuestas:


21

Si queremos atrapar controller_action_predispatch, podemos seguir:

app / code / Vendor / Module / etc / events.xml


     <event name="controller_action_predispatch">
            <observer name="check_login_persistent" instance="Vendor\Module\Observer\CheckLoginPersistentObserver" />
     </event>

app / code / Vendor / Module / Observer / CheckLoginPersistentObserver.php

namespace Vendor\Module\Observer;
use Magento\Framework\Event\ObserverInterface;


class CheckLoginPersistentObserver implements ObserverInterface
{
         /**
         * @var \Magento\Framework\App\Response\RedirectInterface
         */
        protected $redirect;

        /**
         * Customer session
         *
         * @var \Magento\Customer\Model\Session
         */
        protected $_customerSession;

        public function __construct(
            \Magento\Customer\Model\Session $customerSession,
            \Magento\Framework\App\Response\RedirectInterface $redirect

        ) {

            $this->_customerSession = $customerSession;
            $this->redirect = $redirect;

        }

        public function execute(\Magento\Framework\Event\Observer $observer)
        {
            $actionName = $observer->getEvent()->getRequest()->getFullActionName();
            $controller = $observer->getControllerAction();

            $openActions = array(
                'create',
                'createpost',
                'login',
                'loginpost',
                'logoutsuccess',
                'forgotpassword',
                'forgotpasswordpost',
                'resetpassword',
                'resetpasswordpost',
                'confirm',
                'confirmation'
            );
            if ($controller == 'account' && in_array($actionName, $openActions)) {
                return $this; //if in allowed actions do nothing.
            }
            if(!$this->_customerSession->isLoggedIn()) {
                $this->redirect->redirect($controller->getResponse(), 'customer/account/login');
            }

        }

}

2
if ($controller == 'account' && in_array($action, $openActions)) { return $this; //if in allowed actions do nothing. }este código nunca se ejecutó su no es una variable con nombre de acción en el código. también en __construct (colocaste un "," al final que conduce a un error.
Ashish Madankar M2 Professiona

1
¿Cómo hace referencia a su controlador específico para esto? He copiado el código pero no entiendo cómo dispararlo cuando se golpea mi controlador.
harri

4

Hay una solución mucho más fácil. Mira este archivo:

src / vendor / magento / module-sales / etc / di.xml

<type name="Magento\Sales\Controller\Order\History">
    <plugin name="authentication" type="Magento\Sales\Controller\Order\Plugin\Authentication"/>
</type>

Entonces solo necesita usar el complemento de autenticación en su módulo di.xml


4

Para obtener más código de optimización y funcionamiento, puede seguir los pasos a continuación.

  1. crear archivo de evento @ app \ code \ Vendor \ Module \ etc \ frontend \ events.xml

    <?xml version='1.0'?>
    <config xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xsi:noNamespaceSchemaLocation='../../../../../lib/internal/Magento/Framework/Event/etc/events.xsd'>
        <event name='controller_action_predispatch'>
            <observer
                    name='checklogin'
                    instance='Vendor\Module\Model\Observer'
            />
        </event>
    </config>
    
  2. Crear la aplicación de archivo Observer \ code \ Vendor \ Module \ Model \ Observer.php

    namespace Vendor\Module\Model;
    
    class Observer implements \Magento\Framework\Event\ObserverInterface
    {
    
    public function execute(\Magento\Framework\Event\Observer $observer)
    {
        # check if user is logged in
        $objectManager = \Magento\Framework\App\ObjectManager::getInstance();
        $customerSession = $objectManager->get('Magento\Customer\Model\Session');
        if(!$customerSession->isLoggedIn())
        {
            $request = $objectManager->get('Magento\Framework\App\Request\Http');
            //get instance for URL interface
            /** @var \Magento\Framework\UrlInterface $urlInterface */
            $urlInterface = $objectManager->get('Magento\Framework\UrlInterface');
            // URL to redirect to
            $url = $urlInterface->getUrl('customer/account/login');
            if(strpos($request->getPathInfo(), '/customer/account/') !== 0)
            {
                # redirect to /customer/account/login
                $observer->getControllerAction()
                    ->getResponse()
                    ->setRedirect($url);
            }
        }
    }
Al usar nuestro sitio, usted reconoce que ha leído y comprende nuestra Política de Cookies y Política de Privacidad.
Licensed under cc by-sa 3.0 with attribution required.