0

メインのアプリを開発しましたが、最初のアプリと同じで機能の 70% しか実行しない 2 つ目のアプリを開発する必要があります。メインアプリの機能をモジュール化しましたが、構成ファイルに基づいてオン/オフできるようにしたいと考えています。この構成ファイルの値は、アクティビティとサービスのコンテキスト内でアクセスできる必要があります。多くの人が SharedPrefences の使用を提案しましたが、エンド ユーザーがこれを変更する必要はありません。これらの設定を構成するのは、開発者のみを対象としています。これに対する最善のアプローチは何ですか?

4

1 に答える 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 に答える