0

我有claims/Auth_token信息,看起来像

{
    "claims": null,
    "auth_token": "ABCDEFGHIJKLMNOP==",
    "refresh_token": null,
    "auth_token_expiration": "2012-09-04T06:59:13.1343331-04:00",
    "refresh_token_expiration": "2013-05-01T06:59:13.1343331-04:00",
    "token_type": "urn:Test1:Test2:grant-type:trusted_issuer"
}
url=www.testuri.com

使用它我需要创建一个实用程序,该实用程序使用上面提到的声明信息获取 uri 的访问令牌。

4

2 回答 2

4

你得到的信息是JSON

您可以使用 C# 中的 JavaScriptSerializer 类将 JSON 反序列化为对象。

首先,您必须构建一个代表 json 结构的 POCO 对象:

public class ResponseObj
{
    public string claims { get; set; }
    public string auth_token { get; set; }
    public string refresh_token { get; set; }
    public DateTime auth_token_expiration { get; set; }
    public DateTime refresh_token_expiration { get; set; }
    public string token_type { get; set; }
}

之后,您可以像这样反序列化它并使用结果来获取令牌:

string json = "your json string"
ResponseObj deserializedResult = new JavaScriptSerializer().Deserialize<ResponseObj>(json);

string token = deserializedResult.auth_token;

请注意,现在您可以像访问身份验证令牌一样访问响应中的所有属性。如果您想获得可以使用的声明字符串;

string claims = deserializedResult.claims;
于 2014-05-21T06:52:00.137 回答
2

这是一个 JSON 字符串

您需要创建一个具有属性的类(声明、auth_token、refresh_token...等)

然后反序列化这个 JSON 字符串,然后你就可以访问令牌了。

    public class TokenResponse
    {
     public string claims { get; set; }
     public string auth_token { get; set; }
     public string refresh_token { get; set; }
     public string auth_token_expiration { get; set; }
     public string refresh_token_expiration { get; set; }
     public string token_type { get; set; }
    }

现在反序列化 JSON:

    JavaScriptSerializer js = new JavaScriptSerializer();
    var token = js.Deserialize<TokenResponse>(decodedResponse);

现在使用令牌:

    string authToken=token.auth_token
于 2014-05-21T06:51:05.980 回答