Как зашифровать и расшифровать с помощью Camellia 128bit в коде Android JAVA?

Каков синтаксис имени провайдера для Camellia 128bit в коде Android JAVA?? я пытаюсь изменить с Cipher.getInstance("AES/CBC/PKCS7Padding") в Cipher.getInstance("Camellia/CBC/PKCS7Padding","BC")но он говорит, что поставщик BC не предоставляет "Camellia/CBC/PKCS7Padding". Ниже мой код

try {
      String keyString = "Potatoman55@";//length of key is 16
      Cipher desCipher = Cipher.getInstance("Camellia/CBC/PKCS7Padding","BC");
      byte[] key = new byte[0];
      if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.GINGERBREAD) {
          if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
              key = keyString.getBytes(StandardCharsets.UTF_8);
          }
      }
      MessageDigest sha = MessageDigest.getInstance("SHA-1");
      key = sha.digest(key);
      if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.GINGERBREAD) {
          key = Arrays.copyOf(key, 16); // use only first 128 bit
      }

      SecretKeySpec secretKeySpec = new SecretKeySpec(key, "AES");
      desCipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);

      String plainText = "hello wolrd";
      System.out.println("plaintext: "+plainText);

      byte[] text = plainText.getBytes("UTF-8");
      byte[] textencrypted = desCipher.doFinal(text);
      String textEnc = null;
      if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
          System.out.println("encrypted: " + Base64.getEncoder().encodeToString(textencrypted));
          textEnc = Base64.getEncoder().encodeToString(textencrypted);
      }
      result.success(textEnc);

  } catch (Exception ex) {
      System.out.println(ex.toString());
  }

1 ответ

Решение

Я успешно запустил код по этому коду new org.bouncycastle.jce.provider.BouncyCastleProvider());как провайдер. Большое спасибо за этот комментарий. ниже полный синтаксис

Cipher desCipher = Cipher.getInstance("Camellia/CBC/PKCS7Padding",new org.bouncycastle.jce.provider.BouncyCastleProvider());
Другие вопросы по тегам