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