如何为 android api 8 (Froyo) 添加 PBKDF2WithHmacSHA1

Posted

技术标签:

【中文标题】如何为 android api 8 (Froyo) 添加 PBKDF2WithHmacSHA1【英文标题】:How to add PBKDF2WithHmacSHA1 for android api 8 (Froyo) 【发布时间】:2011-10-17 06:51:59 【问题描述】:

我需要一些帮助。我正在编写应用程序,需要使用“PBKDF2WithHmacSHA1”算法(无法更改服务器端)。但这在android中不起作用(不支持),但是我在eclipse中创建了android-maven项目,它在Gingerbread上运行良好,并且是最新的。但在 Froyo 上却没有。我尝试添加具有该算法但没有的安全提供程序。我可以在可用列表中看到它,但无法获取它的实例。我事件尝试spoungycastle(重新编译的bouncecastle),SunJCE。也许您有相同的建议如何解决? o 一些解决方法?

在这一行我得到错误

SecretKeyFactory factory = SecretKeyFactory.getInstance("PBKDF2WithHmacSHA1");

错误:

W/System.err( 1225): java.security.NoSuchAlgorithmException: SecretKeyFactory PBKDF2WithHmacSHA1 implementation not found:
W/System.err( 1225):    at java.security.Provider$Service.newInstance(Provider.java:1100)
W/System.err( 1225):    at org.apache.harmony.security.fortress.Engine.getInstance(Engine.java:112)
W/System.err( 1225):    at javax.crypto.SecretKeyFactory.getInstance(SecretKeyFactory.java:111)
W/System.err( 1225):    at com.ii.app.AppActivity.onCreate(AppActivity.java:46)
W/System.err( 1225):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
W/System.err( 1225):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
W/System.err( 1225):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
W/System.err( 1225):    at android.app.ActivityThread.access$2300(ActivityThread.java:125)
W/System.err( 1225):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
W/System.err( 1225):    at android.os.Handler.dispatchMessage(Handler.java:99)
W/System.err( 1225):    at android.os.Looper.loop(Looper.java:123)
W/System.err( 1225):    at android.app.ActivityThread.main(ActivityThread.java:4627)
W/System.err( 1225):    at java.lang.reflect.Method.invokeNative(Native Method)
W/System.err( 1225):    at java.lang.reflect.Method.invoke(Method.java:521)
W/System.err( 1225):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
W/System.err( 1225):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
W/System.err( 1225):    at dalvik.system.NativeStart.main(Native Method)
W/System.err( 1225): Caused by: java.lang.NullPointerException
W/System.err( 1225):    at com.sun.crypto.provider.SunJCE$2.run(DashoA13*..)
W/System.err( 1225):    at java.security.AccessController.doPrivilegedImpl(AccessController.java:264)
W/System.err( 1225):    at java.security.AccessController.doPrivileged(AccessController.java:84)
W/System.err( 1225):    at com.sun.crypto.provider.SunJCE.c(DashoA13*..)
W/System.err( 1225):    at com.sun.crypto.provider.SunJCE.b(DashoA13*..)
W/System.err( 1225):    at com.sun.crypto.provider.PBKDF2HmacSHA1Factory.<init>(DashoA13*..)
W/System.err( 1225):    at java.lang.Class.newInstanceImpl(Native Method)
W/System.err( 1225):    at java.lang.Class.newInstance(Class.java:1429)
W/System.err( 1225):    at java.security.Provider$Service.newInstance(Provider.java:1098)
W/System.err( 1225):    ... 16 more

【问题讨论】:

运气好,我也有同样的错误? 【参考方案1】:

Spongycastle 有效,但并不简单。你必须这样做:

private static byte[] decryptPBKDF2WithBC(char[] password, byte[] data, byte[] salt, byte[] iv)
  throws NoSuchAlgorithmException, InvalidKeySpecException, NoSuchPaddingException, InvalidKeyException,
  InvalidAlgorithmParameterException, IllegalBlockSizeException, BadPaddingException 

   PBEParametersGenerator generator = new PKCS5S2ParametersGenerator();
   generator.init(PBEParametersGenerator.PKCS5PasswordToUTF8Bytes(password), salt,CryptographicToolBox.CRYPTO_ITERATIONS);
   KeyParameter params = (KeyParameter)generator.generateDerivedParameters(CryptographicToolBox.KEY_SIZE);

   byte[] endcoded = params.getKey();
   SecretKey key = new SecretKeySpec(endcoded, "AES");

   Cipher ciph = Cipher.getInstance("AES/CBC/PKCS5Padding");

   ciph.init(Cipher.DECRYPT_MODE, key, new IvParameterSpec(iv);
   return ciph.doFinal(data);

【讨论】:

我以不同的解决方案结束。现在我连接到其他服务器,我可以在其中控制要使用的加密算法。所以现在我不能检查你的答案。如果有人也解决了这个问题,请写下这个解决方案的工作原理,我会接受答案。 我喜欢这个答案,因为它让我清楚地知道如何使用 IV。

以上是关于如何为 android api 8 (Froyo) 添加 PBKDF2WithHmacSHA1的主要内容,如果未能解决你的问题,请参考以下文章

如何为较旧和较新的 Android 版本实现不同的 API?

如何为小于 24 的 API 添加 Android 网络安全配置

如何为 android 制作更长的 facebook Graph API 会话

如何为个人 android 项目获取 OpenStreetMaps 或 OpenTilesMaps API?

如何为 API 级别 < 23 的项目设置重力

如何为我的 Android 应用获取 Google Places API 密钥