все, у мене є ланцюжок робочих сертифікатів (перевіряється з OpenSSL), але я якось не можу сказати Git завантажувати ці сертифікати.
Я отримую ту саму помилку "ненадійного кореневого авторитету" (SEC_E_UNTRUSTED_ROOT) незалежно від того, чи вказує моя конфігурація git на існуючий чи фальшивий файл ланцюжка сертифікатів.
Для детальної інформації перегляньте доданий скріншот.
Налаштування, яке я використовую .gitconfig
для підробленого файлу:
sslCAInfo = C:/tmp/foobar.crt
або для реального файлу, який працює з OpenSSL:
sslCAInfo = C:/tmp/ca-bundle.crt
Стенограма консолі:
C:\tmp>openssl version
OpenSSL 0.9.8h 28 May 2008
C:\tmp>git --version
git version 2.12.2.windows.2
C:\tmp>git config --list
http.sslverify=true
http.sslcainfo=C:/tmp/ca-bundle.crt
C:\tmp>dir
24.04.2017 13:45 10.875 ca-bundle.crt
c:\tmp>openssl s_client -state -connect https://mygithost:443 -CAfile .\ca-bundle.crt
Verify return code: 0 (ok)
C:\tmp git clone https://mygithost/bitbucket/scm/my.git
Cloning into ...
fatal: unable to access ... : schannel: next InitializeSecurityContext failed: SEC_E_UNTRUSTED_ROOT (0x80090325) - The certificate chain was issued by an authority that is not trusted.
C:\tmp> git -c http.sslverify=false clone https://mygithost/bitbucket/scm/my.git
Cloning into ...
Resoliving deltas: 100%, done.
C:\tmp>git config --list
http.sslverify=true
http.sslcainfo=C:/tmp/foobar.crt
C:\tmp\xxx\git pull
fatal: unable to access ... : schannel: next InitializeSecurityContext failed: SEC_E_UNTRUSTED_ROOT (0x80090325) - The certificate chain was issued by an authority that is not trusted.
set SSL_CERT_FILE=C:\tmp\ca-bundle.crt
щоб сказати openssl, де знайти пакет
C:\git config --get-all-- => error: wrong number of arguments