淘宝Refrash_token签名错误的解决办法

最近在做淘宝相关应用,想要通过Refrash_token来延长SessionKey的授权时间,但是总是报406 sign error.

经过多次尝试和多方询问,方才知道原来淘宝给的.net SDK里面的签名方法(SignTopRequest)是不能用于Refrash_token的签名。

只好老老实实的按照官方例子,把JAVA的翻译成C#的。

 private string GetRefrashSign(string appkey, string sessionKey, string refrashToken, string secret)
{
Dictionary<string, string> signParams = new Dictionary<string, string>();
signParams.Add("appkey", appkey);
signParams.Add("refresh_token", refrashToken);
signParams.Add("sessionkey", sessionKey);
//return TopUtils.SignTopRequest(signParams, secret,true).ToUpper();
StringBuilder paramsString = new StringBuilder();
foreach (KeyValuePair<string, string> param in signParams)
{
paramsString.Append(param.Key);
paramsString.Append(param.Value);
}
paramsString.Append(secret);
return GetMd5String(paramsString.ToString()).ToUpper();
}
private string GetMd5String(string paramsString)
{
MD5 md5 = MD5.Create();
byte[] bytes = md5.ComputeHash(Encoding.UTF8.GetBytes(paramsString));
StringBuilder sb = new StringBuilder();
foreach (byte b in bytes)
sb.AppendFormat("{0:X2}", b);
return sb.ToString();
}
上一篇:通过镜像下载最新Android源码


下一篇:VLAN是什么