В предыдущем разделе мы представили использование некоторых классов шифрования и дешифрования. Давайте объединим их, чтобы провести простой тест. Код выглядит следующим образом.
Основная деятельность:
Скопируйте код кода следующим образом:
пакет com.home.testdes;
импортировать android.os.Bundle;
импортировать android.util.Log;
импортировать android.app.Activity;
публичный класс MainActivity расширяет Activity {
@Override
protected void onCreate (Bundle saveInstanceState) {
super.onCreate(saveInstanceState);
DESUtil u = новый DESUtil();
String mi = u.getEnc("Я люблю тебя");
Log.i("После шифрования", mi);
Строка ming = u.getDec(mi);
Log.i("После расшифровки", ming);
}
}
Инструменты шифрования и дешифрования:
Скопируйте код кода следующим образом:
пакет com.home.testdes;
импортировать java.security.Key;
импортировать java.security.spec.AlgorithmParameterSpec;
импортировать javax.crypto.Cipher;
импортировать javax.crypto.SecretKeyFactory;
импортировать javax.crypto.spec.DESKeySpec;
импортировать javax.crypto.spec.IvParameterSpec;
импортировать android.util.Base64;
/**
* Используйте инструменты шифрования и дешифрования DES.
*
* @author Администратор
*
*/
общественный класс DESUtil {
секретный ключ ключа;//ключевое значение ключа
частный байт[] DESkey;
частный байт[] DESIV = { 0x12, 0x34, 0x56, 0x78, (байт) 0x90, (байт) 0xAB,
(байт) 0xCD, (байт) 0xEF };
Private AlgorithmParameterSpec iv = null;//Интерфейс параметров алгоритма шифрования
общественный DESUtil () {
пытаться {
this.DESkey = "abcdefghijk".getBytes("UTF-8");//Установим ключ
DESKeySpec keySpec = new DESKeySpec(DESkey);//Установить ключевые параметры
iv = новый IvParameterSpec(DESIV); // Установить вектор
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");//Получаем фабрику ключей
key = keyFactory.generateSecret(keySpec);//Получаем объект ключа
} catch (Исключение е) {
е.printStackTrace();
}
}
/**
* Зашифрованная строка, ввод обычного текста, вывод зашифрованного текста
*
* @param inputString
* Простой текст для шифрования.
* @return зашифрованная строка
*/
общественная строка getEnc (String inputString) {
байт [] byteMi = ноль;
байт [] byteMing = ноль;
Строка выводаString = "";
пытаться {
byteMing = inputString.getBytes("UTF-8");
byteMi = this.getEncCode(byteMing);
byte[] temp = Base64.encode(byteMi, Base64.DEFAULT);
выходная строка = новая строка (темп);
} catch (Исключение е) {
} окончательно {
byteMing = ноль;
байтМи = ноль;
}
вернуть выходную строку;
}
/**
* Расшифруйте строку и введите открытый текст в виде зашифрованного текста и выведите результат.
*
* @param inputString
* Строка, которую необходимо расшифровать
* @return расшифрованная строка
*/
общественная строка getDec (String inputString) {
байт [] byteMing = ноль;
байт [] byteMi = ноль;
Строка strMing = "";
пытаться {
byteMi = Base64.decode(inputString.getBytes(), Base64.DEFAULT);
byteMing = this.getDesCode(byteMi);
strMing = новая строка (byteMing, "UTF8");
} catch (Исключение е) {
} окончательно {
byteMing = ноль;
байтМи = ноль;
}
вернуть стрМинг;
}
/**
* При шифровании используется ввод обычного текста byte[] и вывод зашифрованного текста byte[].
*
* @param BT
* Байт-код для шифрования
* @return зашифрованный байт-код
*/
частный byte[] getEncCode(byte[] bt) {
байт [] byteFina = ноль;
Шифр-шифр;
пытаться {
// Получаем экземпляр шифрования
cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, ключ, iv);
byteFina = cipher.doFinal(bt);
} catch (Исключение е) {
е.printStackTrace();
} окончательно {
шифр = ноль;
}
вернуть байтФина;
}
/**
* При расшифровке используется ввод зашифрованного текста byte[] и вывод открытого текста byte[].
*
* @param BT
* Байт-код для расшифровки
* @return расшифрованный байт-код
*/
частный byte[] getDesCode(byte[] bt) {
Шифр-шифр;
байт [] byteFina = ноль;
пытаться {
// Получаем экземпляр шифрования
cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
cipher.init(Cipher.DECRYPT_MODE, ключ, iv);
byteFina = cipher.doFinal(bt);
} catch (Исключение е) {
е.printStackTrace();
} окончательно {
шифр = ноль;
}
вернуть байтФина;
}
}