/** * 发送请求的具体类 * * @return string */ function oAuthRequest($url, $method, $parameters, $multi = false) { $RexChar = '/request_token|access_token/i'; //boss上报,很重要,不能丢失 if (strrpos($url, 'http://') !== 0 && strrpos($url, 'https://') !== 0) { $url = "http://{$this->host}/{$url}.{$this->format}"; } $request = Core_Open_OAuthRequest::from_consumer_and_token($this->consumer, $this->token, $method, $url, $parameters); $request->sign_request($this->sha1_method, $this->consumer, $this->token); switch ($method) { case 'GET': return $this->http($request->to_url(), 'GET'); default: return $this->http($request->get_normalized_http_url(), $method, $request->to_postdata($multi), $multi); } }
/** * pretty much a helper function to set up the request */ public static function from_consumer_and_token($consumer, $token, $http_method, $http_url, $parameters = NULL) { @$parameters or $parameters = array(); $defaults = array("oauth_version" => Core_Open_OAuthRequest::$version, "oauth_nonce" => Core_Open_OAuthRequest::generate_nonce(), "oauth_timestamp" => Core_Open_OAuthRequest::generate_timestamp(), "oauth_consumer_key" => $consumer->key); if ($token) { $defaults['oauth_token'] = $token->key; } $parameters = array_merge($defaults, $parameters); //unset($parameters['pic']); return new Core_Open_OAuthRequest($http_method, $http_url, $parameters); }