蘑菇换api 其他优化
This commit is contained in:
@@ -43,7 +43,7 @@
|
|||||||
<p>代理商专用客户端</p>
|
<p>代理商专用客户端</p>
|
||||||
<p><a href="http://wuxinxikehuduan.image.qiangzipptp.top/%E8%A5%BF%E7%93%9CIP%20-%20%E4%BB%A3%E7%90%86%E7%89%88.zip"> <button type="button" class="btnBlue">西瓜IP-电脑版</button></a></p>
|
<p><a href="http://wuxinxikehuduan.image.qiangzipptp.top/%E8%A5%BF%E7%93%9CIP%20-%20%E4%BB%A3%E7%90%86%E7%89%88.zip"> <button type="button" class="btnBlue">西瓜IP-电脑版</button></a></p>
|
||||||
<p><a href="http://wuxinxikehuduan.image.qiangzipptp.top/%E8%A5%BF%E7%93%9CIP%E5%AE%89%E5%8D%93%E4%BB%A3%E7%90%86%E7%89%88.apk"> <button type="button" class="btnBlue">西瓜IP-安卓</button></a></p><br>
|
<p><a href="http://wuxinxikehuduan.image.qiangzipptp.top/%E8%A5%BF%E7%93%9CIP%E5%AE%89%E5%8D%93%E4%BB%A3%E7%90%86%E7%89%88.apk"> <button type="button" class="btnBlue">西瓜IP-安卓</button></a></p><br>
|
||||||
<p><a href="http://wuxinxikehuduan.image.qiangzipptp.top/%E6%9E%81%E5%AE%A2IP%E7%94%B5%E8%84%91%E4%BB%A3%E7%90%86%E7%89%88-12.13%E6%97%A5%E6%9B%B4%E6%96%B0.zip"> <button type="button" class="btnBlue">极客IP-电脑版</button></a></p><br>
|
<p><a href="http://wuxinxikehuduan.image.qiangzipptp.top/%E6%9E%81%E5%AE%A2IP%E4%BB%A3%E7%90%86%E7%89%88%203.5.rar"> <button type="button" class="btnBlue">极客IP-电脑版</button></a></p><br>
|
||||||
<p><a href="http://wuxinxikehuduan.image.qiangzipptp.top/%E6%9E%81%E5%AE%A2IP%E5%AE%89%E5%8D%93%E4%BB%A3%E7%90%86%E7%89%88.apk"> <button type="button" class="btnBlue">极客IP-安卓</button></a></p><br>
|
<p><a href="http://wuxinxikehuduan.image.qiangzipptp.top/%E6%9E%81%E5%AE%A2IP%E5%AE%89%E5%8D%93%E4%BB%A3%E7%90%86%E7%89%88.apk"> <button type="button" class="btnBlue">极客IP-安卓</button></a></p><br>
|
||||||
|
|
||||||
<p><a href="http://wuxinxikehuduan.image.qiangzipptp.top/%E8%AE%AF%E8%BF%9EIP%E7%94%B5%E8%84%91%E7%AB%AF-%E4%BB%A3%E7%90%86%E7%89%88.rar"> <button type="button" class="btnBlue">迅连IP-电脑版</button></a></p>
|
<p><a href="http://wuxinxikehuduan.image.qiangzipptp.top/%E8%AE%AF%E8%BF%9EIP%E7%94%B5%E8%84%91%E7%AB%AF-%E4%BB%A3%E7%90%86%E7%89%88.rar"> <button type="button" class="btnBlue">迅连IP-电脑版</button></a></p>
|
||||||
|
|||||||
@@ -536,7 +536,7 @@
|
|||||||
<p>@restTimes</p>
|
<p>@restTimes</p>
|
||||||
<div class="pkgNameCard">
|
<div class="pkgNameCard">
|
||||||
<p class="tianka" style="font-size:17px;color:white;">测试卡</p>
|
<p class="tianka" style="font-size:17px;color:white;">测试卡</p>
|
||||||
<p class="qixian">使用期限:1小时</p>
|
<p class="qixian">使用期限:2小时</p>
|
||||||
</div>
|
</div>
|
||||||
<img src="~/img/check.png" class="cardCheck">
|
<img src="~/img/check.png" class="cardCheck">
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -84,7 +84,7 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="item" style="margin-bottom: 5px;">
|
<div class="item" style="margin-bottom: 5px;">
|
||||||
<a href="http://wuxinxikehuduan.image.qiangzipptp.top/%E6%9E%81%E5%AE%A2IP%E7%94%B5%E8%84%91%E4%BB%A3%E7%90%86%E7%89%88-12.13%E6%97%A5%E6%9B%B4%E6%96%B0.zip"> <button type="button" class="btn btn-sdefault" style="width: auto;">极客IP-电脑版</button></a>
|
<a href="http://wuxinxikehuduan.image.qiangzipptp.top/%E6%9E%81%E5%AE%A2IP%E4%BB%A3%E7%90%86%E7%89%88%203.5.rar"> <button type="button" class="btn btn-sdefault" style="width: auto;">极客IP-电脑版</button></a>
|
||||||
</div>
|
</div>
|
||||||
<div class="item" style="margin-bottom: 5px;">
|
<div class="item" style="margin-bottom: 5px;">
|
||||||
<a href="http://wuxinxikehuduan.image.qiangzipptp.top/%E6%9E%81%E5%AE%A2IP%E5%AE%89%E5%8D%93%E4%BB%A3%E7%90%86%E7%89%88.apk"> <button type="button" class="btn btn-sdefault" style="width: auto;">极客IP-安卓</button></a>
|
<a href="http://wuxinxikehuduan.image.qiangzipptp.top/%E6%9E%81%E5%AE%A2IP%E5%AE%89%E5%8D%93%E4%BB%A3%E7%90%86%E7%89%88.apk"> <button type="button" class="btn btn-sdefault" style="width: auto;">极客IP-安卓</button></a>
|
||||||
|
|||||||
@@ -142,10 +142,10 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="col-lg-4 regDan">
|
<div class="col-lg-4 regDan">
|
||||||
<input type="text" name="Account" value="" v-model="OneBuyModel.Account" v-on:blur="checkOneAccount" />
|
<input type="text" name="Account" value="" v-model="OneBuyModel.Account" v-on:blur="checkOneAccount" />
|
||||||
<p class="jinggao" v-if="!OneChecker.AccountOk">5至10位字母或数字或组合</p>
|
<p class="jinggao" v-if="!OneChecker.AccountOk">4至10位字母或数字或组合</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-lg-4 text-left warnText">
|
<div class="col-lg-4 text-left warnText">
|
||||||
<sapn class="grayText">5至10位字母或数字或组合</sapn>
|
<sapn class="grayText">4至10位字母或数字或组合</sapn>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
@@ -269,7 +269,7 @@
|
|||||||
<p class="jinggao" v-if="!MoreChecker.AccountOk">3至8位字母或数字或组合</p>
|
<p class="jinggao" v-if="!MoreChecker.AccountOk">3至8位字母或数字或组合</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-lg-4 text-left warnText">
|
<div class="col-lg-4 text-left warnText">
|
||||||
<sapn class="grayText">3至8位字母或数字或组合</sapn>
|
<sapn class="grayText">2至8位字母或数字或组合</sapn>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
@@ -675,7 +675,7 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
checkOneAccount() {
|
checkOneAccount() {
|
||||||
if (this.OneBuyModel.Account.length > 10 || this.OneBuyModel.Account.length < 5 || !this.hasNumAndChar(this.OneBuyModel.Account)) {
|
if (this.OneBuyModel.Account.length > 10 || this.OneBuyModel.Account.length < 4 || !this.hasNumAndChar(this.OneBuyModel.Account)) {
|
||||||
this.OneChecker.AccountOk = false;
|
this.OneChecker.AccountOk = false;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@@ -691,7 +691,7 @@
|
|||||||
return true;
|
return true;
|
||||||
},
|
},
|
||||||
checkMoreAccount() {
|
checkMoreAccount() {
|
||||||
if (this.MoreBuyModel.Account.length < 3 || this.MoreBuyModel.Account.length > 8 || !this.hasNumAndChar(this.MoreBuyModel.Account)) {
|
if (this.MoreBuyModel.Account.length < 2 || this.MoreBuyModel.Account.length > 8 || !this.hasNumAndChar(this.MoreBuyModel.Account)) {
|
||||||
this.MoreChecker.AccountOk = false;
|
this.MoreChecker.AccountOk = false;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -23,17 +23,16 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
string LoginUrl { get; set; } = "api/login";
|
string LoginUrl { get; set; } = "api/login";
|
||||||
string LoginCodeUrl { get; set; } = "main/imgcode.html";
|
string LoginCodeUrl { get; set; } = "main/imgcode.html";
|
||||||
string RefrushTokenUrl { get; set; } = "agent/index.html";
|
string RefrushTokenUrl { get; set; } = "agent/index.html";
|
||||||
string SingleAddUrl { get; set; } = "api/index/AddAccount?apikey=80cf4f64e990b78a9fc5eb&";
|
string SingleAddUrl { get; set; } = "api/number";
|
||||||
string SingleReAddUrl { get; set; } = "api/index/updateAccount?apikey=80cf4f64e990b78a9fc5eb&";
|
string SingleReAddUrl { get; set; } = "api/number/renew";
|
||||||
string MuiltAddUrl { get; set; } = "agent/memberMuiltAdd.html";
|
string MuiltAddUrl { get; set; } = "agent/memberMuiltAdd.html";
|
||||||
string RefundUrl { get; set; } = "api/index/refund?apikey=80cf4f64e990b78a9fc5eb&";
|
string RefundUrl { get; set; } = "api/number/refund";
|
||||||
string UpdateUrl = "api/index/updateAccount?apikey=80cf4f64e990b78a9fc5eb&";//agent/memberUpdate/id/1155709.html
|
string UpdateUrl = "api/number/";//agent/memberUpdate/id/1155709.html
|
||||||
string OnlineUrl { get; set; } = "api/index/getOnlineList?apikey=80cf4f64e990b78a9fc5eb&";
|
string OnlineUrl { get; set; } = "api/numberLine/";
|
||||||
string KIllUrl { get; set; } = "api/index/disconnect?apikey=80cf4f64e990b78a9fc5eb&";
|
string KIllUrl { get; set; } = "api/numberOffline";
|
||||||
string searchAccountUrl = "api/index/getAccountInfo?apikey=80cf4f64e990b78a9fc5eb&";
|
string searchAccountUrl = "api/numberSingle/";
|
||||||
string searchTestAccountUrl = "api/numberSingle/";
|
string searchTestAccountUrl = "api/numberSingle/";
|
||||||
string DeleteUrl { get; set; } = "api/number/refund";//1160862.html";
|
string DeleteUrl { get; set; } = "api/number/refund";//1160862.html";
|
||||||
string is_exist { get; set; } = "api/index/exist?apikey=80cf4f64e990b78a9fc5eb&";//1160862.html";
|
|
||||||
IHttpClientFactory m_HttpClientFactory;
|
IHttpClientFactory m_HttpClientFactory;
|
||||||
public AgentClient9Service(IHttpClientFactory httpClientFactory):base(httpClientFactory)
|
public AgentClient9Service(IHttpClientFactory httpClientFactory):base(httpClientFactory)
|
||||||
{
|
{
|
||||||
@@ -76,16 +75,33 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public override async Task<ApiResult> NewAccount(string packageKey, string account, string pwd, int connCount = 1, int accountType = 1, int payCount = 1)
|
public override async Task<ApiResult> NewAccount(string packageKey, string account, string pwd, int connCount = 1, int accountType = 1, int payCount = 1)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
Random rd = new Random(Guid.NewGuid().GetHashCode());
|
||||||
|
int i = rd.Next();
|
||||||
|
|
||||||
|
var time_s = DateTime.Now.GetUnixTimeStamp();
|
||||||
|
var agentid = "juipgfwww";
|
||||||
|
var nonce = MD5(time_s.ToString()) + i.ToString();
|
||||||
|
var apikey = "7492520f74a59483f90e67238b92c0ba";
|
||||||
|
var sign = MD5(time_s+nonce+apikey);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
var userid = "11";
|
||||||
|
|
||||||
|
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;
|
||||||
|
|
||||||
var client = CreateHttpClient();
|
var client = CreateHttpClient();
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
var url = this.SingleAddUrl + "type=one&username="+account+"&pass="+pwd+"&taocan="+packageKey+"&connect="+connCount.ToString();
|
|
||||||
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);
|
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
||||||
var status = jo["code"].ToString();
|
Console.WriteLine("=====================================================================================");
|
||||||
if (status =="10000")
|
Console.WriteLine(content);
|
||||||
|
Console.WriteLine("=====================================================================================");
|
||||||
|
var status = jo["errcode"].ToString();
|
||||||
|
|
||||||
|
if (status =="0")
|
||||||
{
|
{
|
||||||
return new ApiResult(ResultCode.C_SUCCESS);
|
return new ApiResult(ResultCode.C_SUCCESS);
|
||||||
}
|
}
|
||||||
@@ -94,11 +110,6 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
return new ApiResult(ResultCode.C_INVALID_ERROR, "开户失败");
|
return new ApiResult(ResultCode.C_INVALID_ERROR, "开户失败");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
|
||||||
{
|
|
||||||
return new ApiResult(ResultCode.C_INVALID_ERROR, "开户失败");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 新开
|
/// 新开
|
||||||
@@ -110,20 +121,7 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
public override async Task<ApiResult> NewMuiltAccount(string packageKey, string account, string pwd, int connCount = 1, int accountType = 1,int startNum=0, int endNum=1 )
|
public override async Task<ApiResult> NewMuiltAccount(string packageKey, string account, string pwd, int connCount = 1, int accountType = 1,int startNum=0, int endNum=1 )
|
||||||
{
|
{
|
||||||
var client = CreateHttpClient();
|
var client = CreateHttpClient();
|
||||||
|
var map = new Dictionary<string, string>(){
|
||||||
var map = new Dictionary<string, string>(){};
|
|
||||||
|
|
||||||
|
|
||||||
if(packageKey == "test"){
|
|
||||||
map = new Dictionary<string, string>(){
|
|
||||||
{"group","test" },
|
|
||||||
{"number",account },
|
|
||||||
{"password",pwd },
|
|
||||||
{"body","api"},
|
|
||||||
{"mobile","13073735878"}
|
|
||||||
};
|
|
||||||
} else {
|
|
||||||
map = new Dictionary<string, string>(){
|
|
||||||
{"group","single" },
|
{"group","single" },
|
||||||
{"number",account },
|
{"number",account },
|
||||||
{"password",pwd },
|
{"password",pwd },
|
||||||
@@ -133,7 +131,6 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
{"body","api"},
|
{"body","api"},
|
||||||
{"mobile","13073735878"}
|
{"mobile","13073735878"}
|
||||||
};
|
};
|
||||||
}
|
|
||||||
var title = GetOpTitle("NewAccount", account);
|
var title = GetOpTitle("NewAccount", account);
|
||||||
LogHelper.Info(title, map.ToJson());
|
LogHelper.Info(title, map.ToJson());
|
||||||
try
|
try
|
||||||
@@ -168,16 +165,31 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public override async Task<ApiResult> NewReAccount(string packageKey, string account, int connCount, int payCount = 1)
|
public override async Task<ApiResult> NewReAccount(string packageKey, string account, int connCount, int payCount = 1)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
Random rd = new Random(Guid.NewGuid().GetHashCode());
|
||||||
|
int i = rd.Next();
|
||||||
|
|
||||||
|
var time_s = DateTime.Now.GetUnixTimeStamp();
|
||||||
|
var agentid = "juipgfwww";
|
||||||
|
var nonce = MD5(time_s.ToString()) + i.ToString();
|
||||||
|
var apikey = "7492520f74a59483f90e67238b92c0ba";
|
||||||
|
var sign = MD5(time_s+nonce+apikey);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
var url = "/api/raduserRenew?agentid="+agentid+"&ti="+time_s+"&nonce="+nonce+"&sign="+sign+"&username="+account+"&day="+packageKey;
|
||||||
|
|
||||||
var client = CreateHttpClient();
|
var client = CreateHttpClient();
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
var url = this.SingleReAddUrl + "type=rebuy&username="+account+"&taocan="+packageKey;
|
|
||||||
var resp = await client.GetAsync(url);
|
var resp = await client.GetAsync(url);
|
||||||
var content = await resp.Content.ReadAsStringAsync();
|
var content = await resp.Content.ReadAsStringAsync();
|
||||||
|
Console.WriteLine("==============================================================");
|
||||||
|
Console.WriteLine(content);
|
||||||
|
Console.WriteLine("==============================================================");
|
||||||
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
||||||
var status = jo["code"].ToString();
|
var status = jo["errcode"].ToString();
|
||||||
if (status =="10000")
|
|
||||||
|
if (status =="0")
|
||||||
{
|
{
|
||||||
return new ApiResult(1);
|
return new ApiResult(1);
|
||||||
}
|
}
|
||||||
@@ -186,12 +198,6 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
return new ApiResult(ResultCode.C_INVALID_ERROR, "续费失败");
|
return new ApiResult(ResultCode.C_INVALID_ERROR, "续费失败");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
|
||||||
{
|
|
||||||
return new ApiResult(ResultCode.C_INVALID_ERROR, "续费失败");
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 删除账号
|
/// 删除账号
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -201,8 +207,39 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
public override async Task<bool> DeleteAccount(string account)
|
public override async Task<bool> DeleteAccount(string account)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
Random rd = new Random(Guid.NewGuid().GetHashCode());
|
||||||
|
int i = rd.Next();
|
||||||
|
|
||||||
|
var time_s = DateTime.Now.GetUnixTimeStamp();
|
||||||
|
var agentid = "juipgfwww";
|
||||||
|
var nonce = MD5(time_s.ToString()) + i.ToString();
|
||||||
|
var apikey = "7492520f74a59483f90e67238b92c0ba";
|
||||||
|
var sign = MD5(time_s+nonce+apikey);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
var url = "/api/raduserRefund?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();
|
||||||
|
Console.WriteLine("==============================================================");
|
||||||
|
Console.WriteLine(content);
|
||||||
|
Console.WriteLine("==============================================================");
|
||||||
|
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
||||||
|
var status = jo["errcode"].ToString();
|
||||||
|
|
||||||
|
if (status =="0")
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 得到账号信息
|
/// 得到账号信息
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -212,34 +249,48 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
public override async Task<ApiResult<OriginAccountModel>> GetAccountInfo(string account,bool isTest=false)
|
public override async Task<ApiResult<OriginAccountModel>> 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 = "juipgfwww";
|
||||||
|
var nonce = MD5(time_s.ToString()) + i.ToString();
|
||||||
|
var apikey = "7492520f74a59483f90e67238b92c0ba";
|
||||||
|
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 client = CreateHttpClient();
|
||||||
|
|
||||||
var url = this.searchAccountUrl + "account="+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);
|
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
||||||
var status = jo["code"].ToString();
|
var status = jo["errcode"].ToString();
|
||||||
var data = jo["data"];
|
var data = jo["data"];
|
||||||
if (status =="10000")
|
if (status =="0")
|
||||||
{
|
{
|
||||||
var trData = new OriginAccountModel
|
var trData = new OriginAccountModel
|
||||||
{
|
{
|
||||||
Id = "",
|
Id = "",
|
||||||
Account = data["username"].ToString(),
|
Account = data["username"].ToString(),
|
||||||
Pwd = data["pass"].ToString(),
|
Pwd = data["password"].ToString(),
|
||||||
AccountType = "",
|
AccountType = "",
|
||||||
Package = "",
|
Package = "",
|
||||||
ConnectCount = "",
|
ConnectCount = "",
|
||||||
RegistTime = data["create_time"].ToString(),
|
RegistTime = data["createtime"].ToString(),
|
||||||
EndTime = data["expire_time"].ToString(),
|
EndTime = data["expiretime"].ToString(),
|
||||||
RestTime = "",
|
RestTime = "",
|
||||||
Amount = "",
|
Amount = "",
|
||||||
Remark = "",
|
Remark = "",
|
||||||
};
|
};
|
||||||
return new ApiResult<OriginAccountModel>(trData);
|
return new ApiResult<OriginAccountModel>(trData);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
return new ApiResult<OriginAccountModel>(ResultCode.C_INVALID_ERROR, "没有查询到信息");
|
return new ApiResult<OriginAccountModel>(ResultCode.C_INVALID_ERROR, "没有查询到信息");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -252,16 +303,24 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
public override async Task<bool> UpdateAccountPwd(string account, string pwd)
|
public override async Task<bool> UpdateAccountPwd(string account, string pwd)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
Random rd = new Random(Guid.NewGuid().GetHashCode());
|
||||||
|
int i = rd.Next();
|
||||||
|
|
||||||
|
var time_s = DateTime.Now.GetUnixTimeStamp();
|
||||||
|
var agentid = "juipgfwww";
|
||||||
|
var nonce = MD5(time_s.ToString()) + i.ToString();
|
||||||
|
var apikey = "7492520f74a59483f90e67238b92c0ba";
|
||||||
|
var sign = MD5(time_s+nonce+apikey);
|
||||||
|
|
||||||
|
var url = "/api/raduserChpw?agentid="+agentid+"&ti="+time_s+"&nonce="+nonce+"&sign="+sign+"&username="+account+"&newpass="+pwd;
|
||||||
|
|
||||||
var client = CreateHttpClient();
|
var client = CreateHttpClient();
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
var url = this.UpdateUrl + "type=update_pass&username="+account+"&pass="+pwd;
|
|
||||||
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);
|
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
||||||
var status = jo["code"].ToString();
|
var status = jo["errcode"].ToString();
|
||||||
if (status =="10000")
|
if (status =="0")
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@@ -269,11 +328,6 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
catch (Exception ex)
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -284,13 +338,35 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public override async Task<ApiResult> Refund(string account, string packageKey, int days)
|
public override async Task<ApiResult> Refund(string account, string packageKey, int days)
|
||||||
{
|
{
|
||||||
var client = CreateHttpClient();
|
|
||||||
var url = this.RefundUrl + "username=" + account;
|
Random rd = new Random(Guid.NewGuid().GetHashCode());
|
||||||
var resp = await client.GetAsync(url);
|
|
||||||
var content = await resp.Content.ReadAsStringAsync();
|
var time_s = DateTime.Now.GetUnixTimeStamp();
|
||||||
|
var nonce = MD5(time_s.ToString());
|
||||||
|
await this.UpdateAccountPwd(account, nonce.Substring(1, 5));
|
||||||
|
|
||||||
|
|
||||||
|
// var url = "/api/raduserRefund?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();
|
||||||
|
// Console.WriteLine("==========================tui====================================");
|
||||||
|
// Console.WriteLine(content);
|
||||||
|
// Console.WriteLine("==============================================================");
|
||||||
|
// JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
||||||
|
// Console.WriteLine("===========================kuan===================================");
|
||||||
|
// Console.WriteLine(jo);
|
||||||
|
// Console.WriteLine("==============================================================");
|
||||||
|
// var status = jo["errcode"].ToString();
|
||||||
|
|
||||||
|
// if (status =="0")
|
||||||
|
// {
|
||||||
return new ApiResult(1);
|
return new ApiResult(1);
|
||||||
|
// }
|
||||||
|
// return new ApiResult(ResultCode.C_INVALID_ERROR, "退款失败");
|
||||||
|
|
||||||
}
|
}
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 是否在线
|
/// 是否在线
|
||||||
@@ -300,15 +376,29 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public override async Task<ApiResult<List<OriginAccountOnlineModel>>> OnLine(string account)
|
public override async Task<ApiResult<List<OriginAccountOnlineModel>>> OnLine(string account)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
Random rd = new Random(Guid.NewGuid().GetHashCode());
|
||||||
|
int i = rd.Next();
|
||||||
|
|
||||||
|
var time_s = DateTime.Now.GetUnixTimeStamp();
|
||||||
|
var agentid = "juipgfwww";
|
||||||
|
var nonce = MD5(time_s.ToString()) + i.ToString();
|
||||||
|
var apikey = "7492520f74a59483f90e67238b92c0ba";
|
||||||
|
var sign = MD5(time_s+nonce+apikey);
|
||||||
|
|
||||||
|
var url = "/api/raduserAcct?agentid="+agentid+"&ti="+time_s+"&nonce="+nonce+"&sign="+sign+"&username="+account;
|
||||||
|
|
||||||
var client = CreateHttpClient();
|
var client = CreateHttpClient();
|
||||||
|
|
||||||
var url = this.OnlineUrl + "account="+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);
|
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
||||||
var status = jo["code"].ToString();
|
Console.WriteLine("=========================================================================================");
|
||||||
|
Console.WriteLine(content);
|
||||||
|
Console.WriteLine("=========================================================================================");
|
||||||
|
var status = jo["errcode"].ToString();
|
||||||
var retData = new List<OriginAccountOnlineModel>();
|
var retData = new List<OriginAccountOnlineModel>();
|
||||||
if (status =="10000")
|
if (status =="0")
|
||||||
{
|
{
|
||||||
if(jo.ContainsKey("data")){
|
if(jo.ContainsKey("data")){
|
||||||
foreach (var tr in jo["data"])
|
foreach (var tr in jo["data"])
|
||||||
@@ -318,13 +408,13 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
var trData = new OriginAccountOnlineModel
|
var trData = new OriginAccountOnlineModel
|
||||||
{
|
{
|
||||||
Account = account,
|
Account = account,
|
||||||
ServerIP = jsondata["serveip"].ToString(),
|
ServerIP = jsondata["serverip"].ToString(),
|
||||||
LoginTime = jsondata["start_time"].ToString(),
|
LoginTime = jsondata["starttime"].ToString(),
|
||||||
OnlineTime = jsondata["online_time"].ToString(),
|
OnlineTime = "",
|
||||||
LoginIP = jsondata["userip"].ToString(),
|
LoginIP = jsondata["framedip"].ToString(),
|
||||||
UpStream = jsondata["upbite"].ToString(),
|
UpStream = "",
|
||||||
DownStream = jsondata["downbite"].ToString(),
|
DownStream = "",
|
||||||
Id= jsondata["id"].ToString(),
|
Id= "{account:\""+account+"\",radacctid:\""+jsondata["radacctid"].ToString()+"\"}",
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -333,8 +423,10 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
}
|
}
|
||||||
return new ApiResult<List<OriginAccountOnlineModel>>(retData);
|
return new ApiResult<List<OriginAccountOnlineModel>>(retData);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
return new ApiResult<List<OriginAccountOnlineModel>>(ResultCode.C_INVALID_ERROR, "查询失败");
|
return new ApiResult<List<OriginAccountOnlineModel>>(ResultCode.C_INVALID_ERROR, "查询失败");
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -345,27 +437,40 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public override async Task<bool> KillOut( string id)
|
public override async Task<bool> KillOut( string id)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
Random rd = new Random(Guid.NewGuid().GetHashCode());
|
||||||
|
int i = rd.Next();
|
||||||
|
|
||||||
|
var time_s = DateTime.Now.GetUnixTimeStamp();
|
||||||
|
var agentid = "juipgfwww";
|
||||||
|
var nonce = MD5(time_s.ToString()) + i.ToString();
|
||||||
|
var apikey = "7492520f74a59483f90e67238b92c0ba";
|
||||||
|
var sign = MD5(time_s+nonce+apikey);
|
||||||
|
|
||||||
|
JObject userinfo = (JObject)JsonConvert.DeserializeObject(id);
|
||||||
|
|
||||||
|
var url = "/api/raduserDisconnect?agentid="+agentid+"&ti="+time_s+"&nonce="+nonce+"&sign="+sign+"&username="+userinfo["account"]+"&radacctid="+userinfo["radacctid"];
|
||||||
|
|
||||||
var client = CreateHttpClient();
|
var client = CreateHttpClient();
|
||||||
|
var title = GetOpTitle("KillOut", id);
|
||||||
|
var info = "";
|
||||||
|
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var url = this.KIllUrl + "id="+id;
|
|
||||||
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);
|
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
||||||
var status = jo["code"].ToString();
|
var status = jo["errcode"].ToString();
|
||||||
if (status =="10000")
|
if (status =="0")
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
return false;
|
LogHelper.Error(title, ex.Message + "-->info:" + info);
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@@ -377,19 +482,42 @@ namespace Hncore.Pass.Vpn.Service
|
|||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public override async Task<bool> Exist(string account)
|
public override async Task<bool> Exist(string account)
|
||||||
{
|
{
|
||||||
|
Random rd = new Random(Guid.NewGuid().GetHashCode());
|
||||||
|
int i = rd.Next();
|
||||||
|
|
||||||
|
var time_s = DateTime.Now.GetUnixTimeStamp();
|
||||||
|
var agentid = "juipgfwww";
|
||||||
|
var nonce = MD5(time_s.ToString()) + i.ToString();
|
||||||
|
|
||||||
|
var apikey = "7492520f74a59483f90e67238b92c0ba";
|
||||||
|
var sign = MD5(time_s+nonce+apikey);
|
||||||
|
|
||||||
|
var url = "/api/raduserExist?agentid="+agentid+"&ti="+time_s+"&nonce="+nonce+"&sign="+sign+"&username="+account;
|
||||||
|
|
||||||
var client = CreateHttpClient();
|
var client = CreateHttpClient();
|
||||||
var url = this.is_exist + "username=" + 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();
|
||||||
|
Console.WriteLine("========================================12321=============================================");
|
||||||
|
Console.WriteLine(content);
|
||||||
|
Console.WriteLine("=====================================================================================");
|
||||||
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
||||||
var status = jo["code"].ToString();
|
Console.WriteLine("========================================2313=============================================");
|
||||||
if (status == "-10000")
|
Console.WriteLine(jo);
|
||||||
|
Console.WriteLine("=====================================================================================");
|
||||||
|
var status = jo["errcode"].ToString();
|
||||||
|
|
||||||
|
var is_exit = jo["data"]["exist"];
|
||||||
|
Console.WriteLine("========================================12321=============================================");
|
||||||
|
Console.WriteLine(jo);
|
||||||
|
Console.WriteLine("=====================================================================================");
|
||||||
|
|
||||||
|
|
||||||
|
if (is_exit.ToString() =="0")
|
||||||
{
|
{
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user