淘宝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 signParams = new Dictionary();
            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 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();
        }
 
  

 
  

你可能感兴趣的:(淘宝Refrash_token签名错误的解决办法)