メインのアプリを開発しましたが、最初のアプリと同じで機能の 70% しか実行しない 2 つ目のアプリを開発する必要があります。メインアプリの機能をモジュール化しましたが、構成ファイルに基づいてオン/オフできるようにしたいと考えています。この構成ファイルの値は、アクティビティとサービスのコンテキスト内でアクセスできる必要があります。多くの人が SharedPrefences の使用を提案しましたが、エンド ユーザーがこれを変更する必要はありません。これらの設定を構成するのは、開発者のみを対象としています。これに対する最善のアプローチは何ですか?
1 に答える
0
今アンドロイドデータはこれらの方法で保存することができます
設定を共有設定に保存したくないので、2 つの方法で行くことをお勧めします。両方のアプリからアクセスできる SQLite データベースを作成するか、設定データを保存し、両方のアプリからアクセスできるファイルを作成します。
データを保存するために選択した方法が何であれ、このような暗号化アルゴリズムを使用してデータを暗号化します
private static byte[] encrypt(byte[] raw, byte[] clear) throws Exception {
SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
Cipher cipher = Cipher.getInstance("AES");
cipher.init(Cipher.ENCRYPT_MODE, skeySpec);
byte[] encrypted = cipher.doFinal(clear);
return encrypted;
}
private static byte[] decrypt(byte[] raw, byte[] encrypted) throws Exception {
SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
Cipher cipher = Cipher.getInstance("AES");
cipher.init(Cipher.DECRYPT_MODE, skeySpec);
byte[] decrypted = cipher.doFinal(encrypted);
return decrypted;
}
そして、次のように呼び出します。
ByteArrayOutputStream baos = new ByteArrayOutputStream();
bm.compress(Bitmap.CompressFormat.PNG, 100, baos); // bm is the bitmap object
byte[] b = baos.toByteArray();
byte[] keyStart = "this is a key".getBytes();
KeyGenerator kgen = KeyGenerator.getInstance("AES");
SecureRandom sr = SecureRandom.getInstance("SHA1PRNG");
sr.setSeed(keyStart);
kgen.init(128, sr); // 192 and 256 bits may not be available
SecretKey skey = kgen.generateKey();
byte[] key = skey.getEncoded();
// encrypt
byte[] encryptedData = encrypt(key,b);
// decrypt
byte[] decryptedData = decrypt(key,encryptedData);
キーを使用してこれらの値にアクセスできるようになりましたが、ユーザーは構成情報を理解できません。
または、Web サービスを使用してデータをサーバーに保存し、両方のアプリでその Web サービスを使用して構成を取得できますが、オフラインでは動作しません :(
于 2012-11-01T04:39:51.657 に答える