Jak mogę odszyfrować zaszyfrowaną wartość konfiguracji?


12
protected $_paymentData;
protected $_scopeConfig;
protected $logger;

public function __construct(
    \Magento\Framework\Model\Context $context,
    \Magento\Framework\Registry $registry,
    \Magento\Framework\Api\ExtensionAttributesFactory $extensionFactory,
    \Magento\Framework\Api\AttributeValueFactory $customAttributeFactory,
    \Magento\Payment\Helper\Data $paymentData,
    \Magento\Framework\App\Config\ScopeConfigInterface $scopeConfig,
    \Magento\Payment\Model\Method\Logger $logger,
    \Magento\Framework\Module\ModuleListInterface $moduleList,
    \Magento\Framework\Stdlib\DateTime\TimezoneInterface $localeDate,
    \Magento\Directory\Model\CountryFactory $countryFactory,
    \Stripe\Stripe $stripe,
    \Inchoo\Stripe\Model\StripeFactory $stripeFactory,
    array $data = array()
) {
    parent::__construct(
        $context,
        $registry,
        $extensionFactory,
        $customAttributeFactory,
        $paymentData,
        $scopeConfig,
        $logger,
        $moduleList,
        $localeDate,
        null,
        null,
        $data
    );
    $this->_scopeConfig = $scopeConfig;
    $this->logger = $logger;
    $this->initializeData($data);
}
 public function getPaymentKey(){
   $key= $this->_scopeConfig->getValue('payment/webpay/keyid');
    echo $key;
    exit; 
}

Wynik echa: idfrk3-45pfnrkhwneirgplbmisniepssnie: hirtw45 True Key - 'p92GBhcQl7TklHOsWcxBk4eOmL6wpQWBG9nT2Qcf'

Odpowiedzi:


27

Wreszcie odnieś sukces w odszyfrowaniu kodu ...

protected $_encryptor;

public function __construct(
    \Magento\Framework\Encryption\EncryptorInterface $encryptor,
) {
    $this->_encryptor = $encryptor;
    parent::__construct($context);
}
$test = 'dfrk3-45pfnrkhwneirgplbmisniepssnie';
$test = $this->_encryptor->decrypt($test);
echo $test;

Udostępnij i pomóż innym ...


Zwraca pustą wartość. Jak uzyskać dane wyjściowe w czytelnym formacie?
Emipro Technologies Pvt. Ltd.

czy możesz udostępnić kod wydania?
Magento2 Devloper

20

\Magento\Framework\App\Config\ScopeConfigInterface::getValuezwróci odszyfrowaną wartość. Gdy ScopeConfigInterface::getValuezwraca zaszyfrowaną wartość, opcja konfiguracji jest niepoprawnie skonfigurowana . Prawidłowa implementacja zaszyfrowanej wartości konfiguracji to:

Dostawca / Moduł / etc / adminhtml / system.xml

Dodajemy tutaj niejasną wartość konfiguracyjną na ścieżce, payment/webpay/keyidktórą krytyczne rzeczy zapewniają i fieldmają dla . W ten sposób Magento wie, jak korzystać z zamaskowanego pola formularza i szyfrować dane wejściowe użytkownika podczas zapisywania.type="obscure"Magento\Config\Model\Config\Backend\Encryptedbackend_model

<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:module:Magento_Config:etc/system_file.xsd">
    <system>
        <section id="payment">
            <group id="webpay">
                <field id="keyid" translate="label" type="obscure" sortOrder="100" showInDefault="1" showInWebsite="1" showInStore="0">
                    <label>Key Id</label>
                    <backend_model>Magento\Config\Model\Config\Backend\Encrypted</backend_model>
                </field>
            </group>
        </section>
    </system>
</config>

Dostawca / Moduł / etc / config.xml

Dodanie backend_model="Magento\Config\Model\Config\Backend\Encrypted"tutaj mówi Magento, że wartość konfiguracji powinna zostać odszyfrowana podczas pobierania za pomocąScopeConfigInterface::getValue

<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:module:Magento_Store:etc/config.xsd">
    <default>
        <payment>
            <webpay>
                <keyid backend_model="Magento\Config\Model\Config\Backend\Encrypted" />
            </webpay>
        </payment>
    </default>
</config>

Dostawca / Moduł / etc / di.xml

Dodaje to ścieżkę konfiguracji do czułej tablicy i zapobiega włączeniu wartości ścieżki podczas zrzutu konfiguracji sklepu.

<?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\Config\Model\Config\TypePool">
        <arguments>
            <argument name="sensitive" xsi:type="array">
                <item name="payment/webpay/keyid" xsi:type="string">1</item>
            </argument>
        </arguments>
    </type>
</config>

Wydaje się, że istnieją pewne scenariusze, w których to nie działa, w moim przypadku działało to wcześniej i zepsuło się po przeniesieniu pola do dołączonej konfiguracji xml grupy. Powyższe sugestie zostały wdrożone, ale nie działały
snez

@ snez, czy próbowałeś ponownie zapisać konfigurację po jej przeniesieniu?
Roman Snitko

5

Jeśli masz zainstalowany n98-magerun2.phar, możesz uzyskać odszyfrowaną wartość konfiguracji za pomocą czegoś takiego:

php bin/n98-magerun2.phar config:store:get --decrypt payment/webpay/keyid

