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的访问令牌。

回答

1

这是一个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 
2

你所得到的信息是JSON

你可以反序列化JSON与JavaScriptSerializer对象在C#中的类。

首先,你必须建立代表您的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; 

请注意,现在您可以像auth令牌一样访问响应中的所有属性。 如果你想获得你可以使用的索赔字符串;

string claims = deserializedResult.claims;