最近在做淘宝相关应用,想要通过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 DictionarysignParams = new Dictionary (); 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 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 }