极客自动踢号
This commit is contained in:
@@ -32,8 +32,10 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
string MuiltAddUrl { get; set; } = "agent/memberMuiltAdd.html";
|
string MuiltAddUrl { get; set; } = "agent/memberMuiltAdd.html";
|
||||||
string RefundUrl { get; set; } = "agent/memberRefundAct.html ";
|
string RefundUrl { get; set; } = "agent/memberRefundAct.html ";
|
||||||
string UpdateUrl = "setuser";
|
string UpdateUrl = "setuser";
|
||||||
string OnlineUrl { get; set; } = "active_log/?user=";
|
string OnlineUrl { get; set; } = "/userapi3/?secretId=20200716182518182489&secretKey=OFcEJAfzYjWT3e2s&type=get_user_onlinelog&user=";
|
||||||
string KIllUrl { get; set; } = "agent/disConnect2/radacctid/{0}.html";
|
// string KIllUrl { get; set; } = "agent/disConnect2/radacctid/{0}.html";
|
||||||
|
string KIllUrl { get; set; } = "/userapi3/?secretId=20200716182518182489&secretKey=OFcEJAfzYjWT3e2s&type=user_online_offline&user={0}&address={1}&server_ip={2}";
|
||||||
|
///userapi3/?secretId=xxx&secretKey=xxxv&type=user_online_offline&user=xxx&address=10.20.0.10&server_ip=58.21.1.x
|
||||||
string searchAccountUrl = "userList/?sum=100&page=1&search_data=";
|
string searchAccountUrl = "userList/?sum=100&page=1&search_data=";
|
||||||
string searchTestAccountUrl = "agent/memberList/type/0.html?search=1&username=";
|
string searchTestAccountUrl = "agent/memberList/type/0.html?search=1&username=";
|
||||||
string DeleteUrl { get; set; } = "agent/memberDel/id/";//1160862.html";
|
string DeleteUrl { get; set; } = "agent/memberDel/id/";//1160862.html";
|
||||||
@@ -180,6 +182,7 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
LogHelper.Info(title, map.ToJson());
|
LogHelper.Info(title, map.ToJson());
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
|
||||||
var resp = await client.GetAsync(this.UserApiUrl + "?" + this.FormatRequest(map));
|
var resp = await client.GetAsync(this.UserApiUrl + "?" + this.FormatRequest(map));
|
||||||
var content = await resp.Content.ReadAsStringAsync();
|
var content = await resp.Content.ReadAsStringAsync();
|
||||||
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
||||||
@@ -490,47 +493,31 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
var url = this.OnlineUrl + account;
|
var url = this.OnlineUrl + account;
|
||||||
var resp = await client.GetAsync(url);
|
var resp = await client.GetAsync(url);
|
||||||
var content = await resp.Content.ReadAsStringAsync();
|
var content = await resp.Content.ReadAsStringAsync();
|
||||||
|
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
||||||
var parser = new HtmlParser();
|
|
||||||
var document = await parser.ParseDocumentAsync(content);
|
|
||||||
var trs = document.QuerySelectorAll("table.table tr").ToList();
|
|
||||||
var retData = new List<OriginAccountOnlineModel>();
|
var retData = new List<OriginAccountOnlineModel>();
|
||||||
if (trs.Count() > 1)
|
if ((int)jo["code"] == 1)
|
||||||
{
|
{
|
||||||
foreach (var tr in trs.Skip(1))
|
foreach (var tr in jo["data"])
|
||||||
{
|
{
|
||||||
var tds = tr.QuerySelectorAll("td").ToList();
|
JObject jsondata = (JObject)JsonConvert.DeserializeObject(tr.ToJson());
|
||||||
var tdAccount = tds[1].FirstChild.TextContent;
|
|
||||||
if (tdAccount != account)
|
|
||||||
continue;
|
|
||||||
info = string.Join("", tds.Select(m => m.OuterHtml));
|
|
||||||
//序号 会员账号 服务器IP 登录时间 在线时长 会员IP 上行流量 下行流量 操作
|
|
||||||
|
|
||||||
var trData = new OriginAccountOnlineModel
|
var trData = new OriginAccountOnlineModel
|
||||||
{
|
{
|
||||||
Account = account,
|
Account = account,
|
||||||
ServerIP = tds[6].TextContent,
|
ServerIP = jsondata["server_ip"].ToString(),
|
||||||
LoginTime = tds[1].TextContent,
|
LoginTime = jsondata["online_time"].ToString(),
|
||||||
OnlineTime = tds[3].TextContent,
|
OnlineTime = jsondata["online_time"].ToString(),
|
||||||
LoginIP = tds[5].TextContent,
|
LoginIP = jsondata["client_ip"].ToString(),
|
||||||
UpStream = tds[4].TextContent,
|
UpStream = "",
|
||||||
DownStream = tds[4].TextContent,
|
DownStream = "",
|
||||||
Id= account,
|
Id= "{user:\""+account+"\",address:\""+jsondata["address"]+"\",server_ip:\""+jsondata["server_ip"]+"\"}",
|
||||||
};
|
};
|
||||||
var href = tr.LastElementChild.QuerySelector("a")?.Attributes["href"]?.Value;
|
|
||||||
if (href.Has())
|
|
||||||
{
|
|
||||||
var start = href.LastIndexOf('/');
|
|
||||||
var end = href.IndexOf(".html");
|
|
||||||
if (start != -1 && end != -1)
|
|
||||||
{
|
|
||||||
trData.Id = href.Substring(start + 1, end - start).TrimEnd('.');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
retData.Add(trData);
|
retData.Add(trData);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return new ApiResult<List<OriginAccountOnlineModel>>(retData);
|
return new ApiResult<List<OriginAccountOnlineModel>>(retData);
|
||||||
|
// return new ApiResult<List<OriginAccountOnlineModel>>(ResultCode.C_INVALID_ERROR, "查询失败");
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
@@ -548,13 +535,18 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
{
|
{
|
||||||
var client = CreateHttpClient();
|
var client = CreateHttpClient();
|
||||||
var title = GetOpTitle("KillOut", id);
|
var title = GetOpTitle("KillOut", id);
|
||||||
|
JObject userinfo = (JObject)JsonConvert.DeserializeObject(id);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
var info = "";
|
var info = "";
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var url = string.Format(this.KIllUrl, id);
|
var url = string.Format(this.KIllUrl, userinfo["user"],userinfo["address"],userinfo["server_ip"]);
|
||||||
var resp = await client.GetAsync(url);
|
var resp = await client.GetAsync(url);
|
||||||
var content = await resp.Content.ReadAsStringAsync();
|
var content = await resp.Content.ReadAsStringAsync();
|
||||||
if(content.Has()&&content.IndexOf("断开成功")!=-1)
|
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
||||||
|
if((int)jo["code"] == 1)
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user