之前用的一個aes的加密解密在4.x-6.x的android版本手機上沒有問題,然后有天用一個android7.0的手機測試的時候,突然就出現加密完后,取值的時候獲取的是null,跟蹤代碼,發現加密存儲的時候拋出異常:
no such provider: Crypto
根本就沒存進去,具體的代碼出錯在下面這個方法中:
@SuppressLint("TrulyRandom")
private static byte[] getRawKey(byte[] seed) throws Exception {
KeyGenerator kgen = KeyGenerator.getInstance("AES");
SecureRandom sr = null;
if (android.os.Build.VERSION.SDK_INT >= 17) {
sr = SecureRandom.getInstance("SHA1PRNG", "Crypto");
} else {
sr = SecureRandom.getInstance("SHA1PRNG");
}
sr.setSeed(seed);
kgen.init(128, sr); // 192 and 256 bits may not be available
SecretKey skey = kgen.generateKey();
byte[] raw = skey.getEncoded();
return raw;
}
原來android7.0中已經沒有了“Crypto”,為了加密成功,只需要將以上方法中的
sr = SecureRandom.getInstance("SHA1PRNG", "Crypto");
替換為
sr = SecureRandom.getInstance("SHA1PRNG", new CryptoProvider());
那么getRawKey方法就變成以下的了:
@SuppressLint("TrulyRandom")
private static byte[] getRawKey(byte[] seed) throws Exception {
KeyGenerator kgen = KeyGenerator.getInstance("AES");
SecureRandom sr = null;
if (android.os.Build.VERSION.SDK_INT >= 17) {
sr = SecureRandom.getInstance("SHA1PRNG", new CryptoProvider());
} else {
sr = SecureRandom.getInstance("SHA1PRNG");
}
sr.setSeed(seed);
kgen.init(128, sr); // 192 and 256 bits may not be available
SecretKey skey = kgen.generateKey();
byte[] raw = skey.getEncoded();
return raw;
}
這樣還沒完,我們需要自己寫一個CryptoProvider類,CryptoProvider.java代碼如下:
static final class CryptoProvider extends Provider {
/**
* Creates a Provider and puts parameters
*/
public CryptoProvider() {
super("Crypto", 1.0, "HARMONY (SHA1 digest; SecureRandom; SHA1withDSA signature)");
put("SecureRandom.SHA1PRNG",
"org.apache.harmony.security.provider.crypto.SHA1PRNG_SecureRandomImpl");
put("SecureRandom.SHA1PRNG ImplementedIn", "Software");
}
}
ok,關于加密的就到這里了,謝謝誒。