begin process at 2012 02 08 13:20:31
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Réseau & internet

 > HTTP FORWARDER

HTTP FORWARDER


 Information sur la source

Note :
Aucune note
Catégorie :Réseau & internet Classé sous :get, http, forward, mitm, proxy Niveau :Débutant Date de création :09/07/2010 Date de mise à jour :10/07/2010 09:52:04 Vu :2 249

Auteur : matad0r

Ecrire un message privé
Commentaire sur cette source (7)
Ajouter un commentaire et/ou une note

 Description

Cliquez pour voir la capture en taille normale
Petit programme en Python qui, utilisé comme un proxy, prend les requêtes "GET" d'un client et télécharge la page concernée avant de la renvoyer au client.

Fonctionnement:
Voir image.

Utilisation:
Lancer l'HTTP Forwarder sur un PC connecté à internet, sur un PC ayant au moins la connexion au réseau local configurer un proxy dans IE ou dans Firefox avec comme adresse l'adresse de l'HTTP Forwarder et comme port le port choisi au démarrage du programme.

Source

  • import socket
  • import sys
  • import http.client
  • import time
  • def getHost(addr): # Fonction pour extraire l'host d'une requête.
  • addr = str(addr)
  • pos1 = addr.find('.')
  • pos1 = pos1 + len(".")
  • addrOk = addr[pos1:]
  • pos2 = addrOk.find("/")
  • addrOk = addrOk[:pos2]
  • return addrOk # Ca retourne la string coupée (ne reste que l'host : http://www.google.com => google.com)
  • def getUrl(addr): # Fonction pour extraire l'URL d'une requête.
  • addr = str(addr)
  • pos1 = addr.find(" ")
  • pos1 = pos1 + len(" ")
  • urlOk = addr[pos1:]
  • pos2 = urlOk.find(" HTTP/1.1")
  • urlOk = urlOk[:pos2]
  • return urlOk # Ca retourne la string coupée (ne reste que l'url : http://xxx.com)
  • def sendBody(body): # Fonction pour envoyer le corps de la page retournée par le serveur
  • try:
  • channel.send(body)
  • return 1
  • except:
  • return 0
  • sys.stdout.write("Listening port : ")
  • port = input()
  • port = int(port)
  • addr = ("", port)
  • sys.stdout.write("Creating socket... ")
  • socketServer = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  • sys.stdout.write("OK !\n")
  • sys.stdout.write("Binding... ")
  • socketServer.bind(addr)
  • sys.stdout.write("OK !\n")
  • print("Listening for requests :")
  • socketServer.listen(1)
  • while 1:
  • channel, details = socketServer.accept()
  • rcvd1 = channel.recv(1024) # Recoit les données de client et le stocke dans rcvd1
  • host = getHost(rcvd1) # Apelle la fonction getHost pour garder que l'host dans la requête qu'on vient de recevoir.
  • print("\nGET Request for :", host)
  • httpConn = http.client.HTTPConnection(host) # On se connecte à l'host extrait de la requête plus haut.
  • print("Asking for the page :", getUrl(rcvd1))
  • try:
  • httpConn.request("GET", getUrl(rcvd1)) # On envoie une requête GET suivie de l'url extraite à l'aide de la fonction getUrl.
  • except:
  • print("Error while requesting the page...")
  • time.sleep(0.5) # Attend une demi seconde pour éviter l'utilisation 100% du cpu
  • try:
  • answer1 = httpConn.getresponse() # Recupere la réponse du serveur
  • except:
  • print("Error while getting response from", host)
  • body = answer1.read() # Lit la reponse
  • httpConn.close() # Ferme la connexion avec le serveur
  • sys.stdout.write("Sending BODY...")
  • if sendBody(body) == 1: # Envoie la réponse du serveur au client.
  • sys.stdout.write("OK !\n")
  • else:
  • sys.stdout.write("ERREUR.\n ")
  • # Et aprés comme c'est une boucle infinie ca repart pour une autre requête
import socket
import sys
import http.client
import time

def getHost(addr):          # Fonction pour extraire l'host d'une requête.
   addr = str(addr)
   pos1 = addr.find('.')
   pos1 = pos1 + len(".")
   addrOk = addr[pos1:]
   pos2 = addrOk.find("/")
   addrOk = addrOk[:pos2]
   return addrOk            # Ca retourne la string coupée (ne reste que l'host : http://www.google.com => google.com)

