Magento 2 - Redirecionar o cliente para a página personalizada após o login


9

Qual classe devo substituir para redirecionar um cliente para uma página específica após o login?

Eu tentei definir Redirect Customer to Account Dashboard after Logging inna configuração da loja, mas não está funcionando.


Você ativar ou desativar o Guest Checkout?
precisa saber é o seguinte

Desativei o checkout de convidado.
Paul

E o seu problema atual?
precisa saber é o seguinte

O código que você forneceu é um pouco diferente do meu magento. Talvez seja de versões diferentes. E eu não entendo por que isso está relacionado ao cookie. Finalmente resolvi substituindo a classe LoginPost. Eu postei minha resposta abaixo. Obrigado!
Paul

11
Minha versão do magento é a v2.0.8
Paul

Respostas:


28

Um plug-in é uma solução melhor nesse caso, porque sua classe estendida pode precisar ser atualizada quando o Magento 2 for atualizado.

Aqui está uma solução usando um pós-plugin no LoginPost-> execute () conforme sugerido por Xenocide8998.

/Vendor/Module/etc/frontend/di.xml:

<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:ObjectManager/etc/config.xsd">
  <type name="\Magento\Customer\Controller\Account\LoginPost">
    <plugin name="vendor_module_loginpostplugin" type="\Vendor\Module\Plugin\LoginPostPlugin" sortOrder="1" />
  </type>
</config>

/Vendor/Module/Plugin/LoginPostPlugin.php:

<?php

/**
 *
 */
namespace Vendor\Module\Plugin;

/**
 *
 */
class LoginPostPlugin
{

    /**
     * Change redirect after login to home instead of dashboard.
     *
     * @param \Magento\Customer\Controller\Account\LoginPost $subject
     * @param \Magento\Framework\Controller\Result\Redirect $result
     */
    public function afterExecute(
        \Magento\Customer\Controller\Account\LoginPost $subject,
        $result)
    {
        $result->setPath('/'); // Change this to what you want
        return $result;
    }

}

11
Isso funciona bem. Uma coisa é quando você precisa $ result-> setPath ('/'); ao seu caminho personalizado, não use "/" antes do URL, por exemplo. $ result-> setPath ('cliente / painel /');
Shuvankar Paul

Boa abordagem usando o plugin
Hafiz Arslan

Trabalho perfeito obrigado
HaFiz Umer

Seu único problema é que, se o cliente tentar fazer login e falhar, você ainda acessará a página inicial. Não há como capturar logons com falha.
21719 Andy

como posso passar o URL da página atual para este plugin?
Rahul

6

Eu o resolvi substituindo a classe LoginPost

etc / di.xml

<preference for="Magento\Customer\Controller\Account\LoginPost" type="Vendor\Module\Controller\Account\LoginPost" />

Fornecedor / Módulo / Controlador / Conta / LoginPost.php

<?php

namespace Vendor\Module\Controller\Account;

use Magento\Customer\Model\Account\Redirect as AccountRedirect;
use Magento\Framework\App\Action\Context;
use Magento\Customer\Model\Session;
use Magento\Customer\Api\AccountManagementInterface;
use Magento\Customer\Model\Url as CustomerUrl;
use Magento\Framework\Exception\EmailNotConfirmedException;
use Magento\Framework\Exception\AuthenticationException;
use Magento\Framework\Data\Form\FormKey\Validator;

/**
 * @SuppressWarnings(PHPMD.CouplingBetweenObjects)
 */
class LoginPost extends \Magento\Customer\Controller\Account\LoginPost {

    public function execute() {
        if ($this->session->isLoggedIn() || !$this->formKeyValidator->validate($this->getRequest())) {
            /** @var \Magento\Framework\Controller\Result\Redirect $resultRedirect */
            $resultRedirect = $this->resultRedirectFactory->create();
            $resultRedirect->setPath('home');
            return $resultRedirect;
        }

        if ($this->getRequest()->isPost()) {
            $login = $this->getRequest()->getPost('login');
            if (!empty($login['username']) && !empty($login['password'])) {
                try {
                    $customer = $this->customerAccountManagement->authenticate($login['username'], $login['password']);
                    $this->session->setCustomerDataAsLoggedIn($customer);
                    $this->session->regenerateId();
                } catch (EmailNotConfirmedException $e) {
                    $value = $this->customerUrl->getEmailConfirmationUrl($login['username']);
                    $message = __(
                            'This account is not confirmed.' .
                            ' <a href="%1">Click here</a> to resend confirmation email.', $value
                    );
                    $this->messageManager->addError($message);
                    $this->session->setUsername($login['username']);
                } catch (AuthenticationException $e) {
                    $message = __('Invalid login or password.');
                    $this->messageManager->addError($message);
                    $this->session->setUsername($login['username']);
                } catch (\Exception $e) {
                    $this->messageManager->addError(__('Invalid login or password.'));
                }
            } else {
                $this->messageManager->addError(__('A login and a password are required.'));
            }
        }

        $resultRedirect = $this->resultRedirectFactory->create();
        $resultRedirect->setPath('home');
        return $resultRedirect;
    }

}

12
Acho que usando um plugin com o afterExecute()seria uma opção mais limpa
Xenocide8998

2
Esta não é uma boa abordagem e só causará problemas no futuro. Plugin é o caminho a percorrer.
Phagento

podemos redirecionar do painel da conta para a página de histórico de pedidos de vendas por padrão?
jafar pinjar

0

Que o armazenamento local atual causou nosso problema.
Se habilitarmos ou desabilitarmos o Redirect Customer to Account Dashboard after Logging inCheck-out do convidado na configuração, esse recurso funcionará bem. No entanto, precisamos limpar o armazenamento local.

Podemos verificar o armazenamento local localStorage.getItem('mage-cache-storage').

Dê uma olhada:

fornecedor / magento / check-out do módulo / view / frontend / web / js / sidebar.js

var cart = customerData.get('cart'),
customer = customerData.get('customer');
if (!customer().firstname && cart().isGuestCheckoutAllowed === false) {
    // set URL for redirect on successful login/registration. It's postprocessed on backend.
    $.cookie('login_redirect', this.options.url.checkout);
    if (this.options.url.isRedirectRequired) {
        location.href = this.options.url.loginUrl;
    } else {
        authenticationPopup.showModal();
    }

    return false;
}

O Magento definirá o cookie com $.cookie('login_redirect', this.options.url.checkout)base no customerDataarmazenamento local.

Do controlador vendor/magento/module-customer/Controller/Account/LoginPost.php. Ele verificará o URL de redirecionamento do cookie.

$redirectUrl = $this->accountRedirect->getRedirectCookie();
if (!$this->getScopeConfig()->getValue('customer/startup/redirect_dashboard') && $redirectUrl) {
    ......
    return $resultRedirect;
}

Versão Magento:

-Magento versão 2.1.0


0

Resolvi isso passando o referenciador no controlador de módulo personalizado.

Etapa 1 `

use Magento\Framework\App\Action\Context;
use Magento\Framework\View\Result\PageFactory;
use Magento\Customer\Model\Session;
use Magento\Framework\UrlInterface;

class Approve extends \Magento\Framework\App\Action\Action {

    /** 
    * @var \Magento\Framework\View\Result\Page 
    */
    protected $resultPageFactory;

    /** 
    * $param \Magento\Framework\App\Action\Context $context */

    /**
    * @param CustomerSession
    */

    protected $_customerSession;

    protected $_urlInterface;

    public function __construct(
        Context $context,
        PageFactory $resultPageFactory,
        Session $customerSession,
        UrlInterface $urlInterface
    )
    {
        $this->resultPageFactory = $resultPageFactory;
        $this->_customerSession  = $customerSession;
        $this->_urlInterface     = $urlInterface;
        parent::__construct($context);

    }

    public function execute(){
        $url  = $this->_urlInterface->getUrl('*/*/*', ['_current' => true, '_use_rewrite' => true]); 
// here pass custom url or you can either use current url on which you are currently and want to come back after logged in.

        $loginUrl = $this->_urlInterface->getUrl('customer/account/login', array('referer' => base64_encode($url)));
        if($this->_customerSession->isLoggedIn()){
            return $this->resultPageFactory->create();
        }
        $this->_redirect($loginUrl);
    }
}`

Passo 2

Vá para Admin: Loja> Configuração> Clientes> Configuração do Cliente> Opções de Login> Redirecionar Painel do Cliente para a Conta após o login> Não

Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.