Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/11: Рейтинг темы: голосов - 11, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 24.10.2016
Сообщений: 17

Не читается RSA pubkey

30.08.2017, 19:16. Показов 2330. Ответов 11
Метки rsa (Все метки)

Студворк — интернет-сервис помощи студентам
Привет.
Создаю rsa ключи и записываю в файлы

Code
1
2
3
4
5
6
7
8
9
10
11
12
13
        RSA * rsa = NULL;
    unsigned long bits = 1024;
    FILE * privKey_file = NULL, *pubKey_file = NULL;
    const EVP_CIPHER *cipher = NULL;
    privKey_file = fopen("private.key", "wb");
    pubKey_file = fopen("public.key", "wb");
    rsa = RSA_generate_key(bits, RSA_F4, NULL, NULL);
    cipher = EVP_get_cipherbyname("bf-ofb");
    PEM_write_RSAPrivateKey(privKey_file, rsa, cipher, NULL, 0, NULL, secret);
    PEM_write_RSAPublicKey(pubKey_file, rsa);
    RSA_free(rsa);
    fclose(privKey_file);
    fclose(pubKey_file);
В дальнейшем, пытаюсь считать открытый ключ

Code
1
2
3
4
5
      pubKey_file = fopen("./public.key", "rb");
    if (pubKey_file == NULL) return;
    pubKey = PEM_read_RSA_PUBKEY(pubKey_file, NULL, NULL, NULL);        <- !!!!!
    if (pubKey == NULL) return;
    fclose(pubKey_file);
Файл открывается, pubKey постоянно возвращает NULL.
Подскажите, где ошибка?
Спасибо.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
30.08.2017, 19:16
Ответы с готовыми решениями:

Как написать шифрование RSA на python без import RSA
Нужнен код без использование RSA библиотеки. Буду блогодарен!

диск с фильмом читается на двд для телевизора не читается на компьютерном двд роме
диск с фильмом читается на двд для телевизора не читается на компьютерном двд роме хочу этот диск прочитать для обработки фильма ...