def getUrl(addr):          # Fonction pour extraire l'URL d'une requête.
   addr = str(addr)
   pos1 = addr.find(" ")
   pos1 = pos1 + len(" ")
   urlOk = addr[pos1:]
   pos2 = urlOk.find(" HTTP/1.1")
   urlOk = urlOk[:pos2]
   return urlOk            # Ca retourne la string coupée (ne reste que l'url : http://xxx.com)

def sendBody(body):    # Fonction pour envoyer le corps de la page retournée par le serveur
   try:
      channel.send(body)
      return 1
   except:
      return 0

sys.stdout.write("Listening port : ")
port = input()
port = int(port)

addr = ("", port)

sys.stdout.write("Creating socket... ")
socketServer = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sys.stdout.write("OK !\n")

sys.stdout.write("Binding... ")
socketServer.bind(addr)
sys.stdout.write("OK !\n")

print("Listening for requests :")
socketServer.listen(1)

while 1:
   channel, details = socketServer.accept()
   rcvd1 = channel.recv(1024)             # Recoit les données de client et le stocke dans rcvd1
   host = getHost(rcvd1)                  # Apelle la fonction getHost pour garder que l'host dans la requête qu'on vient de recevoir.

   print("\nGET Request for :", host)
   httpConn = http.client.HTTPConnection(host) # On se connecte à l'host extrait de la requête plus haut.
   print("Asking for the page :", getUrl(rcvd1))
   try:
      httpConn.request("GET", getUrl(rcvd1)) # On envoie une requête GET suivie de l'url extraite à l'aide de la fonction getUrl.
   except:
      print("Error while requesting the page...")

   time.sleep(0.5) # Attend une demi seconde pour éviter l'utilisation 100% du cpu

   try:
      answer1 = httpConn.getresponse() # Recupere la réponse du serveur
   except:
      print("Error while getting response from", host)
      
   body = answer1.read() # Lit la reponse
   httpConn.close() # Ferme la connexion avec le serveur
   sys.stdout.write("Sending BODY...")
   if sendBody(body) == 1: # Envoie la réponse du serveur au client.
      sys.stdout.write("OK !\n")
   else:
      sys.stdout.write("ERREUR.\n ")
      # Et aprés comme c'est une boucle infinie ca repart pour une autre requête

 Conclusion

Points à améliorer :
- Commenter le code.
- Certaines pages ne se chargent pas. (???)
- Optimisation du code.


 Historique

09 juillet 2010 19:39:41 :
Modification de la description.
10 juillet 2010 09:52:04 :
Code commenté.

 Sources du même auteur

CALCULATRICE (AIDE SUR LES FONCTIONS EN PYTHON)

 Sources de la même categorie

SOCKET MULTITHREAD SIMPLE par Guillamue06
TRANSFERT DE FICHIER PAR SOCKET par Guillamue06
Source avec une capture AUTO-FOLLOW/UNFOLLOW [TWITTER] EN [PERL] UTILISANT NET::TWIT... par GeroXXXX
Source avec Zip PINGEUR RÉSEAU par jeanbleo44
Source avec Zip Source avec une capture LISTING ET LOGS DES CONNEXIONS ET DECONNEXIONS DE MACHINES Q... par saigneurdushi

 Sources en rapport avec celle ci

Source avec Zip Source avec une capture SERVEUR WEB EN PYTHON. par xeolin
[HTTP-CLIENT] - RÉCUPÉRER UNE REQUETE COMPLÈTE SANS PASSER P... par jean84
Source avec Zip SERVEUR HTTP PYTHON par xeolin
UN SIMPLE TRADUCTEUR VIA FREETRANSLATION.COM par Rocco123
Source avec Zip Source avec une capture SERVEUR HTTP/CGI par kedare

Commentaires et avis

Commentaire de aera group le 10/07/2010 10:54:49

Bonjour bonjour,

