最近在做淘宝相关应用,想要通过Refrash_token来延长SessionKey的授权时间,但是总是报406 sign error.
经过多次尝试和多方询问,方才知道原来淘宝给的.net SDK里面的签名方法(SignTopRequest)是不能用于Refrash_token的签名。
只好老老实实的按照官方例子,把JAVA的翻译成C#的。

1 private string GetRefrashSign(string appkey, string sessionKey, string refrashToken, string secret) 2 { 3 Dictionary<string, string> signParams = new Dictionary<string, string>(); 4 signParams.Add("appkey", appkey); 5 signParams.Add("refresh_token", refrashToken); 6 signParams.Add("sessionkey", sessionKey); 7 //return TopUtils.SignTopRequest(signParams, secret,true).ToUpper(); 8 StringBuilder paramsString = new StringBuilder(); 9 foreach (KeyValuePair<string, string> param in signParams) 10 { 11 paramsString.Append(param.Key); 12 paramsString.Append(param.Value); 13 } 14 paramsString.Append(secret); 15 return GetMd5String(paramsString.ToString()).ToUpper(); 16 } 17 private string GetMd5String(string paramsString) 18 { 19 MD5 md5 = MD5.Create(); 20 byte[] bytes = md5.ComputeHash(Encoding.UTF8.GetBytes(paramsString)); 21 StringBuilder sb = new StringBuilder(); 22 foreach (byte b in bytes) 23 sb.AppendFormat("{0:X2}", b); 24 return sb.ToString(); 25 }