ユーザーのカレンダーにアクセスするための認証コードを Google から取得したので、これをアクセス トークンと交換しようとしています。彼ら自身のドキュメントによると:
実際のリクエストは次のようになります。
POST /o/oauth2/token HTTP/1.1 Host: accounts.google.com Content-Type: application/x-www-form-urlencoded code=4/v6xr77ewYqhvHSyW6UJ1w7jKwAzu& client_id=8819981768.apps.googleusercontent.com& client_secret={client_secret}& redirect_uri=https://oauth2-login-demo.appspot.com/code& grant_type=authorization_code
これにアクセスする私の試みは次のとおりです(C#):
string url = "https://accounts.google.com/o/oauth2/token";
WebRequest request = HttpWebRequest.Create(url);
request.Method = "POST";
request.ContentType = "application/x-www-form-urlencoded";
string body = "code=<the_code_I_received>&\r\n"
+ "client_id=<my_client_id>&\r\n"
+ "client_secret=<my_client_secret>&\r\n"
+ "redirect_uri=http://localhost:4300\r\n"
+ "grant_type=authorization_code&\r\n"
;
byte[] bodyBytes = Encoding.ASCII.GetBytes(body);
request.ContentLength = bodyBytes.Length ;
Stream bodyStream = request.GetRequestStream();
bodyStream.Write(bodyBytes, 0, bodyBytes.Length);
bodyStream.Close();
try
{
request.GetResponse();
「http://localhost:4300」は、元のリクエストに入力したものとまったく同じです (そのポートで Web サーバーとしてリッスンしてコードを取得したため、有効でした) が、「http: //localhost' 念のため。
プロキシをnullに設定する(変更なし)、Acceptを変更する(そのヘッダーをWebリクエストに追加することは許可されていませんでした)など、いくつかの提案を試みました。
いずれの場合も、HTTP 400 - 不正なリクエストが返されます (try / catch が発生し、それを示す例外が発生します)。
/token の後にスラッシュを付けると (何でも試してみます!)、500 内部サーバー エラーが発生しました。
私が間違っていることは何か分かりますか?