我开发了一个主应用程序,现在我需要开发第二个应用程序,它与第一个应用程序完全相同,但仅执行70%的功能。我已经模块化了主应用程序的功能,但现在我希望能够基于配置文件打开/关闭它们。需要在“活动和服务”的上下文中访问此配置文件中的值。很多人建议使用SharedPrefences,但我不需要最终用户来修改它。它仅供开发人员配置这些设置。对此最好的方法是什么?
答案 0 :(得分:0)
现在在android数据中可以存储在these ways
中现在您不希望将配置存储在共享首选项中,因此我建议您采用两种方式 创建一个可由两个应用程序OR访问的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服务来获取配置,但它不会脱机工作:(