我正试图重新询问Facebook拒绝的权限。
根据facebook开发人员的说法,一旦有人拒绝了许可,登录对话框就不会重新询问他们,除非你明确告诉对话你再次要求拒绝许可。
您可以在登录时添加auth_type=rerequest
参数。
我做了这个,但是没有工作
var auth = new OAuth2Authenticator(
clientId: "my app id", // your OAuth2 client id
scope: "email", // the scopes for the particular API you're accessing, delimited by "+" symbols
authorizeUrl: new Uri("https://m.facebook.com/dialog/oauth/"),
redirectUrl: new Uri("http://www.facebook.com/connect/login_success.html"));
progressDialog.Show();
auth.Completed += async (sender, eventArgs) =>
{
if (eventArgs.IsAuthenticated)
{
var accessToken = eventArgs.Account.Properties["access_token"].ToString();
var expiresIn = Convert.ToDouble(eventArgs.Account.Properties["expires_in"]);
var expiryDate = DateTime.Now + TimeSpan.FromSeconds(expiresIn);
IDictionary<string, string> hashRequest = new Dictionary<string, string>();
hashRequest.Add("auth_type", "rerequest");
var request = new OAuth2Request("GET", new Uri("https://graph.facebook.com/me?fields=education,email,location,name"),hashRequest, eventArgs.Account);
var response = await request.GetResponseAsync();
var obj = JObject.Parse(response.GetResponseText()); ...
答案 0 :(得分:0)
我解决了将一些属性附加到html请求的问题。
var auth = new OAuth2Authenticator (
clientId: "myappid", // your OAuth2 client id
scope: "email", // the scopes for the particular API you're accessing, delimited by "+" symbols
authorizeUrl: new Uri ("https://m.facebook.com/dialog/oauth?auth_type=rerequest&client_id=myappid&" +
"redirect_uri=http://www.facebook.com/connect/login_success.html&scope=email/"),
redirectUrl: new Uri ("http://www.facebook.com/connect/login_success.html"));