Le jeton d'accès Facebook est également similaire "1249203702 | 2.h1MTNeLqcLqw __. 86400.129394400-605430316 | -WE1iH_CV-afTgyhDPc"
si vous extrayez la partie médiane en utilisant | pour diviser vous obtenez
2.h1MTNeLqcLqw __. 86400.129394400-605430316
puis divisé à nouveau par -
la dernière partie 605430316 est l'identifiant de l'utilisateur.
Voici le code C # pour extraire l'ID utilisateur du jeton d'accès:
public long ParseUserIdFromAccessToken(string accessToken)
{
Contract.Requires(!string.isNullOrEmpty(accessToken);
/*
* access_token:
* 1249203702|2.h1MTNeLqcLqw__.86400.129394400-605430316|-WE1iH_CV-afTgyhDPc
* |_______|
* |
* user id
*/
long userId = 0;
var accessTokenParts = accessToken.Split('|');
if (accessTokenParts.Length == 3)
{
var idPart = accessTokenParts[1];
if (!string.IsNullOrEmpty(idPart))
{
var index = idPart.LastIndexOf('-');
if (index >= 0)
{
string id = idPart.Substring(index + 1);
if (!string.IsNullOrEmpty(id))
{
return id;
}
}
}
}
return null;
}
AVERTISSEMENT:
la structure du jeton d'accès n'est pas documentée et peut ne pas toujours correspondre au modèle ci-dessus. Utilisez à vos risques et périls.
Mise
à jour en raison de changements dans Facebook. la méthode préférée pour obtenir l'ID utilisateur du jeton d'accès chiffré est la suivante:
try
{
var fb = new FacebookClient(accessToken);
var result = (IDictionary<string, object>)fb.Get("/me?fields=id");
return (string)result["id"];
}
catch (FacebookOAuthException)
{
return null;
}