/// <summary> /// 获取信息 /// </summary> /// <param name="user">用户</param> /// <returns></returns> public static async Task <string> GetInfoAsync(User user) { try { if (user == null) { throw new ArgumentNullException(nameof(user)); } QueryCollection queries; queries = new QueryCollection { { "access_key", user.Data.AccessKey }, { "ts", ApiUtils.GetTimeStamp().ToString() } }; queries.AddRange(user.Data.Cookie.Split(';').Select(item => { string[] pair; pair = item.Split('='); return(new KeyValuePair <string, string>(pair[0], pair[1])); })); queries.AddRange(General); queries.SortAndSign(); using HttpResponseMessage response = await user.Handler.SendAsync(HttpMethod.Get, OAUTH2_INFO_URL, queries, user.AppHeaders); return(await response.Content.ReadAsStringAsync()); } catch { return(null); } }
/// <summary> /// 登录 /// </summary> /// <param name="user">用户</param> /// <param name="jsonKey">Key</param> /// <param name="captcha">验证码</param> /// <returns></returns> public static async Task <string> LoginAsync(User user, string jsonKey, string captcha) { if (user == null) { throw new ArgumentNullException(nameof(user)); } if (string.IsNullOrEmpty(jsonKey)) { throw new ArgumentNullException(nameof(jsonKey)); } JToken loginKey; string rsaKey; RSAParameters rsaParameters; QueryCollection queries; loginKey = JObject.Parse(jsonKey)["data"]; rsaKey = (string)loginKey["key"]; rsaParameters = ApiUtils.ParsePublicKey(rsaKey); queries = new QueryCollection { { "username", user.Account }, { "password", ApiUtils.RsaEncrypt(loginKey["hash"] + user.Password, rsaParameters) }, { "captcha", captcha ?? string.Empty } }; queries.AddRange(General); queries.SortAndSign(); using (HttpResponseMessage response = await user.Handler.SendAsync(HttpMethod.Post, OAUTH2_LOGIN_URL, queries, null)) { return(await response.Content.ReadAsStringAsync()); } }
/// <summary> /// 刷新Token /// </summary> /// <param name="user">用户</param> /// <returns></returns> public static async Task <string> RefreshTokenAsync(User user) { if (user == null) { throw new ArgumentNullException(nameof(user)); } QueryCollection queries; queries = new QueryCollection { { "access_key", user.LoginData["access_key"] }, { "refresh_token", user.LoginData["refresh_token"] }, { "ts", ApiUtils.GetTimeStamp().ToString() } }; queries.AddRange(user.LoginData["cookie"].Split(';').Select(item => { string[] pair; pair = item.Split('='); return(new KeyValuePair <string, string>(pair[0], pair[1])); })); queries.AddRange(General); queries.SortAndSign(); using (HttpResponseMessage response = await user.Client.SendAsync(HttpMethod.Post, OAUTH2_REFRESH_TOKEN_URL, queries, user.AppHeaders)) return(await response.Content.ReadAsStringAsync()); }
/// <summary> /// 获取Key /// </summary> /// <param name="user">用户</param> /// <returns></returns> public static async Task <string> GetKeyAsync(User user) { if (user == null) { throw new ArgumentNullException(nameof(user)); } QueryCollection queries; queries = new QueryCollection { { "appkey", General["appkey"] } }; queries.SortAndSign(); using (HttpResponseMessage response = await user.Handler.SendAsync(HttpMethod.Post, OAUTH2_GETKEY_URL, queries, null)) return(await response.Content.ReadAsStringAsync()); }