как зашифровать / расшифровать текст в андроид студии на разных мероприятиях - PullRequest
0 голосов
/ 12 апреля 2019

Я пытался разработать приложение для шифрования / дешифрования текста в Android Studio.Итак, здесь на MainActivity.java я запустил пример кода шифрования и дешифрования.

MainActivity.java

import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;

public class MainActivity extends AppCompatActivity {

Button btn,btn2;
static final String TAG = "SymmetricAlgorithmAES";
String secr="k";
String secr2="d";

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    //code to use my specified defined key
    byte[] key = new byte[0];
    try {
        key = (secr+secr2).getBytes("UTF-8");
    } catch (UnsupportedEncodingException e) {
        e.printStackTrace();
    }
    MessageDigest sha = null;
    try {
        sha = MessageDigest.getInstance("SHA-1");
    } catch (NoSuchAlgorithmException e) {
        e.printStackTrace();
    }
    key = sha.digest(key);
    key = Arrays.copyOf(key, 16); // use only first 128 bit

    SecretKeySpec sks = new SecretKeySpec(key, "AES");

    // Original text
    String theTestText = "This is just a simple test";
    TextView tvorig = (TextView)findViewById(R.id.tvorig);
    tvorig.setText("\n[ORIGINAL]:\n" + theTestText + "\n");

    // Encode the original data with AES
    byte[] encodedBytes = null;
    try {
        Cipher c = Cipher.getInstance("AES");
        c.init(Cipher.ENCRYPT_MODE, sks);
        encodedBytes = c.doFinal(theTestText.getBytes());
    } catch (Exception e) {
        Log.e(TAG, "AES encryption error");
    }
    TextView tvencoded = (TextView)findViewById(R.id.tvencoded);
    tvencoded.setText("" +
            Base64.encodeToString(encodedBytes, Base64.DEFAULT) + "\n");

    // Decode the encoded data with AES
    byte[] decodedBytes = null;
    try {
        Cipher c = Cipher.getInstance("AES");
        c.init(Cipher.DECRYPT_MODE, sks);
        decodedBytes = c.doFinal(encodedBytes);
    } catch (Exception e) {
        Log.e(TAG, "AES decryption error");
    }
    TextView tvdecoded = (TextView)findViewById(R.id.tvdecoded);
    tvdecoded.setText("[DECODED]:\n" + new String(decodedBytes) + "\n");

   }

Код вышеработает правильно с правильным выводом.Но когда я пытаюсь изменить код и пытаюсь записать шифрование и дешифрование в различных действиях, но часть дешифрования не работает должным образом.

Вот код для шифрования , который работает правильнобез ошибок.

Encryption.java

import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;

public class Encryption extends AppCompatActivity {

static final String TAG = "SymmetricAlgorithmAES";
String secr="k";
String secr2="d";

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.encryption);
    enc_text_edt=(EditText)findViewById(R.id.enc_text_edt);
    enc_text_btn=(Button)findViewById(R.id.enc_text_btn);
    enctv=(TextView)findViewById(R.id.enctv);

    //code to use my specified defined key
    byte[] key = new byte[0];
    try {
        key = (secr+secr2).getBytes("UTF-8");
    } catch (UnsupportedEncodingException e) {
        e.printStackTrace();
    }
    MessageDigest sha = null;
    try {
        sha = MessageDigest.getInstance("SHA-1");
    } catch (NoSuchAlgorithmException e) {
        e.printStackTrace();
    }
    key = sha.digest(key);
    key = Arrays.copyOf(key, 16); // use only first 128 bit

    SecretKeySpec sks = new SecretKeySpec(key, "AES");

    final SecretKeySpec finalSks = sks;
    enc_text_btn.setOnClickListener(new OnClickListener() {

        @Override
        public void onClick(View v) {
            try {

                // Encode the original data with AES
                byte[] encodedBytes = null;
                try {
                    Cipher c = Cipher.getInstance("AES");
                    c.init(Cipher.ENCRYPT_MODE, finalSks);
                    encodedBytes = c.doFinal(enc_text_edt.getText().toString().getBytes());
                } catch (Exception e) {
                    Log.e(TAG, "AES encryption error");
                }


                enctv.setText("[ENCRYPTED]:\n" +
                        Base64.encodeToString(encodedBytes, Base64.DEFAULT) + "\n");


                enc_text_edt.setText("");


            } catch (Exception e) {

                e.printStackTrace();
            }

        }
    });
}
}

