这是套接字的另一个问题。
我正在为C#中的游戏制作机器人,到目前为止,我可以让它们进行连接以及类似的一切,但它只是在同一个套接字上同时连接多个帐户。我想我可以通过线程化包含socket.connect()函数的函数来做到这一点,然后将数据包发送到服务器。我甚至查看了过去的python脚本,它基本上做了同样的事情。
以下是Python代码的示例:
if bots["loaded"] < b0ts:
bots["accounts"][acc[0]] = acc[1].replace("\n", "")
bot_thread = threading.Thread(target=self.verify_bot, args=(acc[0],))
bot_thread.start()
基本上我会尝试将其转换为C#,认为它会起作用。但另一方面,几乎所有函数在几乎所有编程语言中都是不同的。
以下是我在C#中为线程部分编写的代码,我出于某种原因使用了后台工作程序,但我也认为这不是它不工作的原因,为什么不呢。
Thread t;
private void backgroundWorker2_DoWork(object sender, DoWorkEventArgs e)
{
for(int i = 0; i <= acc.Items.Count - 1; i++)
{
if(backgroundWorker2.CancellationPending == true)
{
e.Cancel = true;
break;
}
else
{
t = new Thread(() => verify_bots(acc.Items[i].ToString().Split(':')[0], acc.Items[i].ToString().Split(':')[1]));
t.Start();
}
}
}
分组是偶然用于用户名和密码,以防万一有人对它感到困惑。无论如何,只有1个机器人仍然连接,然后我从套接字中得到一个错误,因为它之前已经通过一个连接或类似我认为的东西连接了。
这就是我的问题所在,因为它在python中运行良好,通常我尝试转换为C#的东西都有效。这是verify_bots函数,因此有人可能更容易弄明白。
private void verify_bots(string username, string password)
{
CheckForIllegalCrossThreadCalls = false;
string login_data = string.Format("userID={0}&password={1}", username, password);
ASCIIEncoding encoding = new ASCIIEncoding();
byte[] data = encoding.GetBytes(login_data);
HttpWebRequest request;
request = (HttpWebRequest)WebRequest.Create("https://www.binweevils.com/login");
getTick(request); // getting cookies
request.Method = "POST";
request.KeepAlive = true;
request.UserAgent = "1337JjsHd";
request.CookieContainer = logincookie;
request.ContentType = "application/x-www-form-urlencoded";
request.ContentLength = data.Length;
Stream stream;
stream = request.GetRequestStream();
stream.Write(data, 0, data.Length);
stream.Close();
HttpWebResponse response;
response = request.GetResponse() as HttpWebResponse;
StreamReader responsereader;
responsereader = new StreamReader(response.GetResponseStream());
string final = responsereader.ReadToEnd();
if(final.Contains("register.php"))
{
console.Text = console.Text + username+" Failed!\n";
}
else
{
string post = "";
ASCIIEncoding encoding1 = new ASCIIEncoding();
byte[] data1 = encoding1.GetBytes(post);
request = (HttpWebRequest)WebRequest.Create("https://lb.binweevils.com/php2/weevil/get-login-details.php");
request.Method = "POST";
request.KeepAlive = true;
request.UserAgent = "1337JjsHd";
request.CookieContainer = logincookie;
request.ContentType = "application/x-www-form-urlencoded";
request.ContentLength = data1.Length;
stream = request.GetRequestStream();
stream.Write(data1, 0, data1.Length);
stream.Close();
response = request.GetResponse() as HttpWebResponse;
responsereader = new StreamReader(response.GetResponseStream());
final = responsereader.ReadToEnd();
try
{
string[] a = new string[] { "loginKey=" };
var aa = final.Split(a, StringSplitOptions.None);
logkey = aa[1].ToString();
gethash(@"C:\Python27\hash.py", logkey);
}
catch(Exception)
{
console.Text = console.Text + "Failed to get loginkey.\n";
}
sock.Connect(ip, port);
byte[] recv = new byte[2048];
sendRawPackets(sock, "<policy-file-request/>");
sock.Receive(recv);
sendRawPackets(sock, "<msg t='sys'><body action='verChk' r='0'><ver v='154' /></body></msg>");
sock.Receive(recv);
if(ip.Contains("sfs1"))
{
sendRawPackets(sock, "<msg t='sys'><body action='login' r='0'><login z='Grime'><nick><![CDATA[" + username + "]]></nick><pword><![CDATA["+logkey+"]]></pword></login></body></msg>");
}
else
{
sendRawPackets(sock, "<msg t='sys'><body action='login' r='0'><login z='Slime'><nick><![CDATA[" + username + "]]></nick><pword><![CDATA[" + logkey + "]]></pword></login></body></msg>");
}
sock.Receive(recv);
sendRawPackets(sock, "%xt%login%1#2%-2");
sock.Receive(recv);
sendRawPackets(sock, "%xt%login%2#6%-1%");
sock.Receive(recv);
sendRawPackets(sock, "%xt%login%2#7%17610%69%0,-255,190%");
sock.Receive(recv);
sendRawPackets(sock, "%xt%login%2#4%3150%FlumsFountain%52.9941101744771%0%989.1726320236921%-180%0%190%");
sock.Receive(recv);
string[] move = { "%xt%login%2#1%23%-62%892%66%", "%xt%login%2#1%23%-28%1102%146%", "%xt%login%2#1%23%133%924%-48%", "%xt%login%2#1%23%-39%882%57%", "%xt%login%2#1%23%-39%882%57%", "%xt%login%12#2%23%", "%xt%login%12#2%23%", "%xt%login%2#1%23%54%1002%137%", "%xt%login%2#1%23%-28%934%84%", "%xt%login%2#1%23%144%994%-126%", "%xt%login%2#1%23%84%1118%-177%", "%xt%login%2#1%23%-85%1032%110%", "%xt%login%2#1%23%-34%941%70%", "%xt%login%2#1%23%20%876%17%", "%xt%login%2#1%23%76%951%-79%", "%xt%login%2#1%23%92%999%-133%", "%xt%login%2#1%23%-52%1108%142%", "%xt%login%2#1%23%-92%1045%116%", "%xt%login%2#1%23%19%893%13%", "%xt%login%2#1%23%-84%914%64%", "%xt%login%2#1%23%-19%859%23%", "%xt%login%2#1%23%136%1061%-139%", "%xt%login%2#1%23%91%966%-117%", "%xt%login%2#1%23%63%1086%-156%", "%xt%login%2#1%23%120%1060%-139%", "%xt%login%2#1%23%110%938%-107%", "%xt%login%2#1%23%-84%872%69%", "%xt%login%2#1%23%-117%1045%141%", "%xt%login%2#1%23%-36%961%151%", "%xt%login%2#1%23%72%920%-97%", "%xt%login%2#1%23%117%894%-82%", "%xt%login%2#1%23%32%865%-29%", "%xt%login%2#1%23%-45%889%80%", "%xt%login%2#1%23%-122%1068%141%", "%xt%login%2#1%23%15%1093%-178%", "%xt%login%2#1%23%72%1098%-161%", "%xt%login%2#1%23%83%994%-135%" };
while(true)
{
sendRawPackets(sock, move[new Random().Next(0, move.Length)]); // making bot move around in area
sock.Receive(recv);
Thread.Sleep(5000);
}
}
}
答案 0 :(得分:0)
在for
循环完成i == acc.Items.Count - 1
之前,线程需要相当长的时间才能启动。这意味着每个线程都使用acc.Items[acc.Items.Count - 1]
,因此&#34;在同一个套接字上同时连接多个帐户&#34;。
简单的解决方法是:
for(int i = 0; i <= acc.Items.Count - 1; i++)
{
if(backgroundWorker2.CancellationPending == true)
{
e.Cancel = true;
break;
}
else
{
int a_copy_of_i = i;
t = new Thread(() => verify_bots(acc.Items[a_copy_of_i].ToString().Split(':')[0], acc.Items[a_copy_of_i].ToString().Split(':')[1]));
t.Start();
}
}
答案 1 :(得分:0)
已经把一切都搞清楚了。好像每次我被某个项目困在某事上,我最后迟早会把它弄清楚:)))))
非常感谢。