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


PHP resource::enableCrypto方法代碼示例

本文整理匯總了PHP中resource::enableCrypto方法的典型用法代碼示例。如果您正苦於以下問題:PHP resource::enableCrypto方法的具體用法?PHP resource::enableCrypto怎麽用?PHP resource::enableCrypto使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在resource的用法示例。


在下文中一共展示了resource::enableCrypto方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: auth

 /**
  * Attempt to do SMTP authentication.
  *
  * @param string $uid    The userid to authenticate as.
  * @param string $pwd    The password to authenticate with.
  * @param string $method The requested authentication method.  If none is
  *                       specified, the best supported method will be used.
  * @param bool   $tls    Flag indicating whether or not TLS should be attempted.
  * @param string $authz  An optional authorization identifier.  If specified, this
  *                       identifier will be used as the authorization proxy.
  *
  * @return mixed Returns a PEAR_Error with an error message on any
  *               kind of failure, or true on success.
  * @since 1.0
  */
 public function auth($uid, $pwd, $method = '', $tls = true, $authz = '')
 {
     /* We can only attempt a TLS connection if one has been requested,
      * we're running PHP 5.1.0 or later, have access to the OpenSSL
      * extension, are connected to an SMTP server which supports the
      * STARTTLS extension, and aren't already connected over a secure
      * (SSL) socket connection. */
     if ($tls && version_compare(PHP_VERSION, '5.1.0', '>=') && extension_loaded('openssl') && isset($this->esmtp['STARTTLS']) && strncasecmp($this->host, 'ssl://', 6) !== 0) {
         /* Start the TLS connection attempt. */
         if (PEAR::isError($result = $this->put('STARTTLS'))) {
             return $result;
         }
         if (PEAR::isError($result = $this->parseResponse(220))) {
             return $result;
         }
         if (PEAR::isError($result = $this->socket->enableCrypto(true, STREAM_CRYPTO_METHOD_TLS_CLIENT))) {
             return $result;
         } elseif ($result !== true) {
             return PEAR::raiseError('STARTTLS failed');
         }
         /* Send EHLO again to recieve the AUTH string from the
          * SMTP server. */
         $this->negotiate();
     }
     if (empty($this->esmtp['AUTH'])) {
         return PEAR::raiseError('SMTP server does not support authentication');
     }
     /* If no method has been specified, get the name of the best
      * supported method advertised by the SMTP server. */
     if (empty($method)) {
         if (PEAR::isError($method = $this->getBestAuthMethod())) {
             /* Return the PEAR_Error object from _getBestAuthMethod(). */
             return $method;
         }
     } else {
         $method = strtoupper($method);
         if (!array_key_exists($method, $this->auth_methods)) {
             return PEAR::raiseError("{$method} is not a supported authentication method");
         }
     }
     if (!isset($this->auth_methods[$method])) {
         return PEAR::raiseError("{$method} is not a supported authentication method");
     }
     if (!is_callable($this->auth_methods[$method], false)) {
         return PEAR::raiseError("{$method} authentication method cannot be called");
     }
     if (is_array($this->auth_methods[$method])) {
         list($object, $method) = $this->auth_methods[$method];
         $result = $object->{$method}($uid, $pwd, $authz, $this);
     } else {
         $func = $this->auth_methods[$method];
         $result = $func($uid, $pwd, $authz, $this);
     }
     /* If an error was encountered, return the PEAR_Error object. */
     if (PEAR::isError($result)) {
         return $result;
     }
     return true;
 }
開發者ID:remicollet,項目名稱:Net_SMTP,代碼行數:74,代碼來源:SMTP.php

示例2: cmdConnect

 /**
  * Attempt to connect to the IMAP server.
  *
  * @param string $host Hostname of the IMAP server
  * @param int    $port Port of the IMAP server (default = 143)
  *
  * @return mixed Returns a PEAR_Error with an error message on any
  *               kind of failure, or true on success.
  * @access public
  * @since  1.0
  */
 function cmdConnect($host = 'localhost', $port = 143)
 {
     if ($this->_connected) {
         return new PEAR_Error('already connected, logout first!');
     }
     if (PEAR::isError($error = $this->_socket->connect($host, $port, null, $this->_timeout, $this->_streamContextOptions))) {
         return $error;
     }
     if ($port == 993) {
         if (!$this->_socket->enableCrypto(true, STREAM_CRYPTO_METHOD_TLS_CLIENT)) {
             return new PEAR_Error('Failed to set crypto');
         }
     }
     if (PEAR::isError($this->_getRawResponse())) {
         return new PEAR_Error('unable to open socket');
     }
     $this->_connected = true;
     return true;
 }
開發者ID:Dulciane,項目名稱:jaws,代碼行數:30,代碼來源:IMAPProtocol.php

示例3: auth

 /**
  * Attempt to do SMTP authentication.
  *
  * @param string The userid to authenticate as.
  * @param string The password to authenticate with.
  * @param string The requested authentication method.  If none is
  *               specified, the best supported method will be used.
  * @param bool   Flag indicating whether or not TLS should be attempted.
  * @param string An optional authorization identifier.  If specified, this
  *               identifier will be used as the authorization proxy.
  *
  * @return mixed Returns a PEAR_Error with an error message on any
  *               kind of failure, or true on success.
  * @access public
  * @since  1.0
  */
 function auth($uid, $pwd, $method = '', $tls = true, $authz = '')
 {
     /* We can only attempt a TLS connection if one has been requested,
      * we're running PHP 5.1.0 or later, have access to the OpenSSL 
      * extension, are connected to an SMTP server which supports the 
      * STARTTLS extension, and aren't already connected over a secure 
      * (SSL) socket connection. */
     if ($tls && version_compare(PHP_VERSION, '5.1.0', '>=') && extension_loaded('openssl') && isset($this->_esmtp['STARTTLS']) && strncasecmp($this->host, 'ssl://', 6) !== 0) {
         /* Start the TLS connection attempt. */
         if (PEAR::isError($result = $this->_put('STARTTLS'))) {
             return $result;
         }
         if (PEAR::isError($result = $this->_parseResponse(220))) {
             return $result;
         }
         if (PEAR::isError($result = $this->_socket->enableCrypto(true, STREAM_CRYPTO_METHOD_TLS_CLIENT))) {
             return $result;
         } elseif ($result !== true) {
             return PEAR::raiseError('STARTTLS failed');
         }
         /* Send EHLO again to recieve the AUTH string from the
          * SMTP server. */
         $this->_negotiate();
     }
     if (empty($this->_esmtp['AUTH'])) {
         return PEAR::raiseError('SMTP server does not support authentication');
     }
     /* If no method has been specified, get the name of the best
      * supported method advertised by the SMTP server. */
     if (empty($method)) {
         if (PEAR::isError($method = $this->_getBestAuthMethod())) {
             /* Return the PEAR_Error object from _getBestAuthMethod(). */
             return $method;
         }
     } else {
         $method = strtoupper($method);
         if (!in_array($method, $this->auth_methods)) {
             return PEAR::raiseError("{$method} is not a supported authentication method");
         }
     }
     switch ($method) {
         case 'DIGEST-MD5':
             $result = $this->_authDigest_MD5($uid, $pwd, $authz);
             break;
         case 'CRAM-MD5':
             $result = $this->_authCRAM_MD5($uid, $pwd);
             break;
         case 'LOGIN':
             $result = $this->_authLogin($uid, $pwd);
             break;
         case 'PLAIN':
             $result = $this->_authPlain($uid, $pwd, $authz);
             break;
         default:
             $result = PEAR::raiseError("{$method} is not a supported authentication method");
             break;
     }
     /* If an error was encountered, return the PEAR_Error object. */
     if (PEAR::isError($result)) {
         return $result;
     }
     return true;
 }
開發者ID:dev-lav,項目名稱:htdocs,代碼行數:79,代碼來源:SMTP.php

示例4: auth

 /**
  * Attempt to do SMTP authentication.
  *
  * @param string The userid to authenticate as.
  * @param string The password to authenticate with.
  * @param string The requested authentication method.  If none is
  *               specified, the best supported method will be used.
  *
  * @return mixed Returns a PEAR_Error with an error message on any
  *               kind of failure, or true on success.
  * @access public
  * @since  1.0
  */
 function auth($uid, $pwd, $method = '')
 {
     if (version_compare(PHP_VERSION, '5.1.0', '>=') && (isset($this->_esmtp['STARTTLS']) || $this->_esmtp['STARTTLS'] == true)) {
         if (PEAR::isError($result = $this->_put('STARTTLS'))) {
             return $result;
         }
         if (PEAR::isError($result = $this->_parseResponse(220))) {
             return $result;
         }
         if (PEAR::isError($result = $this->_socket->enableCrypto(true, STREAM_CRYPTO_METHOD_TLS_CLIENT))) {
             return $result;
         } elseif ($result !== true) {
             return PEAR::raiseError('STARTTLS failed');
         }
         /* Send EHLO again to recieve the AUTH string from the
          * SMTP server. */
         $this->_negotiate();
     }
     if (empty($this->_esmtp['AUTH'])) {
         return PEAR::raiseError('SMTP server does not support authentication');
     }
     /* If no method has been specified, get the name of the best
      * supported method advertised by the SMTP server. */
     if (empty($method)) {
         if (PEAR::isError($method = $this->_getBestAuthMethod())) {
             /* Return the PEAR_Error object from _getBestAuthMethod(). */
             return $method;
         }
     } else {
         $method = strtoupper($method);
         if (!in_array($method, $this->auth_methods)) {
             return PEAR::raiseError("{$method} is not a supported authentication method");
         }
     }
     switch ($method) {
         case 'DIGEST-MD5':
             $result = $this->_authDigest_MD5($uid, $pwd);
             break;
         case 'CRAM-MD5':
             $result = $this->_authCRAM_MD5($uid, $pwd);
             break;
         case 'LOGIN':
             $result = $this->_authLogin($uid, $pwd);
             break;
         case 'PLAIN':
             $result = $this->_authPlain($uid, $pwd);
             break;
         default:
             $result = PEAR::raiseError("{$method} is not a supported authentication method");
             break;
     }
     /* If an error was encountered, return the PEAR_Error object. */
     if (PEAR::isError($result)) {
         return $result;
     }
     return true;
 }
開發者ID:KingsleyGU,項目名稱:OSTicket-Reloaded,代碼行數:70,代碼來源:SMTP.php


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