Articles Taggés ‘bot’

Mon apprentissage de python avec Ogame ^^

3 décembre 2009

The kikoolol strike back !! Mon deuxième billets de la soirée …pour pas grand chose en fait.

J’ai voulu apprendre le langage python de façon plutôt ludique en créant un bot qui créer des batiments en boucle pour Ogame … rien d’illégal bien entendu ^^.
Dans le code Python qui va suivre, vous pourrez comprendre (ou pas) comment fonctionne :

  • Les requêtes HTTP en python avec des headers à partir de zéro
  • Les Threads pour les opérations en parallèle
  • Les Semaphores, pour éviter des requêtes en parallèle (pas apprécié par Ogame dans certain cas)

Pour l’utiliser, il suffit ensuite d’ajouter au source qui vont suivre :

  1. og = Ogame()
  2. og.setSessionCookie(
  3.  "le contenu du cookie phpsessid de votre univers",
  4.  "le contenu du cookie prssess de votre univers",
  5.  "le contenu du cookie loginC de votre univers",
  6.  "le parametre de l'url &session=…",
  7.  "uniXX.ogame.fr"votre#univers
  8. )
  9. Farmer.buildInChainsPlanets(og,["id planete","id planete"],[[4,1,2,4,1,2,4,1,2,4],[4,1,2,4,1,2,4,1,2,4]])

le premier paramètre de buildInChainsPlanets est l’objet og
le second est un tableau de string contenant l’id des planètes à « farmer »
le troisième est un tableau de tableau contenant les séquences des batiments à construire :
1 pour le metal 2 pour le cristal 3 pour le deuterium 4 pour l’electricite.

Et voilà … lorsque vous aurez conquis une planète rajoutez-là au tableau ainsi que la séquence de batiments que vous voulez, puis laissez tourner le script plusieurs jours (faite gaffe avec les sessions qui risque de changer si vous vous reconnectez avec votre navigateur).
» En lire plus:Mon apprentissage de python avec Ogame ^^

Exemple de Bot d’Authentification et de clic en Php

20 octobre 2009

Bonjour à tous …

Aujourd’hui ze bot « cliqueur » ^^, il s’agit en fait d’un bot qui s’authentifie en POST, récupère le cookie et va en get sur un lien (le clic quoi).

A quoi ça peut bien servir ?

Pour ma part, c’était pour récupérer une clé pour la closed beta de HON (un Dota avec des binaires pour linux, fallait pas rater ça!!) sur le site de Alienware, le problème, c’est que les clés étaient censé être disponible soit très tard dans la soirée, soit très tôt dans la matinée, et comme je n’aimais pas l’idée de rester sur le site à poireauter, j’ai fait ce que tout programmeurs auraient fait ^^, un sympatique script …

Les actions à faire étaient :

  1. Regarder sur le site si le nombre de clés disponibles étaient supérieur à 0
  2. S’authentifier
  3. Récupérer les clés

Ce qui donne donc le script suivant en tâche Cron toutes les 5 minutes (fallait juste pas oublier de couper le script après réception des clés ^^) :

  1. <?php
  2. define("USERNAME","login");
  3. define("PASSWORD","pass");
  4. define("MAILADRES","mail@mail.com");
  5. $stringLoginPost="username=".USERNAME."&password=".PASSWORD;
  6.  
  7. /***********************************************DO NOT TOUCH**************************************************/
  8. $hon = file_get_contents("http://www.alienwarearena.com/event/hon-beta-giveaway/");
  9.  
  10. preg_match('|<h3[^>]*>Closed Beta Keys Remaining</h3>[\W\w]*<h1[^>]*>([0-9]+)</h1>|iU',$hon,$retour);
  11.  
  12. if($retour[1]!=0)
  13. {
  14.  $socket = socket_create(AF_INET, SOCK_STREAM, 0) or die("Could not create socket\n");
  15.  if(socket_connect($socket,"www.alienwarearena.com","80"))
  16.  {
  17.  //La requete de post pour ce logger
  18.   $postReq = "POST /cmd/account/login/ HTTP/1.1\r\n";
  19.   $postReq.= "Host: www.alienwarearena.com\r\n";
  20.   $postReq.= "Connection: Keep-Alive\r\n";//comme ça on se reconnecte direct ;) Pipelinning ROXX!!
  21.   $postReq.= "Content-type: application/x-www-form-urlencoded\r\n";
  22.   $postReq.= "Content-Length: ".strlen($stringLoginPost)."\r\n\r\n";
  23.   $postReq.= $stringLoginPost."\r\n";
  24.   socket_write($socket,$postReq);
  25.   socket_recv($socket,$retour,1024,0);
  26.  //la récupération de la valeur du cookie
  27.   preg_match("#Set-Cookie: PHPSESSID=([^;]*); path=/#",$retour,$tabRet);
  28.  //On va à la page de récupération des clés ^^
  29.   $getReq = "GET /cmd/account/get-beta-key/hon/ HTTP/1.1\r\n";
  30.   $getReq.= "Host: www.alienwarearena.com\r\n";
  31.   $getReq.= "Cookie: PHPSESSID=".$tabRet[1]."\r\n";
  32.   $getReq.= "Connection: Close\r\n\r\n";
  33.   socket_write($socket,$getReq);
  34.   socket_recv($socket,$retour,1024,0);
  35.  
  36.   mail(MAILADRES,"HON KEY!!","You got an HON KEY : ".$retour);
  37.  }
  38.         socket_close($socket);
  39. }
  40. ?>

Donc voilà … le script reste une idée (qui a fonctionné dans mon cas) à modifier selon les cas, avec curl ça aurait été plus court, mais faire mumuse avec les sockets ça n’a pas de prix …