I need to automatically find & download profile picture for user knowing his email address only. Originally, I focused on Facebook considering the amount of people actively using it. However, there seem to be no direct support from their API anymore.
There was similar question here: How to get a facebook user id from the login email address which is quite outdated and current answers there are "it's deprecated" / "it's not possible"... EDIT: I've found even better question: Find Facebook user (url to profile page) by known email address (where it is actually explained why and since when this feature isn't supported)
What makes me think that this should be possible is that Spokeo is somehow doing it: http://www.spokeo.com/email-search/search?e=beb090303%40hotmail.com
There are some services / APIs offering this kind of feature:
Clearbit
Pipl
...but I haven't found anything free.
If there is some workaround or different approach than using Facebook's API to achieve this, I would like to know. If Facebook is really completely hopeless here, then combination of these: Google+, Linkedin and/or Gravatar could do.
Once you have Facebook's username or user ID, it's easy to build URL to download the picture. So I was trying to look for Facebook's user IDs using emails with the /search
Graph API:https://graph.facebook.com/[email protected]&type=user&access_token=TOKEN
which unfortunatelly always ends with "A user access token is required to request this resource."
Using FB PHP API + FB App ID & SecretI've also tried this: at first I retrieve access_token
using app ID and secret and then I'm trying to use it as a part of /search
request with curl
:
function post_query_url($url, $data) { $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_HEADER, 0); curl_setopt($ch, CURLOPT_POST, 1); curl_setopt($ch, CURLOPT_POSTFIELDS, $data); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0); $res = curl_exec($ch); curl_close($ch); return $res; } function get_query_url($url) { $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_HEADER, 0); curl_setopt($ch, CURLOPT_POST, 0); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0); $ret = curl_exec($ch); curl_close($ch); return $ret; } function get_retrieve_app_access_token($app_id, $secret) { $url = 'https://graph.facebook.com/oauth/access_token?client_id='.$app_id.'&client_secret='.$secret.'&grant_type=client_credentials'; $res = get_query_url($url); if (!empty($res)) { $tokens = explode('=', $res); if (count($tokens) == 2) return $tokens[1]; } return null; } function post_retrieve_app_access_token($app_id, $secret) { $url = 'https://graph.facebook.com/oauth/access_token'; $data = 'client_id='.$app_id.'&client_secret='.$secret.'&grant_type=client_credentials'; $res = post_query_url($url, $data); if (!empty($res)) { $tokens = explode('=', $res); if (count($tokens) == 2) return $tokens[1]; } return null; } function get_id_from_email($email, $accessToken) { $url = 'https://graph.facebook.com/search?q='.urlencode($email).'&type=user&access_token='.$accessToken; $res = get_query_url($url); if (!empty($res)) { return $res; } return null; } echo 'Retrieving token...<br>'; $token = post_retrieve_app_access_token('MY_APP_ID', 'SECRET'); echo 'Retrieved token: ' . $token . '<br>'; echo 'Retrieving user ID...<br>'; $id = get_id_from_email('[email protected]', $token); echo 'Retrieved ID: ' . $id . '<br>';
outputs something like:
Retrieving token... Retrieved token: 367458621954635|DHfdjCnvO243Hbe1AFE3fhyhrtg Retrieving user ID... Retrieved ID: {"error":{"message":"A user access token is required to request this resource.","type":"OAuthException","code":102}}
Since it's asking for "user access token", I've also tried to go to Facebook's Graph Explorer: https://developers.facebook.com/tools/explorer/ let it generate access token for me and queried: [email protected]&type=user&debug=all
That one ends with:
{ "error": { "message": "(#200) Must have a valid access_token to access this endpoint", "type": "OAuthException", "code": 200 } }
...so Facebook seems kinda hopeless here.
That's exactly why Gravatar exists and why people use Gravatar, users know which public profile image they bind to which e-mail address and they know where to change it.
Your app can have the possibility for users to upload their own profile image and fallback to Gravatar.
If you just try to extract an image from Facebook or Google+, it might freak your users out and it will also be harder for them to know where your service got the profile image from.
Using Gravatar in PHP it is as simple as this:
<?php $email = "[email protected]"; $default = ""; // absolute url to default image goes here or leave empty for default gravatar image $size = 200; $grav_url = "http://www.gravatar.com/avatar/" . md5(strtolower(trim($email))) . "?d=" . urlencode($default) . "&s=" . $size; header("content-type: image/jpeg"); echo file_get_contents($grav_url); ?>
Apart from that, you can also use Facebook and/or Google+ as external login providers where users can grant your application access to their profile information.
There was a bug: Can't search for user by email after July 2013 Breaking Changes that has been closed as "By Design" with official response:
"The ability to pass in an e-mail address into the "user" search type was removed on July 10, 2013. This search type only returns results that match a user's name (including alternate name)" ~ Joseph Tuấn Anh Phan (Facebook Team)
so probably no direct support from Graph API.
I've tried Graph API Explorer where you can try to play with some FQL too (just need to select version 2.0 as newer versions are not supported anymore), unfortunately query like:
SELECT uid, name FROM user where email = '[email protected]'
gives:
"error": { "message": "(#604) Your statement is not indexable. The WHERE clause must contain an indexable column. Such columns are marked with * in the tables linked from http://developers.facebook.com/docs/reference/fql ", "type": "OAuthException", "code": 604 }
and reference for table user shows that only uid
and third_party_id
can be used in WHERE
.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With