using AngleSharp.Html.Parser; using Hncore.Infrastructure.Common; using Hncore.Infrastructure.Extension; using Hncore.Infrastructure.Serializer; using Hncore.Infrastructure.WebApi; using Hncore.Pass.Vpn.Model; using Hncore.Pass.Vpn.Request.Product; using Newtonsoft.Json; using Newtonsoft.Json.Linq; using System; using System.Text; using System.Collections.Generic; using System.Diagnostics; using System.Linq; using System.Net; using System.Net.Http; using System.IO; using System.Threading.Tasks; using System.Security.Cryptography; using Newtonsoft.Json; using Newtonsoft.Json.Linq; namespace Hncore.Pass.Vpn.Service { public class AgentClient13Service:AgentClientBaseService { string LoginUrl { get; set; } = "api/login"; string LoginCodeUrl { get; set; } = "main/imgcode.html"; string RefrushTokenUrl { get; set; } = "agent/index.html"; string SingleAddUrl { get; set; } = "api/number"; string SingleReAddUrl { get; set; } = "api/number/renew"; string MuiltAddUrl { get; set; } = "agent/memberMuiltAdd.html"; string RefundUrl { get; set; } = "api/number/refund"; string UpdateUrl = "api/number/";//agent/memberUpdate/id/1155709.html string OnlineUrl { get; set; } = "api/numberLine/"; string KIllUrl { get; set; } = "api/numberOffline"; string searchAccountUrl = "api/numberSingle/"; string searchTestAccountUrl = "api/numberSingle/"; string DeleteUrl { get; set; } = "api/number/refund";//1160862.html"; IHttpClientFactory m_HttpClientFactory; public AgentClient13Service(IHttpClientFactory httpClientFactory):base(httpClientFactory) { m_HttpClientFactory = httpClientFactory; } public override async Task RefrushStatus() { return 1; } public override async Task<(byte[], string)> GetCode() { var client = CreateHttpClient(false); if (this.LoginUrl.NotHas()) return (null, ""); var getResp = await client.GetAsync(this.LoginUrl); var cookie = this.GetCookie(getResp, "PHPSESSID"); if (cookie.Has()) { client.DefaultRequestHeaders.Add("Cookie", cookie); var ret = await client.GetByteArrayAsync(this.LoginCodeUrl + "?t=" + DateTime.Now.Millisecond); return (ret, cookie); } return (null, ""); } public override async Task Login(AgentLoginRequest request) { return new ApiResult(request.Key); } public override bool CheckAccount(int productId,List accounts) { return false; } /// /// 新开 /// /// /// /// /// public override async Task NewAccount(string packageKey, string account, string pwd, int connCount = 1, int accountType = 1, int payCount = 1) { var remark = ""; if(account.Contains("-")){ string[] arrStr = account.Split('-'); account = arrStr[0]; remark = arrStr[1]; } Random rd = new Random(Guid.NewGuid().GetHashCode()); int i = rd.Next(); var time_s = DateTime.Now.GetUnixTimeStamp(); var agentid = "admin1"; var nonce = MD5(time_s.ToString()) + i.ToString(); var apikey = "0c4641686764e0ee56ef54b16fddc966"; var sign = MD5(time_s+nonce+apikey); var userid = "kh"; var url = "/api/raduserCreate?agentid="+agentid+"&ti="+time_s+"&nonce="+nonce+"&sign="+sign+"&userid="+userid+"&username="+account+"&password="+pwd+"&prdid=8&maxonline="+connCount+"&day="+packageKey+"&remark="+remark; var client = CreateHttpClient(); var resp = await client.GetAsync(url); var content = await resp.Content.ReadAsStringAsync(); JObject jo = (JObject)JsonConvert.DeserializeObject(content); var status = jo["errcode"].ToString(); if (status =="0") { return new ApiResult(ResultCode.C_SUCCESS); } else { return new ApiResult(ResultCode.C_INVALID_ERROR, "开户失败"); } } /// /// 新开 /// /// /// /// /// public override async Task NewMuiltAccount(string packageKey, string account, string pwd, int connCount = 1, int accountType = 1,int startNum=0, int endNum=1 ) { var client = CreateHttpClient(); var map = new Dictionary(){ {"group","single" }, {"number",account }, {"password",pwd }, {"connect",connCount.ToString()}, {"interval","1"}, {"type",packageKey}, {"body","api"}, {"mobile","13073735878"} }; var title = GetOpTitle("NewAccount", account); LogHelper.Info(title, map.ToJson()); try { var resp = await client.PostAsForm(this.SingleAddUrl, map); var content = await resp.Content.ReadAsStringAsync(); JObject jo = (JObject)JsonConvert.DeserializeObject(content); var status = jo["status"].ToString(); if (status =="400") { return new ApiResult(ResultCode.C_SUCCESS); } else { LogHelper.Error(title, content); return new ApiResult(ResultCode.C_INVALID_ERROR, "开户失败"); } } catch (Exception ex) { LogHelper.Error(title, ex.Message); return new ApiResult(ResultCode.C_INVALID_ERROR, "开户失败"); } } /// /// 续费 /// /// /// /// /// public override async Task NewReAccount(string packageKey, string account, int connCount, int payCount = 1) { var product_id = ""; var product_sub_id = ""; var product_item_id = ""; var type = ""; var days = ""; if(packageKey.Contains("-")){ string[] arrStr = packageKey.Split('-'); product_id = arrStr[0]; product_sub_id = arrStr[1]; product_item_id = arrStr[2]; days = arrStr[3]; if (product_id == "1") { type = "0"; } if (product_id == "2") { type = "1"; } } Dictionary map = new Dictionary(){ {"t_id","121" }, {"product_id",product_id }, {"product_sub_id",product_sub_id }, {"product_item_id",product_item_id }, {"days",days }, {"type",type }, {"account",account }, }; map = signAct(map); var client = CreateHttpClient(); var resp = await client.PostAsForm("https://jyip.net/open-api/account-renew", map); var content = await resp.Content.ReadAsStringAsync(); JObject jo = (JObject)JsonConvert.DeserializeObject(content); var status = jo["code"].ToString(); if (status == "200") { return new ApiResult(1); } else { return new ApiResult(ResultCode.C_INVALID_ERROR, "续费失败"); } } /// /// 删除账号 /// /// /// /// public override async Task DeleteAccount(string account) { var client = CreateHttpClient(); var infoRet = await this.GetAccountInfo(account, true); if (infoRet.Code != ResultCode.C_SUCCESS) return false; var title = GetOpTitle("DeleteAccount", account); LogHelper.Info(title, account); try { var delete = this.DeleteUrl + infoRet.Data.Id + ".html"; var resp = await client.GetAsync(delete); var content = await resp.Content.ReadAsStringAsync(); if (content.Has() && content.IndexOf("alert(\"删除成功\")") != -1) { return true; } else { LogHelper.Error(title, content); return false; } } catch (Exception ex) { LogHelper.Error(title, ex.Message); return false; } } /// /// 得到账号信息 /// /// /// /// public override async Task> GetAccountInfo(string account,bool isTest=false) { Random rd = new Random(Guid.NewGuid().GetHashCode()); int i = rd.Next(); var time_s = DateTime.Now.GetUnixTimeStamp(); var agentid = "admin1"; var nonce = MD5(time_s.ToString()) + i.ToString(); var apikey = "0c4641686764e0ee56ef54b16fddc966"; var sign = MD5(time_s+nonce+apikey); var url = "/api/raduserInfo?agentid="+agentid+"&ti="+time_s+"&nonce="+nonce+"&sign="+sign+"&username="+account; var client = CreateHttpClient(); var resp = await client.GetAsync(url); var content = await resp.Content.ReadAsStringAsync(); JObject jo = (JObject)JsonConvert.DeserializeObject(content); var status = jo["errcode"].ToString(); var data = jo["data"]; if (status =="0") { var trData = new OriginAccountModel { Id = "", Account = data["username"].ToString(), Pwd = data["password"].ToString(), AccountType = "", Package = "", ConnectCount = "", RegistTime = data["createtime"].ToString(), EndTime = data["expiretime"].ToString(), RestTime = "", Amount = "", Remark = "", }; return new ApiResult(trData); } else { return new ApiResult(ResultCode.C_INVALID_ERROR, "没有查询到信息"); } } /// /// 修改账号密码 /// /// /// /// /// public override async Task UpdateAccountPwd(string account, string pwd) { var account_r = ""; var type = ""; if(account.Contains("-")){ string[] arrStr = account.Split('-'); account_r = arrStr[0]; type = arrStr[1]; } Dictionary map = new Dictionary(){ {"t_id","121" }, {"passwd",pwd }, {"account",account_r }, {"type",type }, }; map = signAct(map); var client = CreateHttpClient(); var resp = await client.PostAsForm("https://jyip.net/open-api/edit-password", map); var content = await resp.Content.ReadAsStringAsync(); JObject jo = (JObject)JsonConvert.DeserializeObject(content); var status = jo["code"].ToString(); if (status == "200") { return true; } else { return false; } } /// /// 退款 /// /// /// /// public override async Task Refund(string account, string packageKey, int days) { return new ApiResult(1); } /// /// 是否在线 /// /// /// /// public override async Task>> OnLine(string account) { var acc = ""; var type = ""; string[] arrStr = account.Split('-'); acc = arrStr[0]; type = arrStr[1]; Dictionary map = new Dictionary(){ {"type",type }, {"account",acc }, }; map = signAct(map); var client = CreateHttpClient(); var resp = await client.PostAsForm("https://jyip.net/open-api/account-is-online", map); var content = await resp.Content.ReadAsStringAsync(); JObject jo = (JObject)JsonConvert.DeserializeObject(content); var status = jo["code"].ToString(); var retData = new List(); if (status == "200") { if(jo.ContainsKey("data")){ JObject jsondata1 = (JObject)JsonConvert.DeserializeObject(jo["data"].ToJson()); JObject jsondata = (JObject)JsonConvert.DeserializeObject(jsondata1[acc].ToJson()); if (jsondata["is_online"].ToString() == "1") { var trData = new OriginAccountOnlineModel { Account = acc, ServerIP = "", LoginTime = "", OnlineTime = "", LoginIP = "", UpStream = "", DownStream = "", Id= "{account:\""+acc+"\",type:\""+type.ToString()+"\"}", }; retData.Add(trData); } } return new ApiResult>(retData); } else { return new ApiResult>(ResultCode.C_INVALID_ERROR, "查询失败"); } } /// /// 踢号 /// /// /// /// public override async Task KillOut( string id) { JObject userinfo = (JObject)JsonConvert.DeserializeObject(id); Dictionary map = new Dictionary(){ {"type",userinfo["type"].ToString() }, {"user",userinfo["account"].ToString() }, }; map = signAct(map); var client = CreateHttpClient(); var resp = await client.PostAsForm("https://jyip.net/open-api/kick-off-line", map); var content = await resp.Content.ReadAsStringAsync(); JObject jo = (JObject)JsonConvert.DeserializeObject(content); var status = jo["code"].ToString(); if (status =="200") { return true; } return false; } /// /// 是否存在 /// /// /// public override async Task Exist(string account) { return false; } private static Dictionary signAct(Dictionary body) { var authStr=""; body.Add("st",DateTime.Now.GetUnixTimeStamp().ToString()); body.Add("app_id","49330ae23dad78f9"); body = body.OrderBy(kv => kv.Key).ToDictionary(kv => kv.Key, p => p.Value); foreach (var item in body) { authStr=authStr+item.Value; } body.Add("sign",Md5(Md5(authStr)+"ddb4311a227fb118cacd63cc68416ab5")); return body; } //Md5摘要 private static string Md5(string text) { MD5 md5 = new MD5CryptoServiceProvider(); byte[] fromData = System.Text.Encoding.UTF8.GetBytes(text); byte[] targetData = md5.ComputeHash(fromData); string byte2String = null; for (int i = 0; i < targetData.Length; i++) { byte2String += targetData[i].ToString("x2"); } return byte2String; } } }