Ошибка Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 0 at pr4.RSA.main(RSA.java:44)
package pr4; import java.math.BigInteger; import java.security.SecureRandom; public class RSA { private final...

11
nd2
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
30.08.2017, 19:22
Цитата Сообщение от cd0c Посмотреть сообщение
Файл открывается, pubKey постоянно возвращает NULL.
Как проверяешь? Отладчиком?
0
0 / 0 / 0
Регистрация: 24.10.2016
Сообщений: 17
30.08.2017, 19:26  [ТС]
Да, конечно
0
nd2
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
30.08.2017, 19:36
Если по этому образцу сделать?
C++
1
2
RSA* t = RSA_new();
RSA* rsa = PEM_read_RSA_PUBKEY(file, &t, nullptr, nullptr);
0
0 / 0 / 0
Регистрация: 24.10.2016
Сообщений: 17
30.08.2017, 19:42  [ТС]
Все равно null
0
nd2
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
30.08.2017, 19:42
Цитата Сообщение от cd0c Посмотреть сообщение
Все равно null
Код в студию!
0
0 / 0 / 0
Регистрация: 24.10.2016
Сообщений: 17
30.08.2017, 19:54  [ТС]
Я же в вопросе выложил код
0
nd2
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
30.08.2017, 19:57
Цитата Сообщение от cd0c Посмотреть сообщение
Я же в вопросе выложил код
Переделанный, вот с этим:
Цитата Сообщение от nd2 Посмотреть сообщение
Если по этому образцу сделать?
0
0 / 0 / 0
Регистрация: 24.10.2016
Сообщений: 17
30.08.2017, 20:10  [ТС]
Code
1
2
3
4
5
6
7
8
9
10
RSA * pubKey = NULL;
    RSA* t = RSA_new();
    FILE * pubKey_file = NULL;
    unsigned char *ctext, *ptext;
    int inlen, outlen;
    pubKey_file = fopen("./public.key", "rb");
    if (pubKey_file == NULL) return;
    pubKey = PEM_read_RSA_PUBKEY(pubKey_file, &t, NULL, NULL);
    if (pubKey == NULL) return;
    fclose(pubKey_file);
0
nd2
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
31.08.2017, 04:34
Попалась мне одна статья на эту тему (там тоже используется PEM_read_RSA_PUBKEY()), с такой цитатой:
Функция PEM_read_RSAPublicKey() не используется, потому что она, по так и не установленной причине, не читает ключ из файла, а возвращает NULL.
Я тоже не смог установить: почему, уже, PEM_read_RSA_PUBKEY() не читает ключ из файла, а возвращает NULL. Зато попробовал, отталкиваясь от обратного, применить PEM_read_RSAPublicKey() и, о чудо!!!...

Не по теме:


"О сколько нам открытий чудных
Готовят просвещенья дух
И опыт, сын ошибок трудных,
И гений, парадоксов друг,
И случай, бог изобретатель... "

А.С. Пушкин

1
0 / 0 / 0
Регистрация: 24.10.2016
Сообщений: 17
31.08.2017, 10:47  [ТС]
Можно Ваш код посмотреть?
У меня без изменений.
Миниатюры
Не читается RSA pubkey  
0
nd2
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
01.09.2017, 06:19
Лучший ответ Сообщение было отмечено cd0c как решение

Решение

Кликните здесь для просмотра всего текста
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
void handle_openssl_error(void)
{
     FILE* f;
     f = fopen("fileError.txt", "w");
     ERR_print_errors_fp(f);
}
 
void foo()
{
    int iRet = EXIT_SUCCESS;
    RSA * rsa = NULL;
    unsigned long bits = 1024;
    FILE * privKey_file = NULL, *pubKey_file = NULL;
    const EVP_CIPHER *cipher = NULL;
    privKey_file = fopen("private.key", "wb");
    pubKey_file = fopen("public.key", "wb");
    rsa = RSA_generate_key(bits, RSA_F4, NULL, NULL);
 
    OpenSSL_add_all_ciphers();
    cipher = EVP_get_cipherbyname("bf-ofb");
    if (!PEM_write_RSAPrivateKey(privKey_file, rsa, cipher, NULL, 0, NULL, "hello"))
    {
        fprintf(stderr,"PEM_write_PrivateKey failed.\n");
        handle_openssl_error();
        iRet = EXIT_FAILURE;
    }
    if (!PEM_write_RSAPublicKey(pubKey_file, rsa))
    {
        fprintf(stderr,"PEM_write_PublicKey failed.\n");
        handle_openssl_error();
        iRet = EXIT_FAILURE;
        
    }
    RSA_free(rsa);
    fclose(privKey_file);
    fclose(pubKey_file);
    
    
    RSA * pubKey = NULL;
    RSA* t = RSA_new();
    pubKey_file = NULL;
    unsigned char *ctext, *ptext;
    int inlen, outlen;
    pubKey_file = fopen("public.key", "rb");
    if (pubKey_file == NULL) 
        return;
   
    pubKey = PEM_read_RSAPublicKey(pubKey_file, NULL, NULL, NULL);
    //pubKey = PEM_read_RSA_PUBKEY(pubKey_file, &t, NULL, NULL);
    if (pubKey == NULL) 
       {
               fprintf(stderr,"PEM_read_RSA_PUBKEY failed.\n");
               handle_openssl_error();
               Ret = EXIT_FAILURE;
               return;
        }
    fclose(pubKey_file);
}
 
int main()
{  
    SSL_load_error_strings();
    ERR_load_BIO_strings();
    OpenSSL_add_all_algorithms();
    foo();
    system("pause");
 }

Добавлено через 1 час 9 минут
Функции для записи и чтения ключей должен соответствовать друг другу:
если запись с помощью PEM_write_RSA_PUBKEY(), то чтение с помощью PEM_read_RSA_PUBKEY(), если запись с помощью PEM_write_RSAPublicKey, то чтение с помощью PEM_read_RSAPublicKey().
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.09.2017, 06:19
Помогаю со студенческими работами здесь

Не читается BD RW DL
Перед стиранием в Nero9 (версия 9.0.9.4.) фильма с BD RW DL Verbatim запустилась CyberLink PowerDVD 12. CyberLink PowerDVD 12 свернул и...

Не читается БД
Есть приложение с QTableView (m_pMyPassView). Также создана БД (SQLite3) с одной таблицей DATA. Вот код, с помощью которого пытаюсь...

флешка не читается
Короче такая проблема,есть флешка на 8гб ей около 2 месяцев,всё нормально работало флешка не подвергалась повреждениям,но вчера вставил её...

Не читается из файла
Доброго времени суток, форумчане. В общем, столкнулся с проблемой, что не выводит на экран содержимое файла. Файл открывается, но...

Файл не читается
При отладке, появляется ошибка &quot;f:\dd\vctools\crt\crtw32\stdio\fopen.c Line 54 Expression(file!=NULL)&quot;. Подскажите пожалуйста из за чего...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение/ Перевод https:/ / **********/ gallery/ thinkpad-x220-tablet-porn-gzoEAjs . . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru