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


PHP HttpSocket::_buildUri方法代碼示例

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


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

示例1: buildUri

 /**
  * Convenience method for testing protected method
  *
  * @param array $uri A $uri array, or uses $this->config if left empty
  * @param string $uriTemplate The Uri template/format to use
  * @return string A fully qualified URL formatted according to $uriTemplate
  */
 public function buildUri($uri = array(), $uriTemplate = '%scheme://%user:%pass@%host:%port/%path?%query#%fragment')
 {
     return parent::_buildUri($uri, $uriTemplate);
 }
開發者ID:pushpendraraj,項目名稱:tigzie,代碼行數:11,代碼來源:HttpSocketTest.php

示例2: request

 /**
  * Overrides HttpSocket::request() to handle cases where
  * $request['auth']['method'] is 'OAuth'.
  *
  * @param array $request As required by HttpSocket::request(). NOTE ONLY
  *    THE ARRAY TYPE OF REQUEST IS SUPPORTED
  * @return array
  */
 function request($request = array())
 {
     // If the request does not need OAuth Authorization header, let the parent
     // deal with it.
     if (!isset($request['auth']['method']) || $request['auth']['method'] != 'OAuth') {
         return parent::request($request);
     }
     $request['auth'] = array_merge($this->defaults, $request['auth']);
     // Nonce, or number used once is used to distinguish between different
     // requests to the OAuth provider
     if (!isset($request['auth']['oauth_nonce'])) {
         $request['auth']['oauth_nonce'] = md5(uniqid(rand(), true));
     }
     if (!isset($request['auth']['oauth_timestamp'])) {
         $request['auth']['oauth_timestamp'] = time();
     }
     // Now starts the process of signing the request. The signature is a hash of
     // a signature base string with the secret keys. The signature base string
     // is made up of the request http verb, the request uri and the request
     // params, and the secret keys are the consumer secret (for your
     // application) and the access token secret generated for the user by the
     // provider, e.g. twitter, when the user authorizes your app to access their
     // details.
     // Building the request uri, note we don't include the query string or
     // fragment. Standard ports must not be included but non standard ones must.
     $uriFormat = '%scheme://%host';
     if (isset($request['uri']['port']) && !in_array($request['uri']['port'], array(80, 443))) {
         $uriFormat .= ':' . $request['uri']['port'];
     }
     $uriFormat .= '/%path';
     $requestUrl = parent::_buildUri($request['uri'], $uriFormat);
     // The realm oauth_ param is optional, but you can include it and use the
     // request uri as the value if it's not already set
     if (!isset($request['auth']['realm'])) {
         $request['auth']['realm'] = $requestUrl;
     }
     // OAuth reference states that the request params, i.e. oauth_ params, body
     // params and query string params need to be normalised, i.e. combined in a
     // single string, separated by '&' in the format name=value. But they also
     // need to be sorted by key, then by value. You can't just merge the auth,
     // body and query arrays together then do a ksort because there may be
     // parameters with the same name. Instead we've got to get them into an
     // array of array('name' => '<name>', 'value' => '<value>') elements, then
     // sort those elements.
     // Let's start with the auth params - however, we shouldn't include the auth
     // method (OAuth), and OAuth reference says not to include the realm or the
     // consumer or token secrets
     $requestParams = $this->assocToNumericNameValue(array_diff_key($request['auth'], array_flip(array('realm', 'method', 'oauth_consumer_secret', 'oauth_token_secret'))));
     // Next add the body params.
     if (isset($request['body'])) {
         $requestParams = array_merge($requestParams, $this->assocToNumericNameValue($request['body']));
     }
     // Finally the query params
     if (isset($request['uri']['query'])) {
         $requestParams = array_merge($requestParams, $this->assocToNumericNameValue($request['uri']['query']));
     }
     // Now we can sort them by name then value
     usort($requestParams, array($this, 'sortByNameThenByValue'));
     // Now we concatenate them together in name=value pairs separated by &
     $normalisedRequestParams = '';
     foreach ($requestParams as $k => $requestParam) {
         if ($k) {
             $normalisedRequestParams .= '&';
         }
         $normalisedRequestParams .= $requestParam['name'] . '=' . rawurlencode(utf8_encode($requestParam['value']));
     }
     // The signature base string consists of the request method (uppercased) and
     // concatenated with the request URL and normalised request parameters
     // string, both encoded, and separated by &
     $signatureBaseString = strtoupper($request['method']) . '&' . rawurlencode(utf8_encode($requestUrl)) . '&' . rawurlencode(utf8_encode($normalisedRequestParams));
     // The signature base string is hashed with a key which is the consumer
     // secret (assigned to your application by the provider) and the token
     // secret (also known as the access token secret, if you've got it yet),
     // both encoded and separated by an &
     $key = '';
     if (isset($request['auth']['oauth_consumer_secret'])) {
         $key .= rawurlencode(utf8_encode($request['auth']['oauth_consumer_secret']));
     }
     $key .= '&';
     if (isset($request['auth']['oauth_token_secret'])) {
         $key .= rawurlencode(utf8_encode($request['auth']['oauth_token_secret']));
     }
     // Finally construct the signature according to the value of the
     // oauth_signature_method auth param in the request array.
     switch ($request['auth']['oauth_signature_method']) {
         case 'HMAC-SHA1':
             $request['auth']['oauth_signature'] = base64_encode(hash_hmac('sha1', $signatureBaseString, $key, true));
             break;
         default:
             // @todo implement the other 2 hashing methods
             break;
     }
//.........這裏部分代碼省略.........
開發者ID:studdr,項目名稱:cakephp-extras,代碼行數:101,代碼來源:http_socket_oauth.php


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