As exercise to understand OpenIDConnect, I am trying to authenticate in my web app with Google following this guide.
The problem is I cannot read the token that Google sends to my application>
var bytes = Convert.FromBase64String(codeEx.Id_token);
var token = Encoding.ASCII.GetString(bytes);
It fails in the first line saying: "The input is not a valid Base-64 string as it contains a non-base 64 character, more than two padding characters, or an illegal character among the padding characters."
The doc states: "An ID token is a cryptographically signed JSON object encoded in base 64. "
For obvious reasons I cannot put the token here. I have tried:
- The input is not a valid Base-64 string as it contains a non-base 64 character
- Add '=' until the length is multiple of 4.
- All together.
I get the code exchange response, and deserialize it with the NewtonSoft.Json library:
var http = new HttpClient(handler);
HttpResponseMessage result = await http.PostAsync("https://www.googleapis.com/oauth2/v3/token", postData);
var json = JObject.Parse(await result.Content.ReadAsStringAsync());
if (json.Property("error") != null)
throw new Exception(json.Property("error").Value.ToString() + ":" + json.Property("error_description").Value.ToString());
var codeEx = json.ToObject<CodeExchangeResponse>();
I don´t know if there is any potential issue with the encoding. I can see several ´-´and ´_´in the token.
Any idea about how to read the token?