begin process at 2012 05 27 17:59:42
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

E-Mail / Messagerie

 > [PHP5][POO][IMAP] UNE CLASSE POUR LIRE DES MAILS EN IMAP DEPUIS UNE BAL EXISTANTE.

[PHP5][POO][IMAP] UNE CLASSE POUR LIRE DES MAILS EN IMAP DEPUIS UNE BAL EXISTANTE.


 Information sur la source

Note :
10 / 10 - par 1 personne
10,00 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
Catégorie :E-Mail / Messagerie Classé sous :messagerie, imap, php5, poo Niveau :Initié Date de création :23/04/2006 Date de mise à jour :23/04/2006 21:59:49 Vu :9 612

Auteur : Nifhell

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

 Description

Cliquez pour voir la capture en taille normale
Bonjour,

Voilà une petite classe, largement inspiré de plusieurs autres codes, qui permet de:

- Se connecter à sa boîte mail en imap.
- De récupérer les entêtes des messages.
- De lire un message.

Prérequis:
Vous devez compiler PHP avec l'option --with-imap[=DIR], où DIR est le préfixe de l'installation du client C.
La pluspart des hébergeurs désactivent cette fonctionnalité, pour des raisons de sécurité.
(Je ne suis pas aller plus loin dans mon dev à cause de ça, chez free la fonction n'est pas activée)
Avantage:
Tout est centralisé.
Défaut:
Ne lis pas les pièces jointes: ça marche pô... (mais je sais pas trop pourquoi...)

Source

  • class CImap {
  • public $m_host = null;
  • public $m_login = null;
  • public $m_pass = null;
  • public $m_port = null;
  • public $m_service = null;
  • public $m_folder = null;
  • public $m_flags = null;
  • public $m_debug = true;
  • protected $m_mailboxes = null;
  • protected $m_stream = null;
  • protected $m_headers = null;
  • protected $m_headersinfo = null;
  • protected $m_overview = null;
  • /**
  • * @desc Constructeur par valeurs.
  • * @param string $host
  • * @param string $login
  • * @param string $pass
  • * @param int $port = 143
  • * @param string $service = "imap"
  • * @param string $folder = "INBOX"
  • * @param string $flags
  • */
  • function CImap($host,$login,$pass,$port=143,$service="imap",$folder="INBOX",$flags="") {
  • if(empty($host) && empty($login) && empty($pass)) {
  • throw new Exception(__CLASS__."<hr><br>Fatal error: You should specify the host, the login and the password for the CImap constructor");
  • }
  • else {
  • $this->m_host = $host;
  • $this->m_login = $login ;
  • $this->m_pass = $pass ;
  • $this->m_port = $port ;
  • $this->m_service = $service ;
  • $this->m_folder = imap_utf7_encode($folder);
  • $this->m_flags = $flags ;
  • }
  • }
  • /**
  • * @desc Met l"attribut $m_folder à la valeur $folder
  • * permet de lire les emails contenu dans le dossier $folder.
  • * @param string $folder = "INBOX"
  • */
  • public function setFolder($folder = "INBOX") {
  • $this->m_folder = imap_utf7_encode($folder);
  • }
  • /**
  • * @desc renvoie la dernière erreur.
  • * @return string
  • * @param <empty>
  • */
  • public function error() {
  • $error = imap_last_error();
  • if(empty($error)) return false;
  • else return $error;
  • }
  • /**
  • * @desc Ouvre un flux imap sur le serveur $m_host authentifié en tant que $m_login avec $m_pass
  • * renvoie faux si une erreur d"ouverture de flux apparait, sinon renvoie le flux ouvert.
  • * @return resource
  • * @param <empty>
  • */
  • public function open_stream() {
  • $this->m_stream = null;
  • if($this->m_debug) $this->m_stream = imap_open("{".$this->m_host.":".$this->m_port."/".$this->m_service.$this->m_flags."}".$this->m_folder,$this->m_login,$this->m_pass);
  • else $this->m_stream = @imap_open("{".$this->m_host.":".$this->m_port."/".$this->m_service.$this->m_flags."}".$this->m_folder,$this->m_login,$this->m_pass);
  • return $this->m_stream;
  • }
  • /**
  • * @desc ferme le flux imap $m_stream
  • * renvoie faux si une erreur de fermeture de flux apparait, sinon renvoie le flux ouvert.
  • * @return bool
  • * @param <empty>
  • */
  • public function close_stream() {
  • if($this->m_debug) return imap_close($this->m_stream);
  • else return @imap_close($this->m_stream);
  • }
  • /**
  • * @desc Ouvre un flux imap sur le serveur $m_host authentifié en tant que $m_login avec $m_pass
  • * renvoie faux si une erreur d"ouverture de flux apparait, sinon renvoie le flux ouvert.
  • * @return array
  • */
  • public function mailbox_list() {
  • $this->m_mailboxes = null;
  • if($this->m_debug) $mailboxes = imap_list($this->m_stream,"{".$this->m_host.":".$this->m_port."/".$this->m_service.$this->m_flags."}","*");
  • else $mailboxes = @imap_list($this->m_stream,"{".$this->m_host.":".$this->m_port."/".$this->m_service.$this->m_flags."}","*");
  • for($i=0;$i<sizeof($mailboxes);$i++) {
  • $ar = spliti("{".$this->m_host.":".$this->m_port."/".$this->m_service.$this->m_flags."}",imap_utf7_decode($mailboxes[$i]));
  • $this->m_mailboxes[$i] = $ar[1];
  • }
  • return $this->m_mailboxes;
  • }
  • /**
  • * @desc Retourne les en-têtes de tous les messages d"une boîte aux lettres, si pas de message renvoie faux
  • * @param <empty>
  • * @return array
  • */
  • protected function headers() {
  • $this->m_headers = null;
  • if($this->m_debug) $this->m_headers = imap_headers($this->m_stream);
  • else $this->m_headers = @imap_headers($this->m_stream);
  • return $this->m_headers;
  • }
  • /**
  • * @desc Lit un sommaire des en-têtes de messages
  • * @param int $msgno = null
  • * @return array
  • */
  • public function overview($msgno = null) {
  • $this->m_overview = null;
  • if($this->headers()) {
  • if(is_null($msgno)) {
  • if($this->m_debug) $overview = imap_fetch_overview($this->m_stream, "1:".sizeof($this->m_headers), 0);
  • else $overview = @imap_fetch_overview($this->m_stream, "1:".sizeof($this->m_headers), 0);
  • while(list($key,$val) = each($overview)) {
  • $i = sizeof($this->m_overview);
  • $this->m_overview[$i] = $val;
  • }
  • }
  • else {
  • if($this->m_debug) $overview = imap_fetch_overview($this->m_stream,$msgno, 0);
  • else $overview = @imap_fetch_overview($this->m_stream, $msgno, 0);
  • list($key,$val) = each($overview);
  • $this->m_overview = $val;
  • }
  • }
  • return $this->m_overview;
  • }
  • /**
  • * @desc Retourne les informations des en-têtes des messages sous forme d"un tableau d"objet.
  • * @param int $msgno = null
  • * @return array
  • */
  • public function headerinfo($msgno = null) {
  • $this->m_headersinfo = null;
  • if($this->headers()) {
  • if(is_null($msgno)) {
  • while (list ($key,$val) = each ($this->m_headers)) {
  • $i = sizeof($this->m_headersinfo);
  • if($this->m_debug) $this->m_headersinfo[$i] = imap_headerinfo($this->m_stream, $key+1);
  • else $this->m_headersinfo[$i] = @imap_headerinfo($this->m_stream, $key+1);
  • }
  • }
  • else {
  • if($this->m_debug) $this->m_headersinfo = imap_headerinfo($this->m_stream, $msgno);
  • else $this->m_headersinfo = @imap_headerinfo($this->m_stream, $msgno);
  • }
  • }
  • return $this->m_headersinfo;
  • }
  • /**
  • * @desc Récupère le corps du message numero $msgno en TEXT/HTML ou en TEXT/PLAIN.(pas les pieces jointes)
  • * @param int $msgno
  • * @return string
  • */
  • public function get_part($msgno){
  • $this->open_stream();
  • if($this->m_debug) $struct = imap_fetchstructure($this->m_stream,$msgno);
  • else $struct = @imap_fetchstructure($this->m_stream,$msgno);
  • $parts = $struct->parts;
  • if ($struct->type) {
  • for ($x=0;$x<sizeof($parts);$x++) {
  • $ttype = $parts[$x]->type;
  • if ($ttype == 1) {
  • # Multipart in multipart
  • $sparts = $parts[$x]->parts;
  • for ($c=0;$c<sizeof($sparts);$c++) {
  • if (!$sparts[$c]->type && empty($sparts[$c]->disposition)) {
  • if (strpos($sparts[$c]->subtype,"html")) {
  • # HTML
  • $part_needed = ($x + 1) . "." . ($c + 1);
  • $part_encoding = $sparts[$c]->encoding;
  • $html_entity = 1;
  • }
  • elseif (strpos($sparts[$c]->subtype,"plain")) {
  • # Plain text
  • $part_needed = ($x + 1) . "." . ($c + 1);
  • $part_encoding = $sparts[$c]->encoding;
  • }
  • }
  • /* PIECES JOINTES
  • else {
  • $dpara = $sparts[$c]->dparameters;
  • for ($v=0;$v<sizeof($dpara);$v++) {
  • if (strpos($dpara[$v]->attribute,"filename")) {
  • $fname = $dpara[$v]->value;
  • }
  • }
  • if (empty($fname)) {
  • $para = $sparts[$c]->parameters;
  • for ($v=0;$v<sizeof($para);$v++) {
  • if (strpos($para[$v]->attribute,"name")) {
  • $fname = $para[$v]->value;
  • }
  • }
  • }
  • if (empty($fname)) {
  • $disp = $sparts[$c]->description;
  • }
  • $an = sizeof($attachments);
  • $attachments[$an]->part = ($x + 1) . "." . ($c + 1);
  • $attachments[$an]->filename = $fname;
  • $attachments[$an]->size = $sparts[$c]->bytes;
  • $attachments[$an]->mime = mimetype($sparts[$c]->type) . "/" . strtolower($sparts[$c]->subtype);
  • $fname = "";
  • }
  • FIN PIECES JOINTES */
  • }
  • }
  • else {
  • if (!$parts[$x]->type && empty($parts[$x]->disposition)) {
  • if (strpos($parts[$x]->subtype,"html")) {
  • # HTML message
  • $part_needed = ($x + 1);
  • $part_encoding = $parts[$x]->encoding;
  • $html_entity = 1;
  • }
  • elseif (strpos($parts[$x]->subtype,"plain")) {
  • # Plain text
  • $part_needed = ($x + 1);
  • $part_encoding = $parts[$x]->encoding;
  • }
  • }
  • /* PIECES JOINTES
  • else {
  • $dpara = $parts[$x]->dparameters;
  • for ($v=0;$v<sizeof($dpara);$v++) {
  • if (strpos($dpara[$v]->attribute,"filename")) {
  • $fname = $dpara[$v]->value;
  • }
  • }
  • if (empty($fname)) {
  • $para = $parts[$x]->parameters;
  • for ($v=0;$v<sizeof($para);$v++) {
  • if (strpos( $para[$v]->attribute,"name")) {
  • $fname = $para[$v]->value;
  • }
  • }
  • }
  • if (empty($fname)) {
  • $fname = $parts[$x]->description;
  • }
  • $an = sizeof($attachments);
  • $attachments[$an]->part = ($x + 1);
  • $attachments[$an]->filename = $fname;
  • $attachments[$an]->size = $parts[$x]->bytes;
  • $attachments[$an]->mime = mimetype($parts[$x]->type) . "/" . strtolower($parts[$x]->subtype);
  • $fname = "";
  • }
  • FIN PIECES JOINTES */
  • }
  • }
  • }
  • else {
  • # Message unique
  • if (strpos($struct->subtype,"html")) {
  • # HTML
  • $part_needed = "body";
  • $part_encoding = $struct->encoding;
  • $html_entity = 1;
  • }
  • else {
  • $part_needed = "body";
  • $part_encoding = $struct->encoding;
  • }
  • }
  • # Récupère le coprs du message
  • if ($part_needed == "body") {
  • if($this->m_debug) $body = imap_body($this->m_stream,$msgno);
  • else $body = @imap_body($this->m_stream,$msgno);
  • }
  • else {
  • if($this->m_debug) $body = imap_fetchbody($this->m_stream,$msgno,$part_needed);
  • else $body = @imap_fetchbody($this->m_stream,$msgno,$part_needed);
  • }
  • switch ($part_encoding)
  • {
  • case 4:
  • $body = imap_qprint($body);
  • break;
  • case 3:
  • $body = imap_base64($body);
  • break;
  • default:
  • break;
  • }
  • if($html_entity) return $body;
  • else return htmlentities($body);
  • }
  • }
class CImap {
	public $m_host = null;
	public $m_login = null;
	public $m_pass = null;
	public $m_port = null;
	public $m_service = null;
	public $m_folder = null;
	public $m_flags = null;
	public $m_debug = true;
	protected $m_mailboxes = null;
	protected $m_stream = null;
	protected $m_headers = null;
	protected $m_headersinfo = null;
	protected $m_overview = null;
	/**
	* @desc Constructeur par valeurs.
	* @param string $host
	* @param string $login
	* @param string $pass
	* @param int $port = 143
	* @param string $service = "imap"
	* @param string $folder = "INBOX"
	* @param string $flags
	*/
	function CImap($host,$login,$pass,$port=143,$service="imap",$folder="INBOX",$flags="") {
		if(empty($host) && empty($login) && empty($pass)) {
			throw new Exception(__CLASS__."<hr><br>Fatal error: You should specify the host, the login and the password for the CImap constructor");
		}
		else {
			$this->m_host = $host;
			$this->m_login = $login ;
			$this->m_pass = $pass ;
			$this->m_port = $port ;
			$this->m_service = $service ;
			$this->m_folder = imap_utf7_encode($folder);
			$this->m_flags = $flags ;
		}
	}
	/**
	* @desc Met l"attribut $m_folder à la valeur $folder
	* permet de lire les emails contenu dans le dossier $folder.
	* @param string $folder = "INBOX"
	*/
	public function setFolder($folder = "INBOX") {
		$this->m_folder = imap_utf7_encode($folder);
	}
	/**
	* @desc renvoie la dernière erreur.
	* @return string
	* @param <empty>
	*/
	public function error() {
		$error = imap_last_error();
		if(empty($error)) return false;
		else return $error;
	}
	/**
	* @desc Ouvre un flux imap sur le serveur $m_host authentifié en tant que $m_login avec $m_pass
	* renvoie faux si une erreur d"ouverture de flux apparait, sinon renvoie le flux ouvert.
	* @return resource
	* @param <empty>
	*/
	public function open_stream() {
		$this->m_stream = null;
		if($this->m_debug) $this->m_stream = imap_open("{".$this->m_host.":".$this->m_port."/".$this->m_service.$this->m_flags."}".$this->m_folder,$this->m_login,$this->m_pass);
		else $this->m_stream = @imap_open("{".$this->m_host.":".$this->m_port."/".$this->m_service.$this->m_flags."}".$this->m_folder,$this->m_login,$this->m_pass);

		return $this->m_stream;
	}
	/**
	* @desc ferme le flux imap $m_stream
	* renvoie faux si une erreur de fermeture de flux apparait, sinon renvoie le flux ouvert.
	* @return bool
	* @param <empty>
	*/
	public function close_stream() {
		if($this->m_debug) return imap_close($this->m_stream);
		else return @imap_close($this->m_stream);
	}
	/**
	* @desc Ouvre un flux imap sur le serveur $m_host authentifié en tant que $m_login avec $m_pass
	* renvoie faux si une erreur d"ouverture de flux apparait, sinon renvoie le flux ouvert.
	* @return array
	*/
	public function mailbox_list() {
		$this->m_mailboxes = null;
		if($this->m_debug) $mailboxes = imap_list($this->m_stream,"{".$this->m_host.":".$this->m_port."/".$this->m_service.$this->m_flags."}","*");
		else $mailboxes = @imap_list($this->m_stream,"{".$this->m_host.":".$this->m_port."/".$this->m_service.$this->m_flags."}","*");
		for($i=0;$i<sizeof($mailboxes);$i++) {
			$ar = spliti("{".$this->m_host.":".$this->m_port."/".$this->m_service.$this->m_flags."}",imap_utf7_decode($mailboxes[$i]));
			$this->m_mailboxes[$i] = $ar[1];
		}
		return $this->m_mailboxes;
	}
	/**
	* @desc  Retourne les en-têtes de tous les messages d"une boîte aux lettres, si pas de message renvoie faux
	* @param <empty>
	* @return array
	*/
	protected function headers() {
		$this->m_headers = null;
		if($this->m_debug) $this->m_headers = imap_headers($this->m_stream);
		else $this->m_headers = @imap_headers($this->m_stream);

		return $this->m_headers;
	}
	/**
	* @desc  Lit un sommaire des en-têtes de messages
	* @param int $msgno = null
	* @return array
	*/
	public function overview($msgno = null) {
		$this->m_overview = null;
		if($this->headers()) {
			if(is_null($msgno)) {
				if($this->m_debug) $overview = imap_fetch_overview($this->m_stream, "1:".sizeof($this->m_headers), 0);
				else $overview = @imap_fetch_overview($this->m_stream, "1:".sizeof($this->m_headers), 0);
				while(list($key,$val) = each($overview)) {
					$i = sizeof($this->m_overview);
					$this->m_overview[$i] = $val;
				}
			}
			else {
				if($this->m_debug) $overview = imap_fetch_overview($this->m_stream,$msgno, 0);
				else $overview = @imap_fetch_overview($this->m_stream, $msgno, 0);
				list($key,$val) = each($overview);
				$this->m_overview = $val;
			}
		}
		return $this->m_overview;
	}
	/**
	* @desc  Retourne les informations des en-têtes des messages sous forme d"un tableau d"objet.
	* @param int $msgno = null
	* @return array
	*/
	public function headerinfo($msgno = null) {
		$this->m_headersinfo = null;
		if($this->headers()) {
			if(is_null($msgno)) {
				while (list ($key,$val) = each ($this->m_headers)) {
					$i = sizeof($this->m_headersinfo);
					if($this->m_debug) $this->m_headersinfo[$i] = imap_headerinfo($this->m_stream, $key+1);
					else $this->m_headersinfo[$i] = @imap_headerinfo($this->m_stream, $key+1);
				}
			}
			else {
				if($this->m_debug) $this->m_headersinfo = imap_headerinfo($this->m_stream, $msgno);
				else $this->m_headersinfo = @imap_headerinfo($this->m_stream, $msgno);
			}
		}
		return $this->m_headersinfo;
	}
	/**
	* @desc  Récupère le corps du message numero $msgno en TEXT/HTML ou en TEXT/PLAIN.(pas les pieces jointes)
	* @param int $msgno
	* @return string
	*/
	public function get_part($msgno){
		$this->open_stream();
		if($this->m_debug) $struct = imap_fetchstructure($this->m_stream,$msgno);
		else $struct = @imap_fetchstructure($this->m_stream,$msgno);
		$parts = $struct->parts;
		if ($struct->type) {
			for ($x=0;$x<sizeof($parts);$x++) {
				$ttype = $parts[$x]->type;
				if ($ttype == 1) {
					# Multipart in multipart
					$sparts = $parts[$x]->parts;
					for ($c=0;$c<sizeof($sparts);$c++) {
						if (!$sparts[$c]->type && empty($sparts[$c]->disposition)) {
							if (strpos($sparts[$c]->subtype,"html")) {
								# HTML
								$part_needed = ($x + 1) . "." . ($c + 1);
								$part_encoding = $sparts[$c]->encoding;
								$html_entity = 1;
							}
							elseif (strpos($sparts[$c]->subtype,"plain")) {
								# Plain text
								$part_needed = ($x + 1) . "." . ($c + 1);
								$part_encoding = $sparts[$c]->encoding;
							}
						}
						/* PIECES JOINTES
						else {
						$dpara = $sparts[$c]->dparameters;
						for ($v=0;$v<sizeof($dpara);$v++) {
						if (strpos($dpara[$v]->attribute,"filename")) {
						$fname = $dpara[$v]->value;
						}
						}
						if (empty($fname)) {
						$para = $sparts[$c]->parameters;
						for ($v=0;$v<sizeof($para);$v++) {
						if (strpos($para[$v]->attribute,"name")) {
						$fname = $para[$v]->value;
						}
						}
						}
						if (empty($fname)) {
						$disp = $sparts[$c]->description;
						}
						$an = sizeof($attachments);
						$attachments[$an]->part = ($x + 1) . "." . ($c + 1);
						$attachments[$an]->filename = $fname;
						$attachments[$an]->size = $sparts[$c]->bytes;
						$attachments[$an]->mime = mimetype($sparts[$c]->type) . "/" . strtolower($sparts[$c]->subtype);
						$fname = "";
						}
						FIN PIECES JOINTES */
					}
				}
				else {
					if (!$parts[$x]->type && empty($parts[$x]->disposition)) {
						if (strpos($parts[$x]->subtype,"html")) {
							# HTML message
							$part_needed = ($x + 1);
							$part_encoding = $parts[$x]->encoding;
							$html_entity = 1;
						}
						elseif (strpos($parts[$x]->subtype,"plain")) {
							# Plain text
							$part_needed = ($x + 1);
							$part_encoding = $parts[$x]->encoding;
						}
					}
					/* PIECES JOINTES
					else {
					$dpara = $parts[$x]->dparameters;
					for ($v=0;$v<sizeof($dpara);$v++) {
					if (strpos($dpara[$v]->attribute,"filename")) {
					$fname = $dpara[$v]->value;
					}
					}
					if (empty($fname)) {
					$para = $parts[$x]->parameters;
					for ($v=0;$v<sizeof($para);$v++) {
					if (strpos( $para[$v]->attribute,"name")) {
					$fname = $para[$v]->value;
					}
					}
					}
					if (empty($fname)) {
					$fname = $parts[$x]->description;
					}
					$an = sizeof($attachments);
					$attachments[$an]->part = ($x + 1);
					$attachments[$an]->filename = $fname;
					$attachments[$an]->size = $parts[$x]->bytes;
					$attachments[$an]->mime = mimetype($parts[$x]->type) . "/" . strtolower($parts[$x]->subtype);
					$fname = "";
					}
					FIN PIECES JOINTES */
				}
			}
		}
		else {
			# Message unique
			if (strpos($struct->subtype,"html")) {
				# HTML
				$part_needed = "body";
				$part_encoding = $struct->encoding;
				$html_entity = 1;
			}
			else {
				$part_needed = "body";
				$part_encoding = $struct->encoding;
			}
		}
		# Récupère le coprs du message
		if ($part_needed == "body") {
			if($this->m_debug) $body = imap_body($this->m_stream,$msgno);
			else $body = @imap_body($this->m_stream,$msgno);
		}
		else {
			if($this->m_debug) $body = imap_fetchbody($this->m_stream,$msgno,$part_needed);
			else $body = @imap_fetchbody($this->m_stream,$msgno,$part_needed);
		}

		switch ($part_encoding)
		{
			case 4:
			$body = imap_qprint($body);
			break;
			case 3:
			$body = imap_base64($body);
			break;
			default:
			break;
		}
		if($html_entity) return $body;
		else return htmlentities($body);
	}
}

 Conclusion

Je compte pas faire de mise à jour, sauf si vous voyez des bugs...


 Historique

23 avril 2006 10:25:46 :
Correction des fonctionnalité + Screenshot
23 avril 2006 21:59:50 :
Mise à jour suite recommandations

 Sources du même auteur

Source avec Zip [PHP5][POO] EXEMPLES DE SYSTEME DE CLASSE (HERITAGE, AGREGAT...
Source avec Zip Source avec une capture [PHP5][POO][JEUX] SUDOKU
UPLOAD CHEZ FREE QUI MARCHE!!
Source avec Zip CRÉATION D'UN ESPACE MEMBRE AVEC MYSQL

 Sources de la même categorie

Source avec Zip Source avec une capture FORM TO MAIL AVEC PROTECTION PAR TOKEN ET CAPTCHA CONTRÔLES ... par cod57
Source avec Zip Source avec une capture FORMULAIRE VERS COURRIEL BASIQUE AVEC CONTRÔLE CAPTCHA ANTI ... par cod57
Source avec Zip CHAT EN PHP ET JQUERY par pitchoubrazil
Source avec Zip Source avec une capture FORMULAIRE DE CHOIX MULTI-CONTACT VALIDE XHTML 1.0 TRANSITIO... par aventurier19
Source avec Zip Source avec une capture WEB MESSENGER par EvildarkEurope

 Sources en rapport avec celle ci

Source avec Zip Source avec une capture TODO LIST (AJAX/PHP5) par VinceMonkeyz
Source avec Zip [PHP5.2] CLASSE PDO par hornetbzz
CLASS RECHERCHE PHP5 POO par mtrix000
CLASS AUTHENTIFICATION PHP5 POO par mtrix000
CLASS PAGINATION PHP5 POO par mtrix000

Commentaires et avis

Commentaire de FhX le 23/04/2006 13:54:50

Voui, y'a un bug :p

( private $m_debug = true; )
# public function debug($b = true) {
#         $this->m_debug = $b;
#     }

Méthode qui ne sert à rien :) Met $m_debug en public et retire la méthode. $m_debug est un bool, donc autant la laisser public. C'est celui qui va utiliser ta classe qui fera :
$imap = new imap_class; // Me rappele plus du nom de ta classe :p
$imap->m_debug = TRUE;
// $imap->m_debug = FALSE;

Faut pas avoir peur des propriétés public surtout :)
Pareil pour $host, $login, $pass... autant mettre ca en public, y'a rien de bien choquant que de faire :
$imap->host = 'xxx';
$imap->user = 'yyy';
$imap->passwd = 'zzz';
Car si t'as un tableau à l'extérieur :
$array = array('host' => 'xxx', 'user' => 'yyy', 'passwd' => 'zzz');
foreach ( $array as $key=>$val ) {
   $imap->$key = $val;
}

