IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

envoi de mail selon checkbox


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Inscrit en
    Juillet 2009
    Messages
    12
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 12
    Points : 7
    Points
    7
    Par défaut envoi de mail selon checkbox
    Bonjour,

    J'essaie de mettre en place un formulaire d'envoi de mail un peu compliqué.

    Principe :

    L'expéditeur peut choisir un ou plusieurs destinataires pré-définis dans une base MySQL .
    Une liste des destinataires potentiels est affichée ; en face de chaque nom figure une checkbox.

    (Pour la suite, le script devra donner la possibilité d'adresser un mail à un destinataire hors-liste, d'envoyer une copie cachée (ou plusieurs), de joindre un fichier, d'archiver les mails envoyés dans la bdd, de faire du bon café... mais chaque chose en son temps !)

    Je ne sais pas comment dire à la fonction mail de prendre en compte les destinataires issus des checkbox.

    Voici mon code actuel :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    <form method="post" action="cettepage.php" enctype="multipart/form-data">
    	<div id="admincompanytable">
    	<table id="companytable">
    		<?php
    		//affiche la liste des utilisateurs
    		//connexion à la base de données
    		mysql_connect('localhost', 'user', 'password');
    		mysql_select_db('entreprises');
    		// récupération de la liste des utilisateurs
    		$companyTable = mysql_query('select * from entreprises_identity order by entreprises_dir');
    		while ($userInfo = mysql_fetch_array($companyTable))
    			{
    		?>
    		<tr>
    			<td class="lot"><?php echo $userInfo['entreprises_dir']; ?> </td>
    			<td class="metier"> <?php echo $userInfo['entreprises_name']; ?></td>
    			<td> <input type="checkbox" name="destinataires[]" value="<?php echo $userInfo['entreprises_mail']; ?>" /></td>
    		</tr>
    		<?php
    			}
    		?>
    	</table>
    	</div>
    	<div id="mailadminform">
    		<label for="destinataire"><b>Destinataires</b><br />
    		<input type="button" value=" Cochez dans la liste ci-contre." size="12" /><br />
    		<label for="subject"><b>Sujet</b></label><br />
    		<input name="subject" type="text" size="24" /><br />
    		<label for="message"><b>Message</b></label><br />
    		<textarea name="message" cols="25" rows="8"></textarea><br />
    		<label for="fileatt"><b>Joindre un fichier</b></label><br /> 
    		<input type="file" name="fileatt" size="11" /><br />
    		<label>&nbsp;</label><br />
    		<input name="Annuler" type="reset" value="Annuler"><input name="soumettre" type="submit" value="Envoyer">
    		<?php 
    		// vérification que les champs destinataires, sujet et message sont bien remplis 
    		if(isset($_POST['destinataires'])&&isset($_POST['subject'])&&isset($_POST['message']))
    			{
    			// affectation des variables destinataires, sujet, message
    			$destinataires = $_POST['destinataires'];
    			$subject = $_POST['subject'];
    			$message = $_POST['message'];
    			// affichage d'un message si succès (ok) ou erreur (ko)
    			$messageok ='<p><b>Succ&egrave;s ! Message envoy&eacute; !</b></p>';
    			$messageko ='<p><b>Erreur... e-mail non envoy&eacute;.</b></p>';
    			// envoi du mail
    			if (mail($destinataires,$subject,$message))
    				{
    				echo $messageok;
    				}
    			else 
    				{
    				echo $messageko;
    				}
    			}
    		else
    			{
    			echo $messageko;
    			}
    		//fermeture de la connexion
    		mysql_close();
    		?>
    	</div>
    </form>
    La table entreprises_identity étant ainsi constituée :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    CREATE TABLE IF NOT EXISTS `entreprises_identity` (
      `entreprises_id` int(2) NOT NULL auto_increment,
      `entreprises_name` varchar(55) NOT NULL,
      `entreprises_mail` varchar(65) NOT NULL,
      `entreprises_dir` varchar(3) NOT NULL,
      PRIMARY KEY  (`entreprises_id`)
    ) ENGINE=MyISAM  DEFAULT CHARSET=latin1;
    En envoi manuel (champ destinataire testé sans chekbox) ce code fontionne (même s'il est loin d'être optimisé).

    Par contre, avec les checkboxes, cette ligne :
    if (mail($destinataires,$subject,$message))
    ne me semble pas adéquate mais je ne sais pas par quoi la remplacer...

    Merci de m'aiguiller.


    à plus,

    rcjcrcjc

  2. #2
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Bonjour,
    Seuls les checkbox cochés sont envoyé au serveur et tu les récupères avec:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    foreach($_POST['destinataires'] as $index=>$adresse_mail)
    {
    //ici tu envoies ton mail avec l'adresse du  destinataire est  $adresse_mail
    }

  3. #3
    Futur Membre du Club
    Inscrit en
    Juillet 2009
    Messages
    12
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 12
    Points : 7
    Points
    7
    Par défaut
    Merci beaucoup.

    J'ai modifié mon code ainsi :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    <?php 
    				$adressesmail = '';
    				foreach($_POST['destinataires'] as $destinataires)
    					{
    					$adressesmail.=",".$destinataires;
    					}
    				$subject = $_POST['subject'];
     				$message = $_POST['message'];
     				$messageok ='<p><b>Succ&egrave;s ! Message envoy&eacute; !</b></p>';
     				$messageko ='<p><b>Erreur... e-mail non envoy&eacute;.</b></p>';
     				if (mail($adressesmail,$subject,$message))
     					{
     					echo $messageok;
     					}
     				else 
     					{
     					echo $messageko;
     					}
     				?>
    Et l'envoi multiple fonctionne apparemment bien.

    Je ne ferme pas encore ce sujet car il reste encore pas mal de boulot sur l'optimisation du code...


    à plus,

    rcjcrcjc

  4. #4
    Futur Membre du Club
    Inscrit en
    Juillet 2009
    Messages
    12
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 12
    Points : 7
    Points
    7
    Par défaut
    Bon, finalement ça ne marche pas si bien que ça...

    Si je ne sélectionne qu'une seule adresse (donc une seule checkbox), tout va bien, le mail part.
    Si j'en sélectionne plusieurs, c'est plus bizarre : le mail part bien, il est reçu par une des adresses seulement mais dans l'en-tête du mail reçu il y bien toutes les adresses d'indiquées comme destinataires...
    Chacune des adresses testées individuellement fonctionne bien.

    Au cas où cela est nécessaire (mais j'en doute...) :
    - je teste en local (le script est sur mon PC) vers des adresses externes ;
    - ma config de php est 5.3.0 (sur openSUSE 11.1) ;
    - le serveur est un Windows 2003.

    Je me suis trompé à quel endroit ?


    à plus,

    rcjcrcjc

Discussions similaires

  1. [Vxi3] Envoi automatique mail selon données univers
    Par dnyyy dans le forum Webi
    Réponses: 3
    Dernier message: 31/12/2014, 10h09
  2. [MySQL] Envoi de mails selon une heure et une date donnée stockée
    Par vw91 dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 16/06/2008, 11h00
  3. [Mail] Envoi de valeurs de checkbox vers un mail
    Par vansb dans le forum Langage
    Réponses: 3
    Dernier message: 07/09/2006, 23h43
  4. Envoi selon checkbox sélectionnées
    Par Polaire76 dans le forum Langage
    Réponses: 1
    Dernier message: 29/03/2006, 11h32
  5. [Php/MySQL] Envoi de mails selon requête
    Par martonpylon12 dans le forum Débuter
    Réponses: 7
    Dernier message: 28/03/2006, 14h00

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo