begin process at 2012 02 09 19:23:05
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Réseaux & Internet

 > VÉRIFIER SI L'ON A DES MAILS

VÉRIFIER SI L'ON A DES MAILS


 Information sur la source

Note :
9 / 10 - par 3 personnes
9,00 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
Catégorie :Réseaux & Internet Classé sous :courriel, pop3, vérifier, serveur, mail Niveau :Débutant Date de création :30/01/2004 Date de mise à jour :19/12/2005 16:51:37 Vu :6 194

Auteur : CyberP

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

 Description

Voilà une petite fonction permettant de vérifier si l'on a des mails. J'ai pondu cette petite fonction pour les besoins d'un autre programme, je n'ai donc pas le temps ni l'envie de l'améliorer... Si quelqu'un veut l'améliorer, voici la liste des commandes d'un serveur POP3 :

USER identifiant
  Cette commande permet de s'authetifier. Elle doit être suivie du nom de l'utilisateur, c'est-à-dire une chaiîne de caractères identifiant l'utilisateur sur le serveur. La commande USER doit précéder la commande PASS.

PASS mot_de_passe
  La commande PASS, permet d'indiquer le mot de passe de l'utilisateur dont le nom a été spécifié lors d'une commande USER préalable.

STAT Information sur les messages contenus sur le serveur
RETR Numéro du message à récupérer
DELE Numéro du message à supprimer
LIST [msg] Numéro du message à afficher
NOOP Permet de garder les connexion ouverte en cas d'inactivité

TOP <messageID> <n>
  Commande affichant n lignes du message, dont le numéro est donné en argument. En cas du réponse positive du serveur, celui-ci renvoie les en-têtes du message, puis une ligne vierge et enfin les n premières lignes du message.

UIDL [msg]
   Demande au serveur de renvoyer une ligne contenant des informations sur le message éventuellement donné en argument. Cette ligne contient une chaîne de caractères, appelée listing d'identificateur unique, permettant d'identifier de façon unique le message sur le serveur, indépendamment de la session. L'argument optionnel est un numéro correspondant à un message existant sur le serveur POP, c'est-à-dire un message non effacé).  

QUIT
  La commande QUIT demande la sortie du serveur POP3. Elle entraîne la suppression de tous les messages marqués comme effacés et renvoie l'état de cette action.

Source

  • char* CheckMail(char* login, char* password, char* server, int port) {
  • SOCKET sock;
  • char* user = new char[1024];
  • strcpy(user, "USER ");
  • char* pass = new char[1024];
  • strcpy(pass, "PASS ");
  • strcat(user, login);
  • strcat(user, "\r\n");
  • strcat(pass, password);
  • strcat(pass, "\r\n");
  • WSADATA wsaData;
  • WSAStartup(0x0101, &wsaData);
  • struct sockaddr_in serverSockAddr;
  • long hostAddr;
  • sock = NULL;
  • hostAddr = inet_addr(server);
  • if (hostAddr != -1)
  • memcpy(&serverSockAddr.sin_addr, &hostAddr, sizeof(hostAddr));
  • else {
  • struct hostent* serverHostEnt;
  • serverHostEnt = gethostbyname(server);
  • if (serverHostEnt == NULL)
  • return false;
  • memcpy(&serverSockAddr.sin_addr, serverHostEnt->h_addr, serverHostEnt->h_length);
  • }
  • serverSockAddr.sin_port = htons(port);
  • serverSockAddr.sin_family = AF_INET;
  • sock = socket(AF_INET, SOCK_STREAM, 0);
  • if (sock < 0)
  • return false;
  • int not = 0;
  • setsockopt(sock, SOL_SOCKET, SO_DONTLINGER, (char *)&not, sizeof(not));
  • if (connect(sock, (struct sockaddr*)&serverSockAddr, sizeof(serverSockAddr)) < 0)
  • return false;
  • unsigned long ioctl_blocking = 1;
  • ioctlsocket(sock, FIONBIO, &ioctl_blocking);
  • char buf[1024];
  • buf[0] = 0x00;
  • while (!buf[0])
  • recv(sock, buf, 1024, 0);
  • char* result = new char[32];
  • for (int i = 0; i < 4; i++) {
  • char* buffer = new char[sizeof(user)];
  • switch (i) {
  • case 0: strcpy(buffer, user); break;
  • case 1: strcpy(buffer, pass); break;
  • case 2: strcpy(buffer, "STAT\r\n"); break;
  • case 3: strcpy(buffer, "QUIT\r\n"); break;
  • }
  • Sleep(1000);
  • send(sock, buffer, strlen(buffer), 0);
  • char buf[1024];
  • buf[0] = 0x00;
  • while (!buf[0])
  • buf[recv(sock, buf, 1024, 0)] = '\0';
  • if (i == 2) {
  • if (buf[0] == '+' && buf[1] == 'O' && buf[2] == 'K') {
  • for (int i = 4; buf[i] != ' '; i++);
  • result[i - 3] = '\0';
  • for (; i >= 4; i--) result[i - 4] = buf[i];
  • } else {
  • strcpy(result, "0");
  • }
  • }
  • }
  • shutdown(sock, 2);
  • return result;
  • }
