0

我在我的 android 应用程序中使用这个库https://github.com/wg/scrypt 。我可以成功编译它并在我的 android 应用程序中绑定本机实现,但是如果 scryptN 函数在 32 位或 64 位环境中执行,它会产生不同的结果,这怎么可能?相反,java 实现在两种环境下都运行良好

要重现该问题,只需使用 NDK 构建共享库并尝试运行此功能

public String hashPassword(String plainPassword) {
        final int shift = 14;
        final int n = 1 << shift;
        final int r = 8;
        final int p = 1;
        final int dklen = 64;

        try {
            return ByteUtils.toHexString(SCrypt.scrypt(
                plainPassword.getBytes("utf-8"),
                "theseed".getBytes("utf-8"),
                n, r, p, dklen));
        } catch (Exception e) {
            LogHelper.e("error hashing password", e);
            return null;
        }
    }

如果您在 32 位架构或 64 位架构上运行,您将获得不同的输出

谢谢

4

1 回答 1

0

最后我找到了解决方案:

对于在 Android 上使用这个库的任何人,我建议改用这个 fork

https://github.com/lhunath/scrypt

它有一个完整的 android ndk 项目设置,您只需从 src/android/jni 文件夹运行 ndk-build(当然您需要正确配置 NDK),它会生成一组工作的 .so 文件。

注意:您必须更改 Application.mk 文件才能为所有平台生成它们

于 2017-07-18T07:01:41.537 回答