Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

VÉRIFIER SI L'ON A DES MAILS


Information sur la source

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 : 4 916

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

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

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

Commentaires et avis

signaler à un administrateur
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 !

signaler à un administrateur
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; Deconnection serveur en C [ par lenneth666 ] Bonjour j'ai fais un client serveur avec une connection TCP. J'aimerais savoir comment l'on peut g&#233;rer la d&#233;connection d'un client ? Il y a select en C [ par lenneth666 ] voil&#224; j'ai fais un serveur tout marche parfaitement a part que j'aimerais savoir qd qq'un se connecte au serveur. Donc il faut faire un selec un serveur unix configure des client windows avec les rpc [ par oussssa ] &nbsp;bonjour :mon probleme c'est de faire un serveur unix qui va executer des prg ecrite en c# qui controle&nbsp; et configures les @ ip, journal d'e serveur unix communique avec des clients windows en audio& video>>>>>> svp trés urgent [ par oussssa ] bonjour :s'il vous plait est ce que vous pouvez m'aider a faire un petit serveur unix qui peut controler et communiquer avec des clients &nbsp;windows


Nos sponsors

Sondage...

CalendriCode

Juillet 2009
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
2728293031  

Consulter la suite du CalendriCode

Téléchargements

Comparez les prix Nouvelle version


HTC G1

Entre 449€ et 449€


Photothèque Nouveau !



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
Temps d'éxécution de la page : 0,499 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.