Статус: Новичок
Группы: Участники
Зарегистрирован: 30.12.2020(UTC) Сообщений: 5 Откуда: Moscow Сказал(а) «Спасибо»: 1 раз
|
Здравствуйте. Установил криптопро JCP на linux. На виртуалке развернул винду и поставил криптопро CSP, установил сертификат .cer и ключ .pfx, зашифровал и расшифровал произвольный файл, тут все ок. Далее экспортировал контейнер с именем по типу xxxx.000 Расшифровать пытаюсь по аналогией с этой темой https://www.cryptopro.ru/forum2/...aspx?g=posts&t=12596Собственно если взять архив crypttests.zip из указанной выше темы и подставить в код, то все работает замечательно. При попытке использовать собственный контейнер, не получается извлечь приватный и публичный ключ из хранилища. Пример кода: Код:
import ru.CryptoPro.CAdES.EnvelopedSignature;
import ru.CryptoPro.CAdES.exception.EnvelopedException;
import ru.CryptoPro.Crypto.CryptoProvider;
import ru.CryptoPro.JCP.JCP;
import ru.CryptoPro.JCP.KeyStore.HDImage.HDImageStore;
import ru.CryptoPro.JCP.tools.Array;
import ru.CryptoPro.reprov.RevCheck;
import ru.CryptoPro.ssl.Provider;
import java.io.ByteArrayInputStream;
import java.io.FileOutputStream;
import java.security.KeyStore;
import java.security.PrivateKey;
import java.security.Security;
import java.security.cert.X509Certificate;
public class TestDecode {
private static final String PATH = System.getProperty("user.dir") + "/src/cryptotest/";
private static void decode(
String encodedFile, String decodedFile, String alias, char[] password) throws Exception {
System.out.println("Decrypting " + encodedFile);
byte[] encoded = Array.readFile(PATH + encodedFile);
var bais = new ByteArrayInputStream(encoded);
EnvelopedSignature envelopedSignature = new EnvelopedSignature(bais);
KeyStore keyStore = KeyStore.getInstance(JCP.HD_STORE_NAME);
keyStore.load(null, null);
PrivateKey privateKey = null;
try {
privateKey = (PrivateKey) keyStore.getKey(alias, password);
} catch (Exception e) {
e.printStackTrace();
}
X509Certificate cert = (X509Certificate) keyStore.getCertificate(alias);
if (null == privateKey || null == cert) {
throw new Exception("нет ключа или серта"); // При обращении к моему контейнеру и cert и privateKey равны null
}
FileOutputStream decoded = new FileOutputStream(PATH + decodedFile);
envelopedSignature.decrypt(cert, privateKey, decoded);
decoded.close();
System.out.println("Decrypted.");
}
public static void main(String[] args) throws Exception, EnvelopedException {
Security.addProvider(new JCP()); // JCP
Security.addProvider(new RevCheck()); // RevCheck
Security.addProvider(new CryptoProvider()); // JCryptoP
Security.addProvider(new Provider()); // JTLS
HDImageStore.setDir(PATH);
decode("123123123.txt.enc", "123123123.txt", "ec8cdfb5", null); // Мой контейнер
// decode("key12csp01.zip.enc", "key12csp01.decoded.zip", "k1707g12", null); // Контейнер из https://www.cryptopro.ru/forum2/default.aspx?g=posts&t=12596
}
}
При обращении к моему контейнеру и cert и privateKey равны null и программы отваливается по исключению. Прошу помощи, что именно я делаю не так. Отредактировано пользователем 14 января 2021 г. 22:13:07(UTC)
| Причина: Не указана
|
|
|
|
Статус: Сотрудник
Группы: Модератор, Участники Зарегистрирован: 03.12.2018(UTC) Сообщений: 1,195 Сказал(а) «Спасибо»: 100 раз Поблагодарили: 274 раз в 254 постах
|
Добрый день! а алиас точно совпадает? имя каталога это обычно первые 8 символов имени контейнера(он же алиас) Код:KeyStore keyStore = KeyStore.getInstance(JCP.HD_STORE_NAME);
keyStore.load(null,null);
List<String> listAlias = Collections.list(keyStore.aliases());
for (String tmp : listAlias)
System.out.println(tmp);
|
|
1 пользователь поблагодарил Санчир Момолдаев за этот пост.
|
|
|
Статус: Новичок
Группы: Участники
Зарегистрирован: 30.12.2020(UTC) Сообщений: 5 Откуда: Moscow Сказал(а) «Спасибо»: 1 раз
|
Благодарю за ответ, вы правы, проблема была в алиасе, а если точнее, в моем непонимании. Проблема решена, спасибо!
|
|
|
|
Быстрый переход
Вы не можете создавать новые темы в этом форуме.
Вы не можете отвечать в этом форуме.
Вы не можете удалять Ваши сообщения в этом форуме.
Вы не можете редактировать Ваши сообщения в этом форуме.
Вы не можете создавать опросы в этом форуме.
Вы не можете голосовать в этом форуме.
Important Information:
The Форум КриптоПро uses cookies. By continuing to browse this site, you are agreeing to our use of cookies.
More Details
Close