2011-11-15 78 views
2

我有一個依賴證書用戶的ASP.NET MVC 3應用程序。當我運行應用程序時,我收到一條錯誤消息:ASP.NET MVC 3 - 證書 - 配置錯誤

Configuration Error 
Description: An error occurred during the processing of a configuration file required to service this request. Please review the specific error details below and modify your configuration file appropriately. 

Parser Error Message: ID1024: The configuration property value is not valid. 
Property name: 'serviceCertificate' 
Error: 'ID1001: The certificate does not have an associated private key. 
Thumbprint: '[ID]'' 

Source Error: 


Line 278: 
Line 279: <microsoft.identityModel> 
Line 280: <service> 
Line 281:  <audienceUris> 
Line 282:  <!--<environment name="DEV">--> 

ID實際上是一個完整的指紋。我究竟做錯了什麼?我該如何解決?我懷疑我的證書沒有正確設置。但是,我不確定這是否屬實,或者如何檢查。謝謝!

回答

2

我能夠通過執行以下操作來解決此問題希望這會有所幫助。

 public static System.Security.Cryptography.X509Certificates.StoreName StoreName 
     { 
      get 
      { 
       StoreName storeName = StoreName.My; 
       if (WebConfigurationManager.AppSettings[SigningStoreName] != null) 
        storeName = (StoreName)Enum.Parse(typeof(StoreName), WebConfigurationManager.AppSettings[SigningStoreName]); 

       return storeName; 
      } 
     } 

     public static System.Security.Cryptography.X509Certificates.StoreLocation StoreLocation 
     { 
      get 
      { 
       StoreLocation storeLocation = StoreLocation.CurrentUser; 
       if (WebConfigurationManager.AppSettings[SigningStoreLocation] != null) 
        storeLocation = (StoreLocation)Enum.Parse(typeof(StoreLocation), WebConfigurationManager.AppSettings[SigningStoreLocation]); 

       return storeLocation; 
      } 
     } 

     public static SigningCredentials GetSigningCredentials() 
     { 
      X509Certificate2 cert = CertificateUtil.GetCertificate(StoreName, StoreLocation, WebConfigurationManager.AppSettings[Common.SigningSubjectNameOrThumbprint]); 
      string signatureAlgorithm = "http://www.w3.org/2000/09/xmldsig#rsa-sha1" 
        , digestAlgorithm = "http://www.w3.org/2000/09/xmldsig#sha1"; 

      RSACryptoServiceProvider rsa = cert.PrivateKey as RSACryptoServiceProvider; 
      if (rsa == null) rsa = RSA.Create() as RSACryptoServiceProvider; 

      RsaSecurityKey rsaKey = new RsaSecurityKey(rsa); 
      RsaKeyIdentifierClause rsaClause = new RsaKeyIdentifierClause(rsa); 
      SecurityKeyIdentifier signingSki = new SecurityKeyIdentifier(new SecurityKeyIdentifierClause[] { rsaClause }); 
      SigningCredentials signingCredentials = new SigningCredentials(rsaKey, signatureAlgorithm, digestAlgorithm, signingSki); 

      return signingCredentials; 
     } 

    public static X509Certificate2 GetCertificate(StoreName name, StoreLocation location, string subjectNameOrThumbprint) 
    { 
     X509Store store = new X509Store(name, location); 
     X509Certificate2Collection certificates = null; 
     store.Open(OpenFlags.ReadOnly); 

     try 
     { 
      X509Certificate2 result = null; 

      certificates = store.Certificates; 

      if (certificates != null && certificates.Count > 0) 
      { 
       result = (from X509Certificate2 cert in certificates 
          where !string.IsNullOrWhiteSpace(cert.Thumbprint) 
          && cert.Thumbprint.ToLower().Replace(" ", "") == subjectNameOrThumbprint.ToLower().Replace(" ", "") 
          select cert 
         ).FirstOrDefault(); 

       if (result == null) 
        result = (from X509Certificate2 cert in certificates 
           where cert.SubjectName != null 
           && cert.SubjectName.Name.ToLower().Replace(" ", "") == subjectNameOrThumbprint.ToLower().Replace(" ", "") 
           select cert 
          ).FirstOrDefault(); 
      } 

      string errMsg = string.Format("{0} - {1} in {2}", name.ToString(), subjectNameOrThumbprint, location.ToString()); 

      if (result == null) 
       throw new ApplicationException(string.Format("No certificate was found for {0} ", errMsg)); 
      else if (result.Verify() == false) 
       throw new ApplicationException(string.Format("Unable to verify certificate for {0}", errMsg)); 

      return result; 
     } 
     finally 
     { 
      store.Close(); 
     } 
    }