Problème script newsletter

Résolu
kbibi99 Messages postés 12 Date d'inscription   Statut Membre Dernière intervention   -  
bg62 Messages postés 23733 Date d'inscription   Statut Modérateur Dernière intervention   -
Bonjour,
je veut faire un système de newslettre pour mon site j'ai ces codes php des pages
index.php
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" >
<head>
<title>La newsletter de MonSite.fr</title>
</head>
<body>
<?php
if(isset($_GET['email'])) // On vérifie que la variable $_GET['email'] existe.
{

if( !empty($_POST['email']) AND $_GET['email']==1 AND isset($_POST['new'])) /* On vérifie que la variable $_POST['email'] contient bien quelque chose, que la variable $_GET['email'] est égale à 1 et que la variable $_POST['new'] existe. */
{
if (preg_match("#^[a-z0-9._-]+@[a-z0-9._-]{2,**\.[a-z]{2,4**$#", $_POST['email'])) // On vérifie qu'on a bien rentré une adresse e-mail valide.
{

if($_POST['new']==0) // Si la variable $_POST['new'] est égale à 0, cela signifie que l'on veut s'inscrire.
{

// On définit les paramètres de l'e-mail.
$email = $_POST['email'];
$message = 'Pour valider votre inscription à la newsletter de MonSite.fr, <a href="https://www.pagesjaunes.fr/?tru=1&email=$email.'">clique z ici</a>.';

$destinataire = $email;
$objet = "Inscription à la newsletter de MonSite.fr" ;

$headers = 'MIME-Version: 1.0' . "\r\n";
$headers .= 'Content-type: text/html; charset=iso-8859-1' . "\r\n";
$headers .= 'From: monsite@monsite.fr' . "\r\n";
if ( mail($destinataire, $objet, $message, $headers) ) // On envoie l'e-mail.
{

echo "Pour valider votre inscription, veuillez cliquer sur le lien dans l'e-mail que nous venons de vous envoyer.";
**
else
{
echo "Il y a eu une erreur lors de l'envoi du mail pour votre inscription.";
**
**
elseif($_POST['new']==1) // Si la variable $_POST['new'] est égale à 1, cela signifie que l'on veut se désinscrire.
{

// On définit les paramètres de l'e-mail.
$email = $_POST['email'];
$message = 'Pour valider votre désinscription de la newsletter de MonSite.fr, <a href="https://www.pagesjaunes.fr/?tru=1&email=$email.'">cli quez ici</a>.';

$destinataire = $email;
$objet = "Désinscription de la newsletter de MonSite.fr" ;

$headers = 'MIME-Version: 1.0' . "\r\n";
$headers .= 'Content-type: text/html; charset=iso-8859-1' . "\r\n";
$headers .= 'From: monsite@monsite.fr' . "\r\n";
if ( mail($destinataire, $objet, $message, $headers) )
{

echo "Pour valider votre désinscription, veuillez cliquer sur le lien dans l'e-mail que nous venons de vous envoyer.";
**
else
{
echo "Il y a eu une erreur lors de l'envoi du mail pour votre désinscription.";
**
**
else
{
echo "Il y a eu une erreur !";
**
**
else
{
echo "Vous n\'avez pas entré une adresse e-mail valide ! Veuillez recommencer !";
**
**
else
{
echo "Il y a eu une erreur.";
**
**
else // Si les champs n'ont pas été remplis.
{
?>
La newsletter :
<form method="post" action="index.php?email=1">
Adresse e-mail : <input type="text" name="email" size="25" /><br />
<input type="radio" name="new" value="0" />S''inscrire
<input type="radio" name="new" value="1" />Se désinscrire<br />
<input type="submit" value="Envoyer" name="submit" /> <input type="reset" name="reset" value="Effacer" />
</form>
<?php
**
?>
</body>
</html>

inscription.php
<?php
if($_GET['tru']==1)
{

setcookie("email", $_GET['email'], time()+25); // On crée un cookie qui expirera 25 secondes plus tard pour des raisons de sécurité.
**
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" >
<head>
<meta http-equiv=Content-Type content="text/html; charset=iso-8859-1">

<?php
if($_GET['tru']==2)
{
?>
<meta http-equiv="refresh" content="1; url=https://www.pagesjaunes.fr/" /> <!-- Redirection vers la page d'accueil du site si on a entré son e-mail. -->

<?php
**
else
{
?>

<meta http-equiv="refresh" content="25; url=https://www.pagesjaunes.fr/" /> <!-- Redirection vers la page d'accueil du site si on tarde trop à entrer son e-mail. -->

<?php
**
?>

<title>Validation de votre inscription à la newsletter de MonSite.fr</title>

</head>
<body>
<p align="center"><font size="5">Validation de votre inscription</font></p>
<?php
if($_GET['tru']==1) //Si la variable $_GET['tru'] est égale à 1.
// On affiche le formulaire
{
?>
<font color="red">Attention, vous avez 25 secondes pour remplir le formulaire. Passé ce délai, celui-ci ne sera plus valide.</font>
<form method="post" action="inscription.php?tru=2">
Entrez votre e-mail : <input type="text" name="email" size="25" /><br />
<input type="submit" value="Envoyer" name="submit" /> <input type="reset" name="reset" value="Effacer" />
</form>
<?php
**
elseif($_GET['tru']==2) // Sinon, si la variable $_GET['tru'] est égale à 2.
{
mysql_connect("localhost", "login", "pass");
mysql_select_db("db");
$email_mail = mysql_real_escape_string($_COOKIE['email']);
$email_entre = mysql_real_escape_string($_POST['email']);

if($email_entre==$email_mail) // Si les deux adresses e-mail sont identiques.
{
mysql_query("INSERT INTO newsletter VALUES('" . $email_entre . "')"); // On l'inscrit dans la base de données MySQL.

echo "Vous avez bien été inscrit à la newsletter de MonSite.fr ! Vous allez être redirigé dans 1 seconde.";

**
else
{

echo "Vous n'avez pas entré la bonne adresse e-mail !";

**
**
else
{
echo "Il y a eu une erreur.";
**
?>
</body>
</html>

desinscription.php
<?php
if($_GET['tru']==1)
{

setcookie("email", $_GET['email'], time()+25); // On crée un cookie qui expirera 25 secondes plus tard pour des raisons de sécurité.

**
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" >
<head>
<meta http-equiv=Content-Type content="text/html; charset=iso-8859-1">
<?php
if($_GET['tru']==2)
{
?>

<meta http-equiv="refresh" content="1; url=https://www.pagesjaunes.fr/" /> <!-- Redirection vers la page d'accueil du site si on a entré son e-mail. -->

<?php
**
else
{
?>

<meta http-equiv="refresh" content="25; url=https://www.pagesjaunes.fr/" /> <!-- Redirection vers la page d'accueil du site si on tarde trop à entrer son e-mail. -->

<?php
**
?>
<title>Validation de votre désinscription de la newsletter de MonSite.fr</title>
</head>
<body>
<p align="center"><font size="5">Validation de votre désinscription</font></p>

<?php
if($_GET['tru']==1) //si la variable $_GET['tru'] est égale à 1
// On affiche le formulaire.
{
?>
<font color="red">Attention, vous avez 25 secondes pour remplir le formulaire. Passé ce délai, celui-ci ne sera plus valide.</font>
<form method="post" action="desinscription.php?tru=2">
Entrez votre adresse e-mail : <input type="text" name="email" size="25" /><br />
<input type="submit" value="Envoyer" name="submit" /> <input type="reset" name="reset" value="Effacer" />
</form>
<?php
**
elseif($_GET['tru']==2) // Sinon, si la variable $_GET['tru'] est égale à 2.
{
mysql_connect("localhost", "login", "pass");
mysql_select_db("db");
$email_mail = mysql_real_escape_string($_COOKIE['email']);
$email_entre = mysql_real_escape_string($_POST['email']);

if($email_entre==$email_mail) // Si les deux adresses e-mail sont identiques.
{
mysql_query("DELETE FROM newsletter WHERE email='" . $email_entre ."'"); //On supprime l'adresse de la BDD.

echo "Vous avez bien été désinscrit de la newsletter de MonSite.fr ! Vous allez être redirigé dans 1 seconde.";

**
else
{
echo "Vous n'avez pas entré la bonne adresse e-mail !!";
**
**
else
{
echo "Il y a eu une erreur.";
**
?>
</body>
</html>

newsletter.php

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" >
<head>
<title>Envoi de la newsletter</title>
<style type="text/css">
h2, th, td
{
text-align:center;
**
table
{
border-collapse:collapse;
border:2px solid white;
margin:auto;
**
th, td
{
border:1px solid black;
**
</style>
</head>
<body>
<p align=center><font size="6"><font color="red">Envoi de la newsletter</font></font></p>

<?php
// On se connecte.
mysql_connect("localhost", "login", "pass");
mysql_select_db("db");

// On récupère les 5 dernières news.
$news = mysql_query('SELECT contenu,timestamp FROM news ORDER BY id DESC LIMIT 0, 5');

$fichier_message = '<html>
<head>
<title>Newsletter de MonSite.fr</title>
</head>
<body bgcolor="black">
<font face="verdana"><font color="white"><font size="5"><p align="center"><font color="red"><u>Balzac61</u></font></p></font>
<font size="3">
<p align="left">Voici les dernières news de MonSite.fr :<br /><ul>'; //On définit le message.

while($donnee = mysql_fetch_assoc($news))
{
$fichier_message .= '<li>'.$donnee["contenu"].'(le'.date("D, d M Y H:i:s",$donnee["timestamp"]).')</li>'; //On ajoute les news au message.
**

$fichier_message .= '</ul></body>
</html>'; // On termine le message.


// On récupère de la table newsletter les personnes inscrites.
$liste_vrac = mysql_query("SELECT email FROM newsletter");

// On définit la liste des inscrits.
$liste = 'monsite@monsite.fr';
while ($donnees = mysql_fetch_assoc($liste_vrac))
{
$liste .= ','; //On sépare les adresses par une virgule.
$liste .= $donnees['email'];
**
$message = $fichier_message;
$destinataire = $liste;

$date = date("d/m/Y");

$objet = "Newsletter de MonSite.fr du $date"; // On définit l'objet qui contient la date.

// On définit le reste des paramètres.
$headers = 'MIME-Version: 1.0' . '\r\n';
$headers .= 'Content-type: text/html; charset=iso-8859-1' . '\r\n';
$headers .= 'From: monsite@monsite.fr' . '\r\n'; // On définit l'expéditeur.
$headers .= 'Bcc:' . $liste . '' . '\r\n'; // On définit les destinataires en copie cachée pour qu'ils ne puissent pas voir les adresses des autres inscrits.

// On envoie l'e-mail.
if ( mail($destinataire, $objet, $fichier_message, $headers) )
{
?>
Envoi de la newsletter réussi.
<?php
**
else
{
?>
Échec de l'envoi de la newsletter.
<?php
**
?>
<br /><br /><u>Liste des inscrits :</u><br />
<table>
<tr>
<th>e-mail</th>
</tr>
<?php

$liste_inscrits_vrac = mysql_query("SELECT email FROM newsletter"); //On récupère la table newsletter en vrac.
while ($donnees = mysql_fetch_assoc($liste_inscrits_vrac))
{
?>

<tr>
<td><?php echo ($donnees['email']); ?></td>
</tr>

<?php
**
?>
</table>
</body>
</html>

j'ai fais toutes les changement nécessaires qui considère la base de données et les liens et le script marche mais il n'envoie pas les messages de validation d'inscription ou désinscription que de fois en+ il y a un problème dans la page d'envoi de newsletter 'newsletter.php' il n'affice pas la liste des inscrits et il affiche cet erreur " Warning: mysql_fetch_assoc(): supplied argument is not a valid MySQL result resource in news.php on line 104 ""



A voir également:

3 réponses

kbibi99 Messages postés 12 Date d'inscription   Statut Membre Dernière intervention   1
 
c la ligne 104 while ($donnees = mysql_fetch_assoc($liste_inscrits_vrac))
et ca de la ligne 101 jusqu'a la ligne 106
<?php

$liste_inscrits_vrac = mysql_query("SELECT email FROM newsletter"); //On récupère la table newsletter en vrac.
while ($donnees = mysql_fetch_assoc($liste_inscrits_vrac))
{
?>
1
Freedomsoul Messages postés 509 Date d'inscription   Statut Membre Dernière intervention   97
 
Et pourrait tu nous indiquer plus précisément la ligne concerné ?
Ce problème vient apparemment d'un requête SQL qui est mal exécutée
0
bg62 Messages postés 23733 Date d'inscription   Statut Modérateur Dernière intervention   2 409
 
il existe des "scripts" en open source ... pourquoi te casser la tête pour essayer de faire ... ???
0