код расшифровки

Decryption.java

import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;

public class Decryption extends AppCompatActivity {

Button dec_text_btn;
TextView dec_edtext_view, dectv;

static final String TAG = "SymmetricAlgorithmAES";
String secr = "k";
String secr2 = "d";

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.decryption);
    dec_text_btn = (Button) findViewById(R.id.dec_text_btn);
    dec_edtext_view = (EditText) findViewById(R.id.dec_edtext_view);
    dectv = (TextView) findViewById(R.id.dectv);


    //code to use my specified defined key
    byte[] key = new byte[0];
    try {
        key = (secr + secr2).getBytes("UTF-8");
    } catch (UnsupportedEncodingException e) {
        e.printStackTrace();
    }
    MessageDigest sha = null;
    try {
        sha = MessageDigest.getInstance("SHA-1");
    } catch (NoSuchAlgorithmException e) {
        e.printStackTrace();
    }
    key = sha.digest(key);
    key = Arrays.copyOf(key, 16); // use only first 128 bit

    SecretKeySpec sks = new SecretKeySpec(key, "AES");


    final SecretKeySpec finalSks = sks;
    dec_text_btn.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {

            try {

                // Decode the encoded data with AES

                byte[] decodedBytes = null;
                try {
                    Cipher c = Cipher.getInstance("AES");
                    c.init(Cipher.DECRYPT_MODE, finalSks);
                    decodedBytes= c.doFinal(dec_edtext_view.getText().toString().getBytes());
                    } catch (Exception e) {
                        Log.e(TAG, "AES encryption error");
                    }

                    dectv.setText("[DECRYPTED]:\n" + new String(decodedBytes) + "\n");


                } catch (Exception e) {
                    e.printStackTrace();
                    Toast.makeText(getApplicationContext(), "creptography exception see log cat....", Toast.LENGTH_SHORT).show();
                }
        }
    });
}
}

Пожалуйста, помогите мне с ошибкой.При выполнении дешифрования он напрямую показывает исключение «исключение крептографии, см. Журнал cat» .

1 Ответ

0 голосов
/ 12 апреля 2019

После прочтения вашего кода, я думаю, что нашел проблему, вы кодируете в Base64, но никогда не декодируете.В Encryption вы делаете следующее

enctv.setText("[ENCRYPTED]:\n" +
                        Base64.encodeToString(encodedBytes, Base64.DEFAULT) + "\n");

, и я могу предположить, что пользователь копирует его в поле расшифровки, но после нажатия кнопки вы делаете

decodedBytes= c.doFinal(dec_edtext_view.getText().toString().getBytes());

вместо декодированияиз Base64.Я также хотел бы добавить несколько замечаний: вы не защищены, безопасность, вы едва достигли какого-либо уровня безопасности, когда ключи находятся на плоскости, как это.

Примечание 1:

Ключи должны генерироваться случайным образом с помощью SecureRandom .Вы можете легко сделать это, выполнив следующее:

byte[] key = new byte[16];
        new SecureRandom().nextBytes(key);

Примечание 2:

Используйте вектор инициализации или IV , это полезно, если пользователь набралто же сообщениеНапример, рассмотрим следующий сценарий, в котором вы шифруете «Hello World», и он выглядит как «ABCDEFGHIJK».Теперь вы отправляете это снова, и это снова "ABCDEFGHIJK".С IV он будет отличаться каждый раз, пока вы генерируете новый IV для сообщения, вы должны добавить этот IV к сообщению, чтобы позже при расшифровке вы могли извлечь его.

Примечание 3:

При объявлении Cipher используйте больше AES.Есть отличная статья о том, как повысить вашу безопасность и знания: ссылка на статью

Примечание 4:

Если возникнет исключение, не продолжайте, как ничего не случилось,вы должны обрабатывать его правильно и не продолжать работу с кодом, который зависит от того, что вызвало исключение.

Примечание 5:

Более подробно изучите Java, вместо того, чтобы переходить к криптографии.private и некоторые final не объявляют null, если вы планируете использовать его позже, если вы проверяете, имеет ли оно значение null.Не объявляйте "UTF-8" в байтах получения, имейте константу, объявляющую Charset , такую ​​как "UTF-8", это легко сделать с Charset.forName("UTF-8")

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...