Et hop, c'est vite reglé :)

Donc autant mettre ca en public, au final c'est l'utilisateur de ta classe qui va être heureux :)

Commentaire de FhX le 23/04/2006 13:57:12

#else {
# if (eregi("html", $struct->subtype)) {
#                 # HTML
#                 $part_needed = "body";
#                 $part_encoding = $struct->encoding;
#                 $html_entity = 1;
#             }
#             else {
#                 $part_needed = "body";
#                 $part_encoding = $struct->encoding;
#             }"
Oublié vite fait, c'est passé à travers :p

Ca sert à rien ce gros if() :p

<?php
} else {
$part_needed = "body";
$part_encoding = $struct->encoding;
  if (eregi("html", $struct->subtype)) $html_entity = 1;
// Et encore, eregi ca fait lourd pour ca ==> preg_match() est 10 fois plus rapide pour ce genre de chose.
// Voir même avec les fonctions str_* ! :p
}
?>

Commentaire de Anthomicro le 23/04/2006 18:34:56

strpos sera encore plus rapide, par contre il arrive qu'ereg soit plus rapide (testé et approuvé sur certaines fonctions de mon site).

Sinon c'est un bon code malgré les quelques bugs :-)

FhX > pour les attributs publics je pense que tout ce qui est host et connexion devrait être fait soit dans la classe soit dans le constructeur, ça éviterait justement de se balader avec ça :-)

Commentaire de Anthomicro le 23/04/2006 18:35:53

au fait : 9/10 (dix quand les bugs seront corrigés) ;-)

Commentaire de Anthomicro le 23/04/2006 18:37:56

bon j'ai noté 10 par erreur m'enfin c'est pas grave...

Commentaire de FhX le 23/04/2006 21:06:22

"FhX > pour les attributs publics je pense que tout ce qui est host et connexion devrait être fait soit dans la classe soit dans le constructeur, ça éviterait justement de se balader avec ça :-)"
Le host et tout peut être publique... ca ne génera rien du tout. Par contre, le lien de connection $link DOIT être privé et DOIT resté dans la classe, car celui ci n'a pas besoin d'être utilisé en dehord.
Alors que si j'ai envie de changer d'hote, de login ou de pass ==> $mysql->host = 'new_host';

Suffit de faire des tests avant la connection à la base de donnée... généralement c'est ce qu'on fait quand la classe est bien faite :)

Commentaire de Anthomicro le 23/04/2006 21:12:21

"Alors que si j'ai envie de changer d'hote, de login ou de pass ==> $mysql->host = 'new_host';"

Pourquoi changer d'hôte ? quand t'as plusieurs bases à gérer tu changes juste la base, sinon si t'as plusieurs bdd à gérer sur deux serveurs distincts (genre réplication) là peut-être oui (et encore je pense que ça se fait plutôt niveau logiciel et pas PHP ce genre de choses, inutile de perdre des perfs alors qu'il n'y a qu'un dossier "datas" à copier

