Всем привет. Никто не сталкивался с проблемой отсутствия корневых сертификатов

в айос? Имеется в виду стандартный QNetworkAccessManager. Мне пришлось сделать буквально ручную проверку сертификата, но это геммор, потому-что с каждой заменой сертификата (а гугл с эплом сейчас требуют менять их ежегодно) приходится принуждать юзеров обновляться, что не есть гуд. И вот очередной раз меняем сертификат и я решил таки разобраться с этим раз и навсегда. На сервере апач настроен так:
SSLCertificateFile - указан путь к файлу с сертификатом
SSLCertificateKeyFile - путь к файлу с ключом
SSLCertificateChainFile - путь к бандлу с двумя сертификатами CA, причем верхний самоподписанный, DigiCert Global Root CA
На андроиде никогда никаких проблем не возникало, на айос же сейчас (это отличается от предыдущего сертификата) ругается на вот этот верхний сертификат от DigiCert - QSslError::SelfSignedCertificateInChain - что вообще логично, ведь он верхнего уровня то. На десктопах тоже таких проблем нет. Только на айос. Может кто сталкивался и объяснит, что мы делаем неправильно?
Проверил вот такое - на загрузке приложения:
QSslConfiguration defConf = QSslConfiguration::defaultConfiguration();
QList<QSslCertificate> cadb = defConf.caCertificates();
qDebug() << "CA certificates:";
qDebug() << "-------------------------------";
for(int i=0; i < cadb.count(); i++)
{
qDebug() << cadb[i].toText();
qDebug() << "-------------------------------";
}
qDebug() << "-------------------------------";
Так вот на андроиде 137 сертификатов и среди них есть наш корневой. На айос же этот список пустой. В сети ничего нет, отсюда я делаю вывод, что это я тупой, а не баг в кьюте. Но в чём дело понять не могу

3 ответов

15 просмотров

Похоже, надо идти в сырцы, смотреть, как это реализуется для ios

Sergey eSKon- Автор вопроса
Anatoly Shirokov
Похоже, надо идти в сырцы, смотреть, как это реали...

офигеть: QList<QSslCertificate> QSslSocketPrivate::systemCaCertificates() { ensureInitialized(); QList<QSslCertificate> systemCerts; // SecTrustSettingsCopyCertificates is not defined on iOS. #ifdef Q_OS_MACOS // iterate through all enum members, order: // kSecTrustSettingsDomainUser, kSecTrustSettingsDomainAdmin, kSecTrustSettingsDomainSystem for (int dom = kSecTrustSettingsDomainUser; dom <= int(kSecTrustSettingsDomainSystem); dom++) { QCFType<CFArrayRef> cfCerts; OSStatus status = SecTrustSettingsCopyCertificates(SecTrustSettingsDomain(dom), &cfCerts); if (status == noErr) { const CFIndex size = CFArrayGetCount(cfCerts); for (CFIndex i = 0; i < size; ++i) { SecCertificateRef cfCert = (SecCertificateRef)CFArrayGetValueAtIndex(cfCerts, i); QCFType<CFDataRef> derData = SecCertificateCopyData(cfCert); if (isCaCertificateTrusted(cfCert, dom)) { if (derData == NULL) { qCWarning(lcSsl, "Error retrieving a CA certificate from the system store"); } else { systemCerts << QSslCertificate(QByteArray::fromCFData(derData), QSsl::Der); } } } } } #endif return systemCerts; } то есть он на айос системные CA вообще не грузит... что за нафиг...

Похожие вопросы

Обсуждают сегодня

Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Ребят, подскажите, пожалуйста, почему в префиксе к ассетам, которые генерируются через фильтр | theme в шаблоне, стал вдруг появляться index.php? Вот так выглядит ссылка на а...
Виталий
1
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Коллеги, может знает кто, можно ли цвет бейджа счётчика в BackendMenu менять без бубнов?
Alex Blaze
3
Карта сайта