Możesz również ustawić zaszyfrowane wartości konfiguracji z wiersza poleceń za pomocą czegoś takiego:

php bin/n98-magerun2.phar config:store:set --encrypt payment/webpay/keyid NEW_KEY_ID_VALUE_HERE

Możesz pobrać n98-magerun2.phar stąd: https://github.com/netz98/n98-magerun2


2
czy n98 nie jest najlepszą rzeczą?
William Tran

Działa to również w n98-magerun (dla Magento 1)
CCBlackburn

0

You can try with below method for payment encryption method to get value,

Musisz zastąpić \Magento\Framework\App\Config\ScopeConfigInterface $scopeConfig,ścieżką poniżej klasy. \Magento\Payment\Gateway\ConfigInterface To działa dobrze,

   <?php
/**
 * Copyright © 2015 Magento. All rights reserved.
 * See COPYING.txt for license details.
 */
namespace Vendor\Module\Gateway\Http;

use Magento\Payment\Gateway\Http\TransferBuilder;
use Magento\Payment\Gateway\Http\TransferFactoryInterface;
use Magento\Payment\Gateway\Http\TransferInterface;
use Magento\Payment\Gateway\ConfigInterface;

class TransferFactory implements TransferFactoryInterface
{
    private $config;

    private $transferBuilder;

    public function __construct(
        ConfigInterface $config,
        TransferBuilder $transferBuilder
    ) {
        $this->config = $config;
        $this->transferBuilder = $transferBuilder;
    }


    public function getPaymentKey()
    {
        echo $this->config->getValue('payment/webpay/keyid')
    }
}

Czy to dla ciebie działa?
Rakesh Jesadiya

Błąd krytyczny: nie można utworzyć interfejsu Magento \ Payment \ Gateway \ ConfigInterface w E: \ wamp \ www \ magento2_8 \ vendor \ magento \ framework \ ObjectManager \ Factory \ Dynamic \ Developer.php w linii 73
Magento2 Devloper

rozwiązałeś problem?
Rakesh Jesadiya

brak pobierania Błąd krytyczny: Nie można utworzyć instancji interfejsu Magento \ Payment \ Gateway \ ConfigInterface w E: \ wamp \ www \ magento2_8 \ vendor \ magento \ framework \ ObjectManager \ Factory \ Dynamic \ De‌ veloper.php w wierszu 73.
Magento2 Devloper

wypróbuj powyższy kod i usuń folder var.
Rakesh Jesadiya

0

Jeśli chcesz odszyfrować jakąś wartość za pomocą klucza: Umieść poniższy kod w pliku decrypt-config-value.php w katalogu głównym projektu magento.

<?php

use Magento\Framework\App\Bootstrap;
require __DIR__ . '/app/bootstrap.php';

$bootstrap = Bootstrap::create(BP, $_SERVER);

$obj = $bootstrap->getObjectManager();

$state = $obj->get('Magento\Framework\App\State');
$state->setAreaCode('frontend');


######################################################################################################################

/**
 * @var \Magento\Framework\Encryption\EncryptorInterfaceFactory $ef
 */
$ef = $obj->get('Magento\Framework\Encryption\EncryptorInterfaceFactory');

class CustomDeploymentConfig extends \Magento\Framework\App\DeploymentConfig {
    public function get($key = null, $defaultValue = null)
    {
        return '8343d1c27ee612c73131c0ec693ed86e';
    }
}

/**
 * @var CustomDeploymentConfig $d
 */
$d = $obj->get(CustomDeploymentConfig::class);

/**
 * @var \Magento\Framework\Encryption\EncryptorInterface $e
 */
$e = $ef->create(['deploymentConfig' => $d]);

echo ">>>", $e->decrypt('encripted-value-here'), "<<<\n";

Uruchom php decrypt-config-value.php za pomocą konsoli lub //twojastrona.com/decrypt-config-value.php za pomocą przeglądarki.


-1

Spróbuj użyć poniższego kodu dla wartości dekodowania json,

class Paymentmodule
{
    protected $jsonEncoder;
    protected $jsonDecoder;

    public function __construct(
        ..//
        \Magento\Framework\Json\DecoderInterface $jsonDecoder
    ) {
        ..//
        $this->jsonDecoder = $jsonDecoder;
    }

    public function getPaymentKey()
    {
        $key= $this->_scopeConfig->getValue('payment/webpay/keyid');
        $config = $this->jsonDecoder->decode($key);
        echo $key;
    }

}

1
Dekodowanie nie powiodło się: błąd składni "; i: 1; s: 10720:" # 0 E: \ wamp \ www \ magento2_8 \ vendor \ magento \ framework \ Json \ Decoder.php (20): Zend_Json :: decode ('0: 2: 234SyEIM4aj ... ') # 1 E: \ wamp \ www \ magento2_8 \ vendor \ magento \ module-checkout \ Controller \ Onepage \ Success.php (58): Magento \ Framework \ Json \ Decoder-> dekodowanie (' 0: 2: 234SyEIM4aj ... ')
Magento2 Devloper

jakiś pomysł na ten błąd?
Magento2 Devloper

nie mam pojęcia o tym, ponieważ jest to metoda płatności, pracowałem dla powyższej metody dla prostego zapytania
Rakesh Jesadiya

błąd składniowy Myślę, że zdefiniuj inne typy.
Magento2 Devloper,

działa dobrze w prostym zapytaniu?
Magento2 Devloper
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.