相关疑难解决方法(0)

为什么java.security.NoSuchProviderException没有这样的提供者:BC?

jar(bcprov-jdk16-145.jar)已添加到项目中,Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider())已添加到类中,并BouncyCastleProvider.PROVIDER_NAME返回"BC"但AesFileIo.writeFile()仍然会抛出java.security.NoSuchProviderException No such provider: BC.有任何想法吗?

import java.io.FileOutputStream;
import java.io.InputStreamReader;
import java.io.ObjectOutputStream;
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import org.bouncycastle.jce.provider.BouncyCastleProvider;

public class AesFileIo {

    private static final String AES_ALGORITHM = "AES/CTR/NoPadding";
    private static final String PROVIDER = BouncyCastleProvider.PROVIDER_NAME;
    private static final byte[] AES_KEY_128 = { // Hard coded for now
        78, -90, 42, 70, -5, 20, -114, 103,
        -99, -25, 76, 95, -85, 94, 57, 54};
    private static final byte[] IV = { // …
Run Code Online (Sandbox Code Playgroud)

java security cryptography jce

65
推荐指数
3
解决办法
11万
查看次数

Android 4.2破坏了我的加密/解密代码,提供的解决方案无效

首先,我已经看到 Android 4.2 在Android 4.2 和提供的解决方案破坏了我的AES加密/解密代码加密错误:

SecureRandom sr = null;
if (android.os.Build.VERSION.SDK_INT >= JELLY_BEAN_4_2) {
    sr = SecureRandom.getInstance("SHA1PRNG", "Crypto");
} else {
    sr = SecureRandom.getInstance("SHA1PRNG");
}
Run Code Online (Sandbox Code Playgroud)

对我不起作用,因为,当解码Android 4.2中Android <4.2加密的数据时,我得到:

javax.crypto.BadPaddingException: pad block corrupted
at com.android.org.bouncycastle.jcajce.provider.symmetric.util.BaseBlockCipher.engineDoFinal(BaseBlockCipher.java:709)
Run Code Online (Sandbox Code Playgroud)

我的代码很简单,直到Android 4.2才开始工作:

public static byte[] encrypt(byte[] data, String seed) throws Exception {

    KeyGenerator keygen = KeyGenerator.getInstance("AES");
    SecureRandom secrand = SecureRandom.getInstance("SHA1PRNG");
    secrand.setSeed(seed.getBytes());
    keygen.init(128, secrand);

    SecretKey seckey = keygen.generateKey();
    byte[] rawKey = seckey.getEncoded();

    SecretKeySpec skeySpec = new SecretKeySpec(rawKey, "AES");
    Cipher cipher = …
Run Code Online (Sandbox Code Playgroud)

android cryptography bouncycastle

34
推荐指数
4
解决办法
3万
查看次数

我应该播种SecureRandom吗?

在我们的代码库中找到以下代码:

public static final int DEFAULT_LENGTH = 16;
private static SecureRandom SR;
static
{
   try
   {
      SecureRandom sd0 = new SecureRandom();
      SR = new SecureRandom(sd0.generateSeed(DEFAULT_LENGTH * 2));
   }
   catch (Exception e){}
}
Run Code Online (Sandbox Code Playgroud)

这里SecureRandom创建了一个默认值,然后用于为另一个创建一个种子,该种子将在稍后的类中使用.这真的有必要吗?第二个是否比第一个更好,因为这样做了?

当第二个生成种子时,给出了字节数,这个重要吗?一个能SecureRandom以不同的量要比其它字节的种子可能是好还是坏?用于播种它的字节数是否应该与它将用于什么?

如果未调用setSeed,则对nextBytes的第一次调用将强制SecureRandom对象自行播种.如果先前调用了setSeed,则不会发生这种自播种.- javadoc

自播不够好吗?它取决于它将用于什么?


注意:对于某些上下文,它在类中使用,为存储在数据库中的东西创建随机ID.

java random

25
推荐指数
3
解决办法
2万
查看次数

java.security.NoSuchProviderException:没有这样的提供者:BC

我正在使用AdvancedInstaller 9.8将我的javacode(webapplication)构建到安装程序.通常我的应用程序运行正常.使用Advanced Installer 9.8创建安装程序后,安装程序大小约为55 MB.但是高级安装程序中有一个选项可以压缩为安装而制作的所有罐子.如果我压缩罐子,安装程序大小约为16 MB.但是当我使用Advanced Installer 9.8进行压缩时,我在执行KeyPairGenerator行时获得异常(如标题中所述) kpg = KeyPairGenerator.getInstance("RSA","BC") ; 在我的代码中.KeyPairGenerator再次来自java.security.*;

有谁可以让我知道,这个问题可能是什么原因.我知道在使用AdvancedInstaller进行压缩时,可能会出现Advanced Installer压缩的问题.但我的问题是在java方面通常可能出现的问题,以解决这个问题.(我的意思是可能的原因,就像任何文件可能被损坏(或)等任何其他原因),以便我可以从那里开始工作.

java bouncycastle

8
推荐指数
2
解决办法
2万
查看次数

SecureNandom提供程序"Crypto"在Android N中不可用,用于确定性地生成密钥

用户可以购买我的应用程序的"专业版".当他们这样做时,我按如下方式存储和验证他们的购买.

  • 合并用户的UUID和另一个唯一字符串.
  • 然后使用静态种子加密生成的字符串.我这样做SecureRandom.getInstance("SHA1PRNG", "Crypto")- 这就是问题!
  • 然后,生成的加密字符串是"解锁代码".
  • 因此,我总是知道用户期望的唯一解锁代码值.
  • 当用户购买"Pro"时,我将"解锁代码"存储在数据库中.
  • 我通过查看数据库中存储的"解锁代码"是否与基于其唯一信息的预期代码匹配来检查用户是否具有"Pro" .

所以,不是最好的系统,但是对于我的简陋应用程序来说,所有内容都是模糊不清的.

问题是SecureRandom.getInstance("SHA1PRNG", "Crypto")在N 上失败,因为不支持"加密".我了解到依赖于特定的提供程序是不好的做法,并且N不支持加密.哎呀.

所以我遇到了一个问题:我依赖于值种子对的加密来始终具有相同的输出.Android N不支持我使用的加密提供程序,因此我不知道如何确保N上的加密输出与其他设备上的加密输出相同.

我的问题:

  1. 是否可以在我的APK中加入"加密"以便它始终可用?
  2. 加密Android N上的值种子对时,我可以确保相同的输出吗?

我的代码:

public static String encrypt(String seed, String cleartext) throws Exception {
    byte[] rawKey = getRawKey(seed.getBytes(), seed);
    byte[] result = encrypt(rawKey, cleartext.getBytes());
    return toHex(result); // "unlock code" which must always be the same for the same seed and clearText accross android versions
}

private static byte[] getRawKey(byte[] seed, …
Run Code Online (Sandbox Code Playgroud)

random android cryptography secure-random android-7.0-nougat

8
推荐指数
2
解决办法
6580
查看次数