当前位置: 首页>>代码示例>>C#>>正文


C# X509Certificate2.Reset方法代码示例

本文整理汇总了C#中System.Security.Cryptography.X509Certificates.X509Certificate2.Reset方法的典型用法代码示例。如果您正苦于以下问题:C# X509Certificate2.Reset方法的具体用法?C# X509Certificate2.Reset怎么用?C# X509Certificate2.Reset使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在System.Security.Cryptography.X509Certificates.X509Certificate2的用法示例。


在下文中一共展示了X509Certificate2.Reset方法的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: X509Certificate2

 public static byte[] HybridDecrypt
                             (
                                 X509Certificate2 decryptorPrivateKeyPfx
                                 , Secret data
                             )
 {
     X509Certificate2 encryptorPublicKeyCer = null;
     try
     {
         RSACryptoServiceProvider decryptorPrivateKeyPfxProvider = decryptorPrivateKeyPfx.PrivateKey as RSACryptoServiceProvider;
         encryptorPublicKeyCer = new X509Certificate2(data.EncryptorPublicKeyCerRawData);
         RSACryptoServiceProvider encryptorPublicKeyCerProvider = encryptorPublicKeyCer.PublicKey.Key as RSACryptoServiceProvider;
         return HybridDecrypt
                             (
                                 decryptorPrivateKeyPfxProvider
                                 , encryptorPublicKeyCerProvider
                                 , data
                             );
     }
     catch
     {
         return null;
     }
     finally
     {
         if (encryptorPublicKeyCer != null)
         {
             encryptorPublicKeyCer.Reset();
         }
     }
 }
开发者ID:Microshaoft,项目名称:Microshaoft.Common.Utilities.Net.4x,代码行数:31,代码来源:CryptographyHelper.cs

示例2: BuscaNome

 public static X509Certificate2 BuscaNome(string Nome)
  {
      X509Certificate2 _X509Cert = new X509Certificate2();
      try
      {
          X509Store store = new X509Store("MY", StoreLocation.CurrentUser);
          store.Open(OpenFlags.ReadOnly | OpenFlags.OpenExistingOnly);
          X509Certificate2Collection collection = (X509Certificate2Collection)store.Certificates;
          X509Certificate2Collection collection1 = (X509Certificate2Collection)collection.Find(X509FindType.FindByTimeValid, HLP.GeraXml.dao.daoUtil.GetDateServidor(), false);
          X509Certificate2Collection collection2 = (X509Certificate2Collection)collection.Find(X509FindType.FindByKeyUsage, X509KeyUsageFlags.DigitalSignature, false);
          if (Nome == "")
          {
              X509Certificate2Collection scollection = X509Certificate2UI.SelectFromCollection(collection2, "Certificado(s) Digital(is) disponível(is)", "Selecione o Certificado Digital para uso no aplicativo", X509SelectionFlag.SingleSelection);
              if (scollection.Count == 0)
              {
                  _X509Cert.Reset();
                  Console.WriteLine("Nenhum certificado escolhido", "Atenção");
              }
              else
              {
                  _X509Cert = scollection[0];
              }
          }
          else
          {
              X509Certificate2Collection scollection = (X509Certificate2Collection)collection2.Find(X509FindType.FindBySubjectDistinguishedName, Nome, false);
              if (scollection.Count == 0)
              {
                  Console.WriteLine("Nenhum certificado válido foi encontrado com o nome informado: " + Nome, "Atenção");
                  _X509Cert.Reset();
              }
              else
              {
                  _X509Cert = scollection[0];
              }
          }
          store.Close();
          return _X509Cert;
      }
      catch (System.Exception ex)
      {
          Console.WriteLine(ex.Message);
          return _X509Cert;
      }
  }
开发者ID:dramosti,项目名称:GeraXml_3.0,代码行数:45,代码来源:belCertificadoDigital.cs

