我使用Facebook的官方Android SDK,我在Facebook上的应用程序的管理员。
我读了默认情况下,应用程序在沙盒模式和任何人,除非管理员和开发人员可以访问它。 我使用它在我的Android应用程序添加Facebook的登录功能。 不过,我加了我的朋友,谁是我为开发人员在开发应用程序,但他们不能通过Facebook登录与应用程序的帐户凭据。 我禁用了应用程序的沙盒模式从Facebook的应用程序设置,还是他们不能访问登录功能。 一旦他们点击Facebook登录按钮,它们被重定向到相同的活动没有任何情况发生,而在我的情况,我成功登录和应用程序正常进行。
是否有任何额外的设置,我需要为了把它公开呢?
谢谢 :)
Session.openActiveSession(this, true, new Session.StatusCallback() {
// callback when session changes state
@Override
public void call(Session session, SessionState state,
Exception exception) {
if (session.isOpened()) {
// make request to the /me API
List<String> permissions = session.getPermissions();
if (!isSubsetOf(PERMISSIONS, permissions)) {
pendingPublishReauthorization = true;
Session.NewPermissionsRequest newPermissionsRequest = new Session.NewPermissionsRequest(
RegisterActivity.this, PERMISSIONS);
session.requestNewReadPermissions(newPermissionsRequest);
return;
}
Request.executeMeRequestAsync(session,
new Request.GraphUserCallback() {
// callback after Graph API response with
// user object
@Override
public void onCompleted(GraphUser user,
Response response) {
if (user == null) {
Toast.makeText(
RegisterActivity.this
.getApplicationContext(),
"Facebook Error",
Toast.LENGTH_LONG).show();
} else {
Toast.makeText(
RegisterActivity.this
.getApplicationContext(),
user.getName()
+ " Logged in Successfully.",
Toast.LENGTH_LONG).show();
GraphUser abc = user;
id = user.getId();
name = user.getName();
gender = user.getProperty("gender")
.toString();
editname.setText(name);
username.setText(user.getUsername());
JSONObject jo = user
.getInnerJSONObject();
Log.d("Details", jo.toString());
try {
emailid.setText(user
.getProperty("email")
.toString());
} catch (Exception e1) {
// TODO Auto-generated catch
// block
e1.printStackTrace();
}
try {
location = user.getLocation()
.getProperty("name")
.toString();
} catch (Exception e) {
e.printStackTrace();
}
}
return;
}
});
}
}
});
把onActivityResult方法
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
Session.getActiveSession().onActivityResult(this, requestCode,
resultCode, data);
}
isSubsetoff()方法
private boolean isSubsetOf(Collection<String> subset,
Collection<String> superset) {
for (String string : subset) {
if (!superset.contains(string)) {
return false;
}
}
return true;
}
和权限根据自己的需要
private static final List<String> PERMISSIONS = Arrays.asList("email",
"user_about_me", "user_location", "user_checkins");