„Wystąpił błąd wewnętrzny.” Podczas ładowania pliku pfx z X509Certificate2

Próbuję użyć certyfikatu z podpisem własnym (c #):

X509Certificate2 cert = new X509Certificate2(
    Server.MapPath("~/App_Data/myhost.pfx"), "pass");

na współdzielonym serwerze hostingowym i wystąpił błąd:

System.Security.Cryptography.CryptographicException: An internal error occurred.

ślad stosu kończy się na

System.Security.Cryptography.CryptographicException.
    ThrowCryptogaphicException(Int32 hr) +33
System.Security.Cryptography.X509Certificates.X509Utils.
    _LoadCertFromFile(String fileName, IntPtr password, UInt32 dwFlags, 
        Boolean persistKeySet, SafeCertContextHandle& pCertCtx) +0
System.Security.Cryptography.X509Certificates.X509Certificate.
    LoadCertificateFromFile(String fileName, Object password, 
        X509KeyStorageFlags keyStorageFlags) +237
System.Security.Cryptography.X509Certificates.X509Certificate2..ctor(
    String fileName, String password) +131

Na moim komputerze dev ładuje się dobrze. Powód załadowania pliku * .pfx nie jest plikiem * .cer, ponieważ potrzebuję dostępu do klucza prywatnego (plik ładuje się Ok). Zrobiłem pfx na moim dev mochine w ten sposób:

makecert -r -n "CN=myhost.com, [email protected]" -sky exchange -b 01/01/2009
    -pe -sv myhost.pvk myhost.cer
<b>pvk2pfx</b> -pvk myhost.pvk -spc myhost.cer -pfx myhost.pfx -po pass</code>

Używam wersji v5.131.3790.0 makecert

questionAnswers(2)

yourAnswerToTheQuestion