示例3: BuscaNroSerie

        public X509Certificate2 BuscaNroSerie(string NroSerie)
        {
            X509Certificate2 _X509Cert = new X509Certificate2();
            try
            {

                X509Store store = new X509Store("MY", StoreLocation.CurrentUser);
                store.Open(OpenFlags.ReadOnly | OpenFlags.OpenExistingOnly);
                X509Certificate2Collection collection = (X509Certificate2Collection)store.Certificates;
                X509Certificate2Collection collection1 = (X509Certificate2Collection)collection.Find(X509FindType.FindByTimeValid, DateTime.Now, true);
                X509Certificate2Collection collection2 = (X509Certificate2Collection)collection1.Find(X509FindType.FindByKeyUsage, X509KeyUsageFlags.DigitalSignature, true);
                if (NroSerie == "")
                {
                    X509Certificate2Collection scollection = X509Certificate2UI.SelectFromCollection(collection2, "Certificados Digitais", "Selecione o Certificado Digital para uso no aplicativo", X509SelectionFlag.SingleSelection);
                    if (scollection.Count == 0)
                    {
                        _X509Cert.Reset();
                        Console.WriteLine("Nenhum certificado válido foi encontrado com o número de série informado: " + NroSerie, "Atenção");
                    }
                    else
                    {
                        _X509Cert = scollection[0];
                    }
                }
                else
                {
                    X509Certificate2Collection scollection = (X509Certificate2Collection)collection2.Find(X509FindType.FindBySerialNumber, NroSerie, true);
                    if (scollection.Count == 0)
                    {
                        _X509Cert.Reset();
                        Console.WriteLine("Nenhum certificado válido foi encontrado com o número de série informado: " + NroSerie, "Atenção");
                    }
                    else
                    {
                        _X509Cert = scollection[0];
                    }
                }
                store.Close();
                return _X509Cert;
            }
            catch (System.Exception ex)
            {
                Console.WriteLine(ex.Message);
                return _X509Cert;
            }
        }
开发者ID:dramosti,项目名称:GeraXml_2.0,代码行数:46,代码来源:belGerarxml.cs

示例4: TryGetMatchingX509Certificate

        private bool TryGetMatchingX509Certificate(IntPtr certContext, X509FindType findType, uint dwFindType, object findValue, bool validOnly, out X509Certificate2 cert)
        {
            cert = new X509Certificate2(certContext);
            if (dwFindType == 0)
            {
                switch (findType)
                {
                    case X509FindType.FindBySubjectDistinguishedName:
                        if (string.Compare((string) findValue, cert.SubjectName.Name, StringComparison.OrdinalIgnoreCase) == 0)
                        {
                            break;
                        }
                        cert.Reset();
                        cert = null;
                        return false;

                    case X509FindType.FindByIssuerDistinguishedName:
                        if (string.Compare((string) findValue, cert.IssuerName.Name, StringComparison.OrdinalIgnoreCase) == 0)
                        {
                            break;
                        }
                        cert.Reset();
                        cert = null;
                        return false;

                    case X509FindType.FindBySerialNumber:
                        if (this.BinaryMatches((byte[]) findValue, cert.GetSerialNumber()))
                        {
                            break;
                        }
                        cert.Reset();
                        cert = null;
                        return false;

                    case X509FindType.FindBySubjectKeyIdentifier:
                    {
                        X509SubjectKeyIdentifierExtension extension = cert.Extensions["2.5.29.14"] as X509SubjectKeyIdentifierExtension;
                        if ((extension == null) || !this.BinaryMatches((byte[]) findValue, extension.RawData))
                        {
                            cert.Reset();
                            cert = null;
                            return false;
                        }
                        break;
                    }
                }
            }
            if (validOnly && !new X509Chain(false) { ChainPolicy = { RevocationMode = X509RevocationMode.NoCheck, RevocationFlag = X509RevocationFlag.ExcludeRoot } }.Build(cert))
            {
                cert.Reset();
                cert = null;
                return false;
            }
            return (cert != null);
        }
开发者ID:pritesh-mandowara-sp,项目名称:DecompliedDotNetLibraries,代码行数:55,代码来源:X509CertificateStore.cs

示例5: InstallClientCertificateToKeystore

        /////////////////////////////////////////////////////
        //                                                 //
        // InstallClientCertificateToKeystore()            //
        //                                                 //
        /////////////////////////////////////////////////////
        //Description:  Takes a public or private key file and
        //              adds it to the local user's key store
        //Returns:      the key data as a string
        /////////////////////////////////////////////////////
        internal static bool InstallClientCertificateToKeystore(X509Certificate2 certificate)
        {
            //try to open local machine's crypto store
            X509Store store;
            try
            {
                //open the user's certificate store
                store = new X509Store("MY", StoreLocation.CurrentUser);
                store.Open(OpenFlags.ReadWrite | OpenFlags.OpenExistingOnly);
            }
            catch (Exception ex)
            {
                throw new Exception("Failed to open MY store:  " + ex.Message);
            }

            //add the new X509 cert to the opened store
            store.Add(certificate);

            //close store
            store.Close();
            certificate.Reset();

            return true;
        }
开发者ID:kumaraguruv,项目名称:codeword,代码行数:33,代码来源:CwCryptoHelper.cs

