DotNetOpenAuthを使用して独自のリソースサーバーを作成しています。すべてが機能し、トークンを正常に取得できます。ただし、現在、リソースサーバーを呼び出すクライアントの構築を開始しており、DotNetOpenAuthによって返される応答に小さな問題があります。DotNetOpenAuthがアクセストークンを表すJSON文字列を返すことを期待していました。これは実行されますが、小さな注意点があります。JSON文字列の前には16進数が付けられ、後置にはゼロが付けられます。
HTTP/1.1 200 OK
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Transfer-Encoding: chunked
Content-Type: application/json; charset=utf-8
Server: Microsoft-IIS/8.0
X-AspNetMvc-Version: 4.0
X-AspNet-Version: 4.0.30319
X-SourceFiles: =?UTF-8?B?RDpcUGVyc29vbmxpamtlIHByb2plY3RlblxpY2hlY2ttb3ZpZXMtZG90bmV0XHNyY1xXZWJBcGlcdG9rZW5zXA==?=
X-Powered-By: ASP.NET
Date: Mon, 04 Mar 2013 13:04:12 GMT
3d2
{"access_token":"gAAAADrFpM2DRiBdqVBPdEq_ISvdfZb6CaRMZr7vWcn2AuKGs2TXyNlzLaUX8xtLQfxFdbTYBIK-LF8cfEwvV8gUKC0lpcodb9OWm9sUmu_IIApmMPIBQDgT1LtkEjOsv_gQdmwN906Pd1KczI2O3Pt1DqzhL_Rpub9zJQmh6EKDp4_EJAEAAIAAAACTvB0tYmrRNExdGQhGBrHgYnlgt7Rw-ilB2wLScW1YgOHE6MOY0WrfKG9aFLUAcmADYSrX55n9mfC9NKDXJBARc5ev-hnWTnApw7yq51c1KwbKv7bxoEVzar8eAAFrJi_OBQjlcaN8IFfnryu1VK_C1o-U2gLgdnBZzFcCDhgNseRFjUCmYXssEvjUswg0Oy3c_F_IXpP85kL6QCYmpGwV1juTuiMwMuZOCbcPMAssM70JMi7Ai7zT7hxCCZ5SLgeyLjBqPX7bXnhRIO24mkZ9pN5pCzorjOX_8rqdrPwR6WkPy0tc69oyBTak8L6nJYWzxfuAVhZGEowHCx3KNWfG_R_w23N7Y3c9HoIfO6RSYpnfieGLKhxHxd1_jsczGtM","token_type":"bearer","expires_in":3600,"refresh_token":"q5NN!IAAAANCHUJ5tukpT_UzgkRGCTM4Oy1qgw8GP5wn8HDS2jN1isQAAAAFfLe6KZMht1mmbIbF6RihvMZvjrwtaoZRZbaavPbte9CtjLWB_isHOroLv669rq1PmTppmVyo1Om3HVvp2AC16SDe7l02POHIYbPs_Cox6kekHc74_8pLP8SAGcrXy1EzjAPKc_UksMTp8aqaAnrU3ulx2TYYrRMyYb6pW7awO6_aiHtLixrF6dVA1-6DWvKuCSeJW0oZCm45Op1-wht8qAWkK3B70C6dZU6dmsggleA","scope":"movie list user comment"}
0
公式の仕様(https://datatracker.ietf.org/doc/html/draft-ietf-oauth-v2-31#section-4.1.4)を見ると、プレフィックスやポストフィックスについては何も書かれていません。出力は正しいですか、それともこれはDotNetOpenAuthのバグですか?Content-length
ヘッダーがないという反応について私を驚かせたのは1つです。3d2
これにより、おそらく文字列は実際にはコンテンツの長さであると私は信じました。16進数の3d2は10進数で978であり、これは正確には3d2と0の間のJSON文字列の長さであるためです。
通常のContent-lengthヘッダーを返し、前置と後置を出力しないようにDotNetOpenAuthを構成する方法はありますか?
完了するために、次のコード(依存性注入を使用)を使用して、.NET4.0上のASP.NETMVC4アプリケーションで承認サーバーを実行します。
public sealed class TokensController : Controller
{
private readonly AuthorizationServer authorizationServer;
public TokensController(AuthorizationServer authorizationServer)
{
this.authorizationServer = authorizationServer;
}
public ActionResult Create()
{
var outgoingWebResponse = this.authorizationServer.HandleTokenRequest(this.Request);
var asActionResult = outgoingWebResponse.AsActionResult();
return asActionResult;
}
}