Commentaire de FhX le 23/04/2006 21:43:23

Ce que je voulais dire, c'est que ca porte pas atteinte au code pur :)
Tu peux faire :
<?php

public $host;

public function __construct($host) {
  $this->host = $host;
}

?>
Puis, pour une raison où une autre, faire :
$mysql = new mysql('host.com');
$mysql->host = 'host.fr';
Pas besoin de rajouter une méthode en plus pour faire :
$mysql->setHost('host.fr');
ou alors
$mysql->changeoption('host', 'host.fr'); <== qui est encore plus lent !

Voila pourquoi je dis qu'il ne faut pas avoir peur du "public" et faire des méthodes dans le vent :)

Commentaire de Nifhell le 23/04/2006 22:04:00

Voilà, mis à jour ;) (mis en publique les attributs parus necessaires, enfin je crois...)

Commentaire de Nifhell le 23/04/2006 22:08:01

Et remplacer les eregi par des strpos (comme conseillé effectivement dans le manuel php...)

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

IMAP [ par RockmanX ] je cherche quelqu'un qui maîtrise les flots IMAP ou ki sait ou je peux trouver un tutorial aide script de messagerie interne [ par nova ] salut à tousdébutante en php (enfin pas tant que ça) mais surtout par rapport àl'interfacage avec mysql j'aimerais construire une messagerie interne p Questions pour les pros de imap [ par Nosferatu131 ] Bonjour à vous,Voilà mes problèmes, et je m'en arrache les cheveux :Je créé un webmail. Tout va bien sauf que :- je n'arrive pas à faire en sorte que Problème avec IMAP [ par Yuleesize ] Lu,Je suis en train d'essyaer de faire un "mini webmail" et donc j'utilise les fonctions imap de php...Et il me retourne bien le mail mais...Il me mod aide pour installation de messagerie [ par lucy ] je suis très débutante et j'aimerais bien qu on m'expliquer commen installer une messagerie.. alors si qqn si connait.. ben donnez moi votre adresse m snif.. comment installer une messagerie?? [ par lucy ] j'ai télécharger un script de messagerie mais je suis incapable de l'installer sur mon site.. je comprends rien..aidez moi.. si vous avez msn.. ajoute differnec entre php 4 et php5 [ par hardelgylls ] Bonjourpetite question :j'ai passer un oral et l'examinateur m'a demandé quel était la différence entre php4 et php5. et la gros blanc, est ce que qqu Doc PHP5 sniff sniff [ par slhuilli ] Bonjour, Bonsoir,Je suis a la recherche d'un PDF qui recenserait les mots-clefs + explications (bref un bouquin complet) sur PHP 5 qui parait-il est Imap mail : Message Lu / Non Lu [ par maesius ] Bonjour,voila je vient de mettre en place un petit webmail PHP mais g un souci pour afficher : "message lu" ou "message non lu"...J'ai essayer de recu Imap Body d'un message [ par maesius ] Imap Body d'un message Bonjour,voila , j'ai un souci. Je suis en train de faire un petit webmail et je coince sur le dechiffrage du body.J'ai pu voir


Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

A découvrir



 
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 : 0,749 sec (4)

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