-
-
Save xeoncross/4260755 to your computer and use it in GitHub Desktop.
Working PHP example of uploading a photo with V2 api
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| <?php | |
| #Requires PHP 5.3.0 | |
| define("CONSUMER_KEY", "consumer_key"); | |
| define("CONSUMER_SECRET", "consumer_secret"); | |
| define("OAUTH_TOKEN", "access_token"); | |
| define("OAUTH_SECRET", "access_secret"); | |
| function oauth_gen($method, $url, $iparams, &$headers) { | |
| $iparams['oauth_consumer_key'] = CONSUMER_KEY; | |
| $iparams['oauth_nonce'] = strval(time()); | |
| $iparams['oauth_signature_method'] = 'HMAC-SHA1'; | |
| $iparams['oauth_timestamp'] = strval(time()); | |
| $iparams['oauth_token'] = OAUTH_TOKEN; | |
| $iparams['oauth_version'] = '1.0'; | |
| $iparams['oauth_signature'] = oauth_sig($method, $url, $iparams); | |
| print $iparams['oauth_signature']; | |
| $oauth_header = array(); | |
| foreach($iparams as $key => $value) { | |
| if (strpos($key, "oauth") !== false) { | |
| $oauth_header []= $key ."=".$value; | |
| } | |
| } | |
| $oauth_header = "OAuth ". implode(",", $oauth_header); | |
| $headers["Authorization"] = $oauth_header; | |
| } | |
| function oauth_sig($method, $uri, $params) { | |
| $parts []= $method; | |
| $parts []= rawurlencode($uri); | |
| $iparams = array(); | |
| ksort($params); | |
| foreach($params as $key => $data) { | |
| if(is_array($data)) { | |
| $count = 0; | |
| foreach($data as $val) { | |
| $n = $key . "[". $count . "]"; | |
| $iparams []= $n . "=" . rawurlencode($val); | |
| $count++; | |
| } | |
| } else { | |
| $iparams[]= rawurlencode($key) . "=" .rawurlencode($data); | |
| } | |
| } | |
| $parts []= rawurlencode(implode("&", $iparams)); | |
| $sig = implode("&", $parts); | |
| return base64_encode(hash_hmac('sha1', $sig, CONSUMER_SECRET."&". OAUTH_SECRET, true)); | |
| } | |
| $headers = array("Host" => "http://api.tumblr.com/", "Content-type" => "application/x-www-form-urlencoded", "Expect" => ""); | |
| $params = array("data" => array(file_get_contents("/path/to/file"), file_get_contents("/path/to/file")), | |
| "type" => "photo"); | |
| $blogname = "testing.tumblr.com"; | |
| oauth_gen("POST", "http://api.tumblr.com/v2/blog/$blogname/post", $params, $headers); | |
| $ch = curl_init(); | |
| curl_setopt($ch, CURLOPT_USERAGENT, "PHP Uploader Tumblr v1.0"); | |
| curl_setopt($ch, CURLOPT_URL, "http://api.tumblr.com/v2/blog/$blogname/post"); | |
| curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1 ); | |
| curl_setopt($ch, CURLOPT_HTTPHEADER, array( | |
| "Authorization: " . $headers['Authorization'], | |
| "Content-type: " . $headers["Content-type"], | |
| "Expect: ") | |
| ); | |
| $params = http_build_query($params); | |
| curl_setopt($ch, CURLOPT_POST, 1); | |
| curl_setopt($ch, CURLOPT_POSTFIELDS, $params); | |
| $response = curl_exec($ch); | |
| print $response; | |
| ?> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Hi, I've noticed that when calling the oauth_gen, the entire $params array is passed to the function, in the case of a large photoset (let's say 5 files of about 1.5Mb each), the result array is something that will be around 15Mb or more.
talking with the tumblr api helpdesk, they told me that:
the parameters array aren't to be passed for the oauth signature, but,
modifing the code result inot 401 errors, I'm pushing the conversation here:
http://stackoverflow.com/questions/36747697/oauth-signature-creation-issue-with-php
if you please take a look there because there is something weird. Thanks.