Token dostępu do Facebooka również wygląda podobnie „1249203702 | 2.h1MTNeLqcLqw __. 86400.129394400-605430316 | -WE1iH_CV-afTgyhDPc”
jeśli wyodrębnisz środkową część za pomocą | się podzielić
2.h1MTNeLqcLqw __. 86400.129394400-605430316
następnie podziel ponownie przez -
ostatnia część 605430316 to identyfikator użytkownika.
Oto kod C # służący do wyodrębniania identyfikatora użytkownika z tokenu dostępu:
public long ParseUserIdFromAccessToken(string accessToken)
{
Contract.Requires(!string.isNullOrEmpty(accessToken);
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;
}
OSTRZEŻENIE:
Struktura tokena dostępu nie jest udokumentowana i może nie zawsze pasować do powyższego wzorca. Używaj go na własne ryzyko.
Aktualizacja
Ze względu na zmiany na Facebooku. preferowana metoda pobierania identyfikatora użytkownika z zaszyfrowanego tokena dostępu jest następująca:
try
{
var fb = new FacebookClient(accessToken);
var result = (IDictionary<string, object>)fb.Get("/me?fields=id");
return (string)result["id"];
}
catch (FacebookOAuthException)
{
return null;
}