facebook登录按钮获取邮箱的方式
由于公司英语商城要做免注册登录,我就想到了facebook,按照官方的文档,一步一步做下去,心情很好,竟然没有坑,但是我高兴的太早了,上线测试了一下发现无法获取用户的邮箱与头像,那有什么用呢.
然后就是查官方,文化差异,那文档就不是写给你中国人看的,最后经过2个多小时的的折腾,终于搞出来了,直接上代码
(function(d, s, id) {
var js, fjs = d.getElementsByTagName(s)[0];
if (d.getElementById(id)) return;
js = d.createElement(s); js.id = id;
js.src = "https://connect.facebook.net/en_US/sdk.js";
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));
// Here we run a very simple test of the Graph API after login is
// successful. See statusChangeCallback() for when this call is made.
function testAPI() {
console.log('Welcome! Fetching your information.... ');
FB.api('/me?fields=name,picture,email', function(response) {
console.log(response);
document.getElementById('status').innerHTML =
'Thanks for logging in, ' +response.name+"<br>"+response.email+"<br>"+'<img src="'+ response.picture.data.url + '">';
});
}
关键是FB.api('/me?fields=name,picture,email', function(response) {
官方竟然没有给出这个M文档!!!!!
官方文档https://developers.facebook.com/docs/facebook-login/permissions/#reference-default
授予您的应用访问User对象的默认字段的权限,这些字段是人员公开个人资料的子集:
- id
- first_name
- last_name
- middle_name
- name
- name_format
- picture
- short_name