QR-сканер возвращает значение, отличное от того, которое я передаю ему - PullRequest
0 голосов
/ 06 января 2020

Пожалуйста, не обращайте внимания на алгоритм кодирования / размер изображения / пароль и т. Д. c. Это демо. Я генерирую qr-код следующим образом:

private final byte[] keyValue =
        new byte[]{'T', 'T', 'T', 'T', 'T', 'T', 'T', 'T', 'T', 'T', 'T', 'T', 'T', 'T', 'T', 'T'};


public String generateQR(ConsumerDto consumerDto) {
    CryptoUtil cryptoUtil = new CryptoUtil(keyValue);
    String encryptedConsumerDto = cryptoUtil.encrypt(String.valueOf(consumerDto));

    String resultImage = "";
    if (!StringUtils.isEmpty(consumerDto)) {
        QRCodeWriter writer = new QRCodeWriter();
        try (ByteArrayOutputStream outputStream = new ByteArrayOutputStream()) {
            BitMatrix bitMatrix = writer.encode(encryptedConsumerDto,
                    BarcodeFormat.QR_CODE, 500, 500, getHintsForEncoding());
            BufferedImage bufferedImage = MatrixToImageWriter.toBufferedImage(bitMatrix);
            ImageIO.write(bufferedImage, "png", outputStream);
            resultImage = "data:image/png;base64," + Base64.getEncoder().encodeToString(outputStream.toByteArray());
            return resultImage;
        } catch (WriterException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    return resultImage;
}

После генерации, когда я возвращаю значение в интерфейс, он находится в base64:



Но когда интерфейс пытается сканировать код (любой qr-сканер), он получает это значение:

zrzVfLTvdptoDEM0mDM795LN7xsiK8OND74EPuDfcc+pxniItkpDACO0yssEHNNrX6IdccyeyTlrDBmIsaETv5xsOMjOpLY0ZelX/kkyjwr7UQR59VmKLf4a7EwBlMGZsKFIpQoqXVptAEBDthL78QsJahLpCCtq7bcsOv9DUhjCz5P1j3Ai5GZ1xGobuVXRkLn0SYJInjPeSHihjcx47Q== 

Мне нужно получить из внешнего интерфейса ту же строку base64, которую я дал ему в кодировке, чтобы потом можно было ее декодировать. Вот криптуал, который я использую для кодирования / декодирования объектов:

public class CryptoUtil {

private static final String CRYPTO_ALGORITHM = "AES";
private static final Logger LOGGER = LoggerFactory.getLogger(CryptoUtil.class);
private static final byte[] keyValue =
        new byte[]{'T', 'h', 'e', 'B', 'e', 's', 't', 'S', 'e', 'c', 'r', 'e', 't', 'K', 'e', 'y'};


private final Key key;
private final Cipher cipher = getCipherInstance();

public CryptoUtil(byte[] key) {
    this.key = new SecretKeySpec(key, CRYPTO_ALGORITHM);
}

private Cipher getCipherInstance() {
    try {
        return Cipher.getInstance(CRYPTO_ALGORITHM);
    } catch (GeneralSecurityException e) {
        LOGGER.error("Crypto error: Unable to get cipher instance");
        throw new RuntimeException(e);
    }
}

public String encrypt(String password) {
    try {
        cipher.init(Cipher.ENCRYPT_MODE, key);
        byte[] encVal = cipher.doFinal(password.getBytes());
        return new BASE64Encoder().encode(encVal);
    } catch (GeneralSecurityException e) {
        LOGGER.error("Crypto error: Unable to encrypt password");
        throw new RuntimeException(e);
    }
}

public String decrypt(String encryptedPassword) {
    try {
        cipher.init(Cipher.DECRYPT_MODE, key);
        byte[] decodedValue = new BASE64Decoder().decodeBuffer(encryptedPassword);
        return new String(cipher.doFinal(decodedValue), StandardCharsets.UTF_8);
    } catch (GeneralSecurityException | IOException e) {
        LOGGER.error("Crypto error: Unable to encrypt password");
        throw new RuntimeException(e);
    }
}

}

...