char* CheckMail(char* login, char* password, char* server, int port) {
	SOCKET sock;

	char* user = new char[1024];
	strcpy(user, "USER ");
	char* pass = new char[1024];
	strcpy(pass, "PASS ");

    strcat(user, login);
	strcat(user, "\r\n");
    strcat(pass, password);
	strcat(pass, "\r\n");

	WSADATA wsaData;
	WSAStartup(0x0101, &wsaData);

    struct sockaddr_in serverSockAddr;
    long hostAddr;

    sock = NULL;
	hostAddr = inet_addr(server);

	if (hostAddr != -1)
		memcpy(&serverSockAddr.sin_addr, &hostAddr, sizeof(hostAddr));
    else {
		struct hostent* serverHostEnt;
        serverHostEnt = gethostbyname(server);
        if (serverHostEnt == NULL)
			return false;
		memcpy(&serverSockAddr.sin_addr, serverHostEnt->h_addr, serverHostEnt->h_length);
	}

    serverSockAddr.sin_port = htons(port);
    serverSockAddr.sin_family = AF_INET;

    sock = socket(AF_INET, SOCK_STREAM, 0);
    if (sock < 0)
		return false;

	int not = 0;
    setsockopt(sock, SOL_SOCKET, SO_DONTLINGER, (char *)&not, sizeof(not));

    if (connect(sock, (struct sockaddr*)&serverSockAddr, sizeof(serverSockAddr)) < 0)
		return false;

	unsigned long ioctl_blocking = 1;
    ioctlsocket(sock, FIONBIO, &ioctl_blocking);

	char buf[1024];
	buf[0] = 0x00;
	while (!buf[0])
		recv(sock, buf, 1024, 0);

	char* result = new char[32];

	for (int i = 0; i < 4; i++) {
		char* buffer = new char[sizeof(user)];
		switch (i) {
			case 0: strcpy(buffer, user); break;
			case 1: strcpy(buffer, pass); break;
			case 2: strcpy(buffer, "STAT\r\n"); break;
			case 3: strcpy(buffer, "QUIT\r\n"); break;
		}
		Sleep(1000);
		send(sock, buffer, strlen(buffer), 0);

		char buf[1024];
		buf[0] = 0x00;
		while (!buf[0])
			buf[recv(sock, buf, 1024, 0)] = '\0';

		if (i == 2) {
			if (buf[0] == '+' && buf[1] == 'O' && buf[2] == 'K') {
				for (int i = 4; buf[i] != ' '; i++);
				result[i - 3] = '\0';
				for (; i >= 4; i--) result[i - 4] = buf[i];
			} else {
				strcpy(result, "0");
			}
		}
	}

    shutdown(sock, 2);
    
    return result;
}

 Conclusion

#include <windows.h> et ws2_32.lib nécessaires

Exemple d'utilisation :

MessageBox(NULL, CheckMail(nom_dutilisateur, mot_de_passe, pop3.wanadoo.fr, 110), "Messages en attente", NULL);


 Historique

19 décembre 2005 16:51:37 :
Ajout de mots clés

 Sources du même auteur

Source avec Zip Source avec une capture DÉBUT DE MOTEUR 3D
Source avec Zip Source avec une capture PROGRAMME DE CHAT À PLUSIEURS ASSEZ COMPLÊT [VC++ 6]

 Sources de la même categorie

Source avec Zip SERVEUR MULTITHREAD [LINUX/WIN] par nipepsinicolas
Source avec Zip Source avec une capture SECURE REMOTE SHELL [WIN32] par ganjarasta
Source avec Zip Source avec une capture SUIVI DE PRODUCTION ONDULEUR PHOTOVOLTAÏQUE SOLARMAX par brunovan
Source avec Zip MINICHAT MULTI-CLIENT par wisar
SOCKET CPP par baptchr55

 Sources en rapport avec celle ci

Source avec Zip Source avec une capture SECURE REMOTE SHELL [WIN32] par ganjarasta
Source avec Zip MINICHAT MULTI-CLIENT par wisar
Source avec Zip Source avec une capture CLIENT/SERVEUR UTILISANT LES IOCP RÉALISÉ AVEC BORLAND BUILD... par goodboy21
Source avec Zip SERVEUR/CLIENT LINUX par ghost4
RECUPERER LE DNS DU SERVEUR MX MAIL D'UNE ADRESSE EMAIL par darkpoulpo

Commentaires et avis

Commentaire de LordBob le 22/03/2006 23:57:51

salut, je viens de tester ta source. et je n'arrive jamais a aller plus loin que le connect(), t'aurrais pas une explication, je suis sous VC2005 !

Commentaire de CyberP le 23/03/2006 17:33:30

euh désolé je n'ai pas VC2005 donc je ne sais pas s'il y a une explication logique à cela
sinon essaye de débugger pour voir pourquoi ça ne marche pas
essaye un autre code qui utilise ce genre de fonctions pour voir si c'est bien à cause de ce code que ça ne marche pas ou si c'est un problème dû au pc

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

Serveur mail [ par PunkDude424 ] Salut, je me suis fait un petit serveur de mail, je suis capable de le faire tourner sur ma machine et ainsi permetttre au autre utilisateur de mon ré serveur POP3 [ par djjej ] Bonjour à tous!Je voudrais savoir si quelqu'un sait ou je peux trouver un code source(en C ou en java) pour un serveur POP3.Merci Vérification d'une adresse e-mail [ par Kaneda Shotaro ] Quelqu'un a-t'il une fonction&nbsp; qui permette de v&#233;rifier sir une adresse mail est valide (sans v&#233;rifier qu'elle existe r&#233;ellement) envoyer un mail en VC++ par SMTP [ par amizak ] Bonjour tt le monde.je developpe un eapplication pour l'envoie des email avec VC++ en utilisant le protocole smtp.j'utilise ma machine en tant que ser [MFC]-Serveur MAIL [ par donslim ] Bonjour à tous,Voilà,je vous explique mon gros problème. Je dois créer un programme accédant à une boîte mail pour vérifier les mails recu. Le serveur récupérer la pièce jointe d'un mail avec pop3 [ par mailer ] Bonjour, J'ai d&#233;velopp&#233; une application C++ qui envoi et r&#233;cup&#232;re des mails avec SMTP/POP3. Lors de l'envoi, je code mes pi&#232; Client Mail pop3 avec piece-jointe [ par cartes1 ] Bonjour Quelle est la différence entre la réception Pop3 du corps de texte d'un message et la reception d'une piece-jointe: en effet les codes-sources script shell d' envoi log par mail [ par Negritson ] Bonjour à tous, Je voudrais envoyer directement par mail les logs d'erreurs d'un fichier sur lequel ecrivent d'autres programmes. Voila mon script: # connecter un serveur domino en c [ par wassimbazmi ] Bonjour tout le monde, Quelqu'un pourrait il me dire quel API C utiliser pour pouvoir me connecter à un serveur domino dans le but de faire une ap aide creation serveur t'chat [ par crazygoth ] Bonjour Je dois réaliser un projet qui consiste a faire un serveur de t'chat en c sous Linux. je précise que je débute sous Linux et c également. Ma


Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Février 2012
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
272829    

Consulter la suite du CalendriCode

Photothèque

 
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 : 1,825 sec (3)

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