Получение аналогичного зашифрованного текста для клиента React Native в виде кода Java на стороне сервера - PullRequest
2 голосов
/ 07 марта 2020

Я новичок в React Native. Парень на стороне сервера написал логи шифрования c в Java, которые выглядят следующим образом

import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;
import java.util.Base64;

import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;

@Service
public class AES {

    @Autowired
    static AesProps props;

    private static String secretkey = "abcdefghijklmnopqhijklmnopq"; // Sample key

    private static SecretKeySpec secretKey;
    private static byte[] key;

    public static void setKey(String myKey) {
        MessageDigest sha = null;
        try {
            key = myKey.getBytes("UTF-8");
            sha = MessageDigest.getInstance("SHA-1");
            key = sha.digest(key);
            key = Arrays.copyOf(key, 16);
            secretKey = new SecretKeySpec(key, "AES");
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        }
    }

    public static String encrypt(String strToEncrypt) {
        try {
            setKey(secretkey);
            Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5PADDING");
            cipher.init(Cipher.ENCRYPT_MODE, secretKey);
            return Base64.getEncoder().encodeToString(cipher.doFinal(strToEncrypt.getBytes("UTF-8")));
        } catch (Exception e) {
            System.out.println("Error while encrypting: " + e.toString());
        }
        return null;
    }

Я пытаюсь найти способ шифрования в React Native, который даст мне тот же шифр, что и выше. Java код. Я прошел react-native-aes-crypto, но многие вещи отсутствуют. Например, как использовать PKCS5PADDING и как сделать соответствующий SecretKeySpec. Любая помощь будет высоко ценится.

...