示例6: SelecionarCertificado

        /// <summary>
        /// Busca certificados instalado se informado uma serie
        /// se não abre caixa de dialogos de certificados.
        /// </summary>
        /// <param name="cerSerie">Serie do certificado.</param>
        /// <returns>X509Certificate2.</returns>
        /// <exception cref="System.Exception">
        /// Nenhum certificado digital foi selecionado ou o certificado selecionado está com problemas.
        /// or
        /// Certificado digital não encontrado
        /// or
        /// </exception>
        public static X509Certificate2 SelecionarCertificado(string cerSerie)
        {
            var certificate = new X509Certificate2();
            try
            {
                X509Certificate2Collection certificatesSel = null;
                var store = new X509Store("MY", StoreLocation.CurrentUser);
                store.Open(OpenFlags.OpenExistingOnly);
                var certificates = store.Certificates.Find(X509FindType.FindByTimeValid, DateTime.Now, true)
                    .Find(X509FindType.FindByKeyUsage, X509KeyUsageFlags.DigitalSignature, true);
                if ((string.IsNullOrEmpty(cerSerie)))
                {
                    certificatesSel = X509Certificate2UI.SelectFromCollection(certificates, "Certificados Digitais", "Selecione o Certificado Digital para uso no aplicativo", X509SelectionFlag.SingleSelection);
                    if ((certificatesSel.Count == 0))
                    {
                        certificate.Reset();
                        throw new Exception("Nenhum certificado digital foi selecionado ou o certificado selecionado está com problemas.");
                    }

                    certificate = certificatesSel[0];
                }
                else
                {
                    certificatesSel = certificates.Find(X509FindType.FindBySerialNumber, cerSerie, true);
                    if ((certificatesSel.Count == 0))
                    {
                        certificate.Reset();
                        throw new Exception("Certificado digital não encontrado");
                    }

                    certificate = certificatesSel[0];
                }

                store.Close();
                return certificate;
            }
            catch (Exception exception)
            {
                throw new Exception(exception.Message);
            }
        }
开发者ID:rnmoge,项目名称:ACBr.Net.Core,代码行数:53,代码来源:CertificadoDigital.cs

示例7: TryGetMatchingX509Certificate

        bool TryGetMatchingX509Certificate(IntPtr certContext, X509FindType findType,
            uint dwFindType, object findValue, bool validOnly, out X509Certificate2 cert)
        {
            cert = new X509Certificate2(certContext);
            if (dwFindType == CAPI.CERT_FIND_ANY)
            {
                switch (findType)
                {
                    case X509FindType.FindBySubjectDistinguishedName:
                        if (0 != String.Compare((string)findValue, cert.SubjectName.Name, StringComparison.OrdinalIgnoreCase))
                        {
                            cert.Reset();
                            cert = null;
                            return false;
                        }
                        break;

                    case X509FindType.FindByIssuerDistinguishedName:
                        if (0 != String.Compare((string)findValue, cert.IssuerName.Name, StringComparison.OrdinalIgnoreCase))
                        {
                            cert.Reset();
                            cert = null;
                            return false;
                        }
                        break;

                    case X509FindType.FindBySerialNumber:
                        if (!BinaryMatches((byte[])findValue, cert.GetSerialNumber()))
                        {
                            cert.Reset();
                            cert = null;
                            return false;
                        }
                        break;

                    case X509FindType.FindBySubjectKeyIdentifier:
                        X509SubjectKeyIdentifierExtension skiExtension =
                            cert.Extensions[CAPI.SubjectKeyIdentifierOid] as X509SubjectKeyIdentifierExtension;
                        if (skiExtension == null || !BinaryMatches((byte[])findValue, skiExtension.RawData))
                        {
                            cert.Reset();
                            cert = null;
                            return false;
                        }
                        break;

                    default:
                        DiagnosticUtility.DebugAssert(findType + " is not supported!");
                        break;
                }
            }

            if (validOnly)
            {
                X509Chain chain = new X509Chain(false);
                chain.ChainPolicy.RevocationMode = X509RevocationMode.NoCheck;
                chain.ChainPolicy.RevocationFlag = X509RevocationFlag.ExcludeRoot;
                if (!chain.Build(cert))
                {
                    cert.Reset();
                    cert = null;
                    return false;
                }
            }
            return cert != null;
        }
开发者ID:nlh774,项目名称:DotNetReferenceSource,代码行数:66,代码来源:X509CertificateStore.cs


注:本文中的System.Security.Cryptography.X509Certificates.X509Certificate2.Reset方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。