Justement je cherche depuis des années un code se rapprochant de celui ci (lueur d'espoir :p) ... En fait, je voudrais créer une sorte de par feu sur mon pc.

L'idée, c'est de créer un programme, un peu comme le tient, qui intercepte les requêtes émises ou reçus, les analyse puis si elles sont saines les réexpédies vers leur adresse d'origine. En gros, un serveur comme le tiens mais installer sur un seul PC.

Vois tu ce que je veux dire, et a tu une petite piste à me donnée ?

Commentaire de matad0r le 10/07/2010 12:01:15

C'est une bonne idée, tu peux partir sur ce principe :
Mon code en local, sauf que tu paramètres Windows pour que toutes les requêtes et pas seulement celles du Web Browser y parviennent.
Tu peux créer une fonction pour détecter si la requête est un GET (inspire-toi des miennes), si c'est le cas forward la requête (exactement comme dans mon code), sinon renseigne-toi sur la syntaxe des autres requêtes type SMTP, POP ou Windows (me souviens plus du nom), tu peux les forwarder de la même facon que moi sauf que en plus tu peux ecrire le contenu de la requête.
J'éspère que tu as compris parce que je m'embrouille un peu ^^

Commentaire de aera group le 11/07/2010 19:59:47

Ce que veux savoir c'est comment intercepter les requêtes !!! Je bloque sur ça depuis .... toujours en faite :p. Tu dis qu'il faut paramétrer Windows, ma question et : Comment et quoi faire ?
La détection des requêtes issu d'un navigateur Web est plutôt facile à détecté, ils émettent une entête caractéristique (cf serveur web de Xeolin)

Commentaire de matad0r le 13/07/2010 17:52:01

Attention, je ne "détecte" pas les requêtes ! Je configure Firefox avec mon serveur comme proxy pour qu'il y envoit les requêtes. Pour configurer un proxy "global" de Windows, je pense qu'il faudrait créer une nouvelle interface réseau comme le font les pare-feux...

Commentaire de aera group le 13/07/2010 18:39:31

Je suis d'accord, toi tu configure Firefox ou tout autre navigateur Web pour qu'il redirige la requête vers ton programme serveur proxy.

Ma question est alors, comment créer une nouvelle interface réseau avec Python ?

Commentaire de matad0r le 19/07/2010 16:27:32

Oula.
Aucune idée... Seulement tu peux la créer manuellement je pense ! Ensuite il suffit de créer un proxy...
Google est notre ami. :)

Commentaire de xeolin le 21/08/2010 07:18:11

... Houla !
Je trouve ça domage, il y a trois heu non quatre sources sur pythonfrance qui utilisent le socket avec le threading et toi, bas rien :(

En tout cas l'idée est bonne, ça fonctionne, malgrès que d'attentre .5s par chaque requette est asser inefficace.. Jette un coup d'oeil sur les autre codes, et je te donnerai une notte ensuite : ton code a du potentiel non négligeable, et je t'encourage grandement à y ajouter du multithreading !

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

au sujet de Tkinter et le module turtle [ par nico1900 ] from turtle import *forward(120)left(90) color('red') forward(80)bon en fait je voulais tester le module turtle avec l e code ci-d Bittorent Source [ par 0mega ] Bonjour a tous ! J'essaie en vain de compiler la source du dernier client bittorent (python 2.4) mais sans succés. Voici le read-me inclus av Il me manque une librairie [ par cipher16 ] Bonjour ... je viens de commencer à coder en python ... et il semblerai qu'il me manque une librairie ayant un rapport avec internet ... J'ai che DLA - mouvement de brown [ par loper ] salut, ben jai un petit sousis, je dois réaliser un programme en Numeric python ki représente le mouvement des particules. ci-joint je vous Lancer un script python [ par Zaltez ] Bonjour à toutes et tous,Je me decide a poser la question sur ce forum après avoir essayer plusieurs solution expliqué sur internet sans résultat. En Serveur Proxy [ par aera group ] Bonjour,Je souhaiterais développer un logiciel de control parental, et j'ai pensé pour cella créé un serveur proxy et je voudrais savoir si quelqu'un prob. module turtle [ par kechor ] from turtle import* forward(120) left(90) color('red') forward(80) bonjour, j'utilise python ver.2.4 voici le code que j'ai recopié d'après le livre Extraire des informations d'un fichier texte [ par med93100 ] Bonjour la compagnie , Je tiens deja à vous dire que je suis débutant en python , donc mon prolbème est la , j'ai un texte avec plein de code html pa python & http [ par olobo ] Bonjour! J'aimerais savoir si en python il est possible de recuperer par le biais du port 80 les requettes http faite a partir du browser (firefox ou Envoi de fichier sur ftp avec un proxy [ par tititoss91 ] Bonjour, je suis en train de réaliser un projet qui permet de récupérer un fichier dans un répertoire, de le zipper et ensuite de l'envoyer sur un ser


Nos sponsors


Sondage...

CalendriCode

Février 2012
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
272829    

Consulter la suite du CalendriCode

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 4,150 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales