根据时间戳及密钥判断当前token值是否有效

需要的方法:

/// <summary>
/// 将c# DateTime时间格式转换为Unix时间戳格式
/// </summary>
/// <param name="time">时间</param>
/// <returns>double</returns>
public static double ConvertDateTimeToTimeStamp()
{
double intResult = 0;
DateTime startTime = TimeZone.CurrentTimeZone.ToLocalTime(new System.DateTime(1970, 1, 1));
intResult = (DateTime.Now - startTime).TotalSeconds;
return intResult;
}

/// <summary>
/// 毫秒时间戳
/// </summary>
/// <returns></returns>
public static double TimeSpanByTotalMilliseconds()
{
return (DateTime.Now.ToUniversalTime().Ticks - 621355968000000000) / 10000;
}

传入参数 :{"TimeStampRange":"时间戳","sign":"签名"}  协商的固定参数:SignKey:密钥

string plan=thirdLogin.Unionid + thirdLogin.TimeStampRange.ToString() + SignKey;

if (EncrypHelper.GetMD5(plan) != thirdLogin.Sign || (Math.Abs(TimeHelper.TimeSpanByTotalMilliseconds() - thirdLogin.TimeStampRange) > 300000)){}

1.将用户标识列,时间戳和密钥拼接的字段进行MD5加密,判断传入的sign是否正确

2.判断传入的时间戳是否超过了10分钟,精确到毫秒。

注释:Math.Abs获取其绝对值

 

posted @ 2018-09-07 11:35  蹦蹦郭  阅读(3585)  评论(0编辑  收藏  举报