當前位置: 首頁>>代碼示例>>C#>>正文


C# SafeHandles.SafeSslContextHandle類代碼示例

本文整理匯總了C#中Microsoft.Win32.SafeHandles.SafeSslContextHandle的典型用法代碼示例。如果您正苦於以下問題:C# SafeSslContextHandle類的具體用法?C# SafeSslContextHandle怎麽用?C# SafeSslContextHandle使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


SafeSslContextHandle類屬於Microsoft.Win32.SafeHandles命名空間,在下文中一共展示了SafeSslContextHandle類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: Create

            public static SafeSslHandle Create(SafeSslContextHandle context, bool isServer)
            {
                IntPtr memMethod = libcrypto.BIO_s_mem();

                SafeBioHandle readBio = libcrypto.BIO_new(memMethod);
                if (readBio.IsInvalid)
                {
                    return new SafeSslHandle();
                }

                SafeBioHandle writeBio = libcrypto.BIO_new(memMethod);
                if (writeBio.IsInvalid)
                {
                    readBio.Dispose();
                    return new SafeSslHandle();
                }
                
                SafeSslHandle handle = SSL_new(context);
                if (handle.IsInvalid)
                {
                    readBio.Dispose();
                    writeBio.Dispose();
                    return handle;
                }
                handle._isServer = isServer;

                // After SSL_set_bio, the BIO handles are owned by SSL pointer
                // and are automatically freed by SSL_free. To prevent a double
                // free, we need to keep the ref counts bumped up till SSL_free
                bool gotRef = false;
                readBio.DangerousAddRef(ref gotRef);
                try
                {
                    bool ignore = false;
                    writeBio.DangerousAddRef(ref ignore);
                }
                catch
                {
                    if (gotRef)
                    {
                        readBio.DangerousRelease();
                    }
                    throw;
                }

                SSL_set_bio(handle, readBio, writeBio);
                handle._readBio = readBio;
                handle._writeBio = writeBio;

                if (isServer)
                {
                    SSL_set_accept_state(handle);
                }
                else
                {
                    SSL_set_connect_state(handle);
                }
                return handle;
            }
開發者ID:rainersigwald,項目名稱:corefx,代碼行數:59,代碼來源:Interop.SafeSslHandle.cs

示例2: SetSslCtxVerifyCallback

            private static CURLcode SetSslCtxVerifyCallback(
                IntPtr curl,
                IntPtr sslCtx)
            {
                using (SafeSslContextHandle ctx = new SafeSslContextHandle(sslCtx, ownsHandle: false))
                {
                    Interop.Ssl.SslCtxSetCertVerifyCallback(ctx, s_sslVerifyCallback, IntPtr.Zero);
                }

                return CURLcode.CURLE_OK;
            }
開發者ID:ReedKimble,項目名稱:corefx,代碼行數:11,代碼來源:CurlHandler.SslProvider.cs

示例3: SetSslCtxVerifyCallback

            private static int SetSslCtxVerifyCallback(
                IntPtr curl,
                IntPtr sslCtx,
                IntPtr userPtr)
            {
                using (SafeSslContextHandle ctx = new SafeSslContextHandle(sslCtx, ownsHandle: false))
                {
                    Interop.Ssl.SslCtxSetCertVerifyCallback(ctx, s_sslVerifyCallback, userPtr);
                }

                return Interop.libcurl.CURLcode.CURLE_OK;
            }
開發者ID:nadyalo,項目名稱:corefx,代碼行數:12,代碼來源:CurlHandler.SslProvider.cs

示例4: SetSslCtxVerifyCallback

            private static CURLcode SetSslCtxVerifyCallback(
                IntPtr curl,
                IntPtr sslCtx,
                IntPtr userPointer)
            {
                using (SafeSslContextHandle ctx = new SafeSslContextHandle(sslCtx, ownsHandle: false))
                {
                    Interop.Ssl.SslCtxSetCertVerifyCallback(ctx, s_sslVerifyCallback, curl);

                    if (userPointer == IntPtr.Zero)
                    {
                        VerboseTrace("Not using client Certificate callback ");
                    }
                    else
                    {
                        ClientCertificateProvider provider = null;
                        try
                        {
                            GCHandle handle = GCHandle.FromIntPtr(userPointer);
                            provider = (ClientCertificateProvider)handle.Target;
                        }
                        catch (InvalidCastException)
                        {
                            Debug.Fail("ClientCertificateProvider wasn't the GCHandle's Target");
                            return CURLcode.CURLE_ABORTED_BY_CALLBACK;
                        }
                        catch (InvalidOperationException)
                        {
                            Debug.Fail("Invalid GCHandle in CurlSslCallback");
                            return CURLcode.CURLE_ABORTED_BY_CALLBACK;
                        }

                        Debug.Assert(provider != null, "Expected non-null sslCallback in curlCallBack");
                        Interop.Ssl.SslCtxSetClientCertCallback(ctx, provider._callback);
                    }
                }
                return CURLcode.CURLE_OK;
            }
開發者ID:rahulkotecha,項目名稱:corefx,代碼行數:38,代碼來源:CurlHandler.SslProvider.cs

示例5: SetEncryptionPolicy

 internal static extern void SetEncryptionPolicy(SafeSslContextHandle ctx, EncryptionPolicy policy);
開發者ID:ReedKimble,項目名稱:corefx,代碼行數:1,代碼來源:Interop.Ssl.cs

示例6: SslCtxSetVerify

 internal static extern void SslCtxSetVerify(SafeSslContextHandle ctx, SslCtxSetVerifyCallback callback);
開發者ID:ReedKimble,項目名稱:corefx,代碼行數:1,代碼來源:Interop.Ssl.cs

示例7: SslCtxSetQuietShutdown

 internal static extern void SslCtxSetQuietShutdown(SafeSslContextHandle ctx);
開發者ID:ReedKimble,項目名稱:corefx,代碼行數:1,代碼來源:Interop.Ssl.cs

示例8: SslCtxCheckPrivateKey

 internal static extern int SslCtxCheckPrivateKey(SafeSslContextHandle ctx);
開發者ID:ReedKimble,項目名稱:corefx,代碼行數:1,代碼來源:Interop.Ssl.cs

示例9: SslCtxUsePrivateKey

 internal static extern int SslCtxUsePrivateKey(SafeSslContextHandle ctx, SafeEvpPKeyHandle keyPtr);
開發者ID:ReedKimble,項目名稱:corefx,代碼行數:1,代碼來源:Interop.Ssl.cs

示例10: SSL_CTX_set_cipher_list

 internal static extern int SSL_CTX_set_cipher_list(SafeSslContextHandle ctx, string policy);
開發者ID:bbologna,項目名稱:corefx,代碼行數:1,代碼來源:Interop.libssl.cs

示例11: SSL_new

 internal static extern SafeSslHandle SSL_new(SafeSslContextHandle ctx);
開發者ID:shrutigarg,項目名稱:corefx,代碼行數:1,代碼來源:Interop.libssl.cs

示例12: Create

        public static SafeSslHandle Create(SafeSslContextHandle context, bool isServer)
        {
            SafeBioHandle readBio = Interop.Crypto.CreateMemoryBio();
            SafeBioHandle writeBio = Interop.Crypto.CreateMemoryBio();
            SafeSslHandle handle = Interop.Ssl.SslCreate(context);
            if (readBio.IsInvalid || writeBio.IsInvalid || handle.IsInvalid)
            {
                readBio.Dispose();
                writeBio.Dispose();
                handle.Dispose(); // will make IsInvalid==true if it's not already
                return handle;
            }
            handle._isServer = isServer;

            // SslSetBio will transfer ownership of the BIO handles to the SSL context
            try
            {
                readBio.TransferOwnershipToParent(handle);
                writeBio.TransferOwnershipToParent(handle);
                handle._readBio = readBio;
                handle._writeBio = writeBio;
                Interop.Ssl.SslSetBio(handle, readBio, writeBio);
            }
            catch (Exception exc)
            {
                // The only way this should be able to happen without thread aborts is if we hit OOMs while
                // manipulating the safe handles, in which case we may leak the bio handles.
                Debug.Fail("Unexpected exception while transferring SafeBioHandle ownership to SafeSslHandle", exc.ToString());
                throw;
            }

            if (isServer)
            {
                Interop.Ssl.SslSetAcceptState(handle);
            }
            else
            {
                Interop.Ssl.SslSetConnectState(handle);
            }
            return handle;
        }
開發者ID:AndreGleichner,項目名稱:corefx,代碼行數:41,代碼來源:Interop.Ssl.cs

示例13: SSL_CTX_set_quiet_shutdown

 internal static extern void SSL_CTX_set_quiet_shutdown(SafeSslContextHandle ctx, int mode);
開發者ID:shrutigarg,項目名稱:corefx,代碼行數:1,代碼來源:Interop.libssl.cs

示例14: SSL_CTX_ctrl

 internal static extern long SSL_CTX_ctrl(SafeSslContextHandle ctx, int cmd, long larg, IntPtr parg);
開發者ID:shrutigarg,項目名稱:corefx,代碼行數:1,代碼來源:Interop.libssl.cs

示例15: SSL_CTX_check_private_key

 internal static extern int SSL_CTX_check_private_key(SafeSslContextHandle ctx);
開發者ID:shrutigarg,項目名稱:corefx,代碼行數:1,代碼來源:Interop.libssl.cs


注:本文中的Microsoft.Win32.SafeHandles.SafeSslContextHandle類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。