Posted on: 17 avr 2008
Tutorial Paypal : La récupération des données par IPN
Vous devez avoir suivi l’étape 2 Création du bouton HTML “Acheter maintenant” avant de passer à celle-ci.
Passons maintenant à la page de récupération des données
notify.php qui devra être placé à l’adresse indiqué dans la variable notify_url de votre bouton dans cet exemple : http://www.monsite.com/paypal/notify.php
tout d’abord nous devons créer dans notre base de donnée une table qui contiendra l’historique des transactions paypal.
j’utilise ici l’exemple donné par PaypalTech.com qui va nous permettre d’arriver à nos fins
Voici les tables à créer dans votre base de donnée :
-
-
# Table structure for table `paypal_cart_info` #CREATE TABLE `paypal_cart_info` ( `txnid` varchar(30) NOT NULL default ”, `itemname` varchar(255) NOT NULL default ”, `itemnumber` varchar(50) default NULL, `os0` varchar(20) default NULL, `on0` varchar(50) default NULL, `os1` varchar(20) default NULL, `on1` varchar(50) default NULL, `quantity` char(3) NOT NULL default ”, `invoice` varchar(255) NOT NULL default ”, `custom` varchar(255) NOT NULL default ” ) TYPE=MyISAM;
-
-
# Table structure for table `paypal_subscription_info` #
-
-
CREATE TABLE `paypal_subscription_info` ( `subscr_id` varchar(255) NOT NULL DEFAULT ”, `sub_event` varchar(50) NOT NULL DEFAULT ”, `subscr_date` varchar(255) NOT NULL DEFAULT ”, `subscr_effective` varchar(255) NOT NULL DEFAULT ”, `period1` varchar(255) NOT NULL DEFAULT ”, `period2` varchar(255) NOT NULL DEFAULT ”, `period3` varchar(255) NOT NULL DEFAULT ”, `amount1` varchar(255) NOT NULL DEFAULT ”, `amount2` varchar(255) NOT NULL DEFAULT ”, `amount3` varchar(255) NOT NULL DEFAULT ”, `mc_amount1` varchar(255) NOT NULL DEFAULT ”, `mc_amount2` varchar(255) NOT NULL DEFAULT ”, `mc_amount3` varchar(255) NOT NULL DEFAULT ”, `recurring` varchar(255) NOT NULL DEFAULT ”, `reattempt` varchar(255) NOT NULL DEFAULT ”, `retry_at` varchar(255) NOT NULL DEFAULT ”, `recur_times` varchar(255) NOT NULL DEFAULT ”, `username` varchar(255) NOT NULL DEFAULT ”, `password` varchar(255) DEFAULT NULL, `payment_txn_id` varchar(50) NOT NULL DEFAULT ”, `subscriber_emailaddress` varchar(255) NOT NULL DEFAULT ”, `datecreation` date NOT NULL DEFAULT ‘0000-00-00′ ) TYPE=MyISAM;
-
-
# Table structure for table `paypal_payment_info` #
-
-
CREATE TABLE `paypal_payment_info` ( `firstname` varchar(100) NOT NULL DEFAULT ”, `lastname` varchar(100) NOT NULL DEFAULT ”, `buyer_email` varchar(100) NOT NULL DEFAULT ”, `street` varchar(100) NOT NULL DEFAULT ”, `city` varchar(50) NOT NULL DEFAULT ”, `state` char(3) NOT NULL DEFAULT ”, `zipcode` varchar(11) NOT NULL DEFAULT ”, `memo` varchar(255) DEFAULT NULL, `itemname` varchar(255) DEFAULT NULL, `itemnumber` varchar(50) DEFAULT NULL, `os0` varchar(20) DEFAULT NULL, `on0` varchar(50) DEFAULT NULL, `os1` varchar(20) DEFAULT NULL, `on1` varchar(50) DEFAULT NULL, `quantity` char(3) DEFAULT NULL, `paymentdate` varchar(50) NOT NULL DEFAULT ”, `paymenttype` varchar(10) NOT NULL DEFAULT ”, `txnid` varchar(30) NOT NULL DEFAULT ”, `mc_gross` varchar(6) NOT NULL DEFAULT ”, `mc_fee` varchar(5) NOT NULL DEFAULT ”, `paymentstatus` varchar(15) NOT NULL DEFAULT ”, `pendingreason` varchar(10) DEFAULT NULL, `txntype` varchar(10) NOT NULL DEFAULT ”, `tax` varchar(10) DEFAULT NULL, `mc_currency` varchar(5) NOT NULL DEFAULT ”, `reasoncode` varchar(20) NOT NULL DEFAULT ”, `custom` varchar(255) NOT NULL DEFAULT ”, `country` varchar(20) NOT NULL DEFAULT ”, `datecreation` date NOT NULL DEFAULT ‘0000-00-00′ ) TYPE=MyISAM;
et voici maintenant la structure de notre fichier
-
$DB_Server = "localhost"; // Votre serveur de Base de donnée
-
-
$DB_Username = "toto"; //nom de l’utilisateur
-
-
$DB_Password = "pass"; // password
-
-
$DB_DBName = "nom_base"; // nom de la base
-
-
//create MySQL connection
-
-
-
-
//select database
-
-
-
-
$notify_email = "votremailréel@mail.com"; // Email ou vous allez recevoir le résultat du paiement
-
-
/////////////////////////////////////////////////
-
-
/////////////Begin Script below./////////////////
-
-
/////////////////////////////////////////////////
-
-
$paypal[’serveur’] = ‘www.sandbox.paypal.com’; //mode test
-
-
//$paypal['serveur'] = ‘www.paypal.com’; A activer quand on passera en mode réel
-
-
// read the post from PayPal system and add ‘cmd’
-
-
$req = ‘cmd=_notify-validate’;
-
-
foreach ($_POST as $key => $value) {
-
-
-
$req .= "&$key=$value";
-
-
}
-
-
// post back to PayPal system to validate
-
-
$header = "POST /cgi-bin/webscr HTTP/1.0\r\n";
-
-
$header .= "Content-Type: application/x-www-form-urlencoded\r\n";
-
-
-
-
// assign posted variables to local variables
-
-
$item_name = $_POST[‘item_name’];
-
-
$business = $_POST[‘business’];
-
-
$item_number = $_POST[‘item_number’];
-
-
$payment_status = $_POST[‘payment_status’];
-
-
$mc_gross = $_POST[‘mc_gross’];
-
-
$payment_currency = $_POST[‘mc_currency’];
-
-
$txn_id = $_POST[‘txn_id’];
-
-
$receiver_email = $_POST[‘receiver_email’];
-
-
$receiver_id = $_POST[‘receiver_id’];
-
-
$quantity = $_POST[‘quantity’];
-
-
$num_cart_items = $_POST[‘num_cart_items’];
-
-
$payment_date = $_POST[‘payment_date’];
-
-
$first_name = $_POST[‘first_name’];
-
-
$last_name = $_POST[‘last_name’];
-
-
$payment_type = $_POST[‘payment_type’];
-
-
$payment_status = $_POST[‘payment_status’];
-
-
$payment_gross = $_POST[‘payment_gross’];
-
-
$payment_fee = $_POST[‘payment_fee’];
-
-
$settle_amount = $_POST[’settle_amount’];
-
-
$memo = $_POST[‘memo’];
-
-
$payer_email = $_POST[‘payer_email’];
-
-
$txn_type = $_POST[‘txn_type’];
-
-
$payer_status = $_POST[‘payer_status’];
-
-
$address_street = $_POST[‘address_street’];
-
-
$address_city = $_POST[‘address_city’];
-
-
$address_state = $_POST[‘address_state’];
-
-
$address_zip = $_POST[‘address_zip’];
-
-
$address_country = $_POST[‘address_country’];
-
-
$address_status = $_POST[‘address_status’];
-
-
$item_number = $_POST[‘item_number’];
-
-
$tax = $_POST[‘tax’];
-
-
$option_name1 = $_POST[‘option_name1′];
-
-
$option_selection1 = $_POST[‘option_selection1′];
-
-
$option_name2 = $_POST[‘option_name2′];
-
-
$option_selection2 = $_POST[‘option_selection2′];
-
-
$for_auction = $_POST[‘for_auction’];
-
-
$invoice = $_POST[‘invoice’];
-
-
$custom = $_POST[‘custom’];
-
-
$notify_version = $_POST[‘notify_version’];
-
-
$verify_sign = $_POST[‘verify_sign’];
-
-
$payer_business_name = $_POST[‘payer_business_name’];
-
-
$payer_id =$_POST[‘payer_id’];
-
-
$mc_currency = $_POST[‘mc_currency’];
-
-
$mc_fee = $_POST[‘mc_fee’];
-
-
$exchange_rate = $_POST[‘exchange_rate’];
-
-
$settle_currency = $_POST[’settle_currency’];
-
-
$parent_txn_id = $_POST[‘parent_txn_id’];
-
-
$pending_reason = $_POST[‘pending_reason’];
-
-
$reason_code = $_POST[‘reason_code’];
-
-
// subscription specific vars
-
-
$subscr_id = $_POST[’subscr_id’];
-
-
$subscr_date = $_POST[’subscr_date’];
-
-
$subscr_effective = $_POST[’subscr_effective’];
-
-
$period1 = $_POST[‘period1′];
-
-
$period2 = $_POST[‘period2′];
-
-
$period3 = $_POST[‘period3′];
-
-
$amount1 = $_POST[‘amount1′];
-
-
$amount2 = $_POST[‘amount2′];
-
-
$amount3 = $_POST[‘amount3′];
-
-
$mc_amount1 = $_POST[‘mc_amount1′];
-
-
$mc_amount2 = $_POST[‘mc_amount2′];
-
-
$mc_amount3 = $_POST[‘mcamount3′];
-
-
$recurring = $_POST[‘recurring’];
-
-
$reattempt = $_POST[‘reattempt’];
-
-
$retry_at = $_POST[‘retry_at’];
-
-
$recur_times = $_POST[‘recur_times’];
-
-
$username = $_POST[‘username’];
-
-
$password = $_POST[‘password’];
-
-
//auction specific vars
-
-
$for_auction = $_POST[‘for_auction’];
-
-
$auction_closing_date = $_POST[‘auction_closing_date’];
-
-
$auction_multi_item = $_POST[‘auction_multi_item’];
-
-
$auction_buyer_id = $_POST[‘auction_buyer_id’];
-
-
if (!$fp) {
-
-
// HTTP ERROR
-
-
} else {
-
-
-
-
-
-
-
-
//check if transaction ID has been processed before
-
-
$checkquery = "select txnid from paypal_payment_info where txnid=’".$txn_id."’";
-
-
-
-
if ($nm == 0){
-
-
//execute query
-
-
if ($txn_type == "cart"){ //cas du panier (non évoqué dans ce tuto
-
-
$strQuery = "insert into paypal_payment_info(paymentstatus,buyer_email,firstname,lastname,street,city,state,zipcode,country,mc_gross,mc_fee,memo,paymenttype,paymentdate,txnid,pendingreason,reasoncode,tax,datecreation,custom) values (’".$payment_status."’,'".$payer_email."’,'".$first_name."’,'".$last_name."’,'".$address_street."’,'".$address_city."’,'".$address_state."’,'".$address_zip."’,'".$address_country."’,'".$mc_gross."’,'".$mc_fee."’,'".$memo."’,'".$payment_type."’,'".$payment_date."’,'".$txn_id."’,'".$pending_reason."’,'".$reason_code."’,'".$tax."’,'".$fecha."’,'".$custom."’)";
-
-
-
for ($i = 1; $i <= $num_cart_items; $i++) {
-
-
$itemname = "item_name".$i;
-
-
$itemnumber = "item_number".$i;
-
-
$on0 = "option_name1_".$i;
-
-
$os0 = "option_selection1_".$i;
-
-
$on1 = "option_name2_".$i;
-
-
$os1 = "option_selection2_".$i;
-
-
$quantity = "quantity".$i;
-
-
$struery = "insert into paypal_cart_info(txnid,itemnumber,itemname,os0,on0,os1,on1,quantity,invoice,custom) values (’".$txn_id."’,'".$_POST[$itemnumber]."’,'".$_POST[$itemname]."’,'".$_POST[$on0]."’,'".$_POST[$os0]."’,'".$_POST[$on1]."’,'".$_POST[$os1]."’,'".$_POST[$quantity]."’,'".$invoice."’,'".$custom."’)";
-
-
-
}
-
-
}
-
-
else{ // notre cas celui du bouton à achat immédiat
-
-
$strQuery = "insert into paypal_payment_info(paymentstatus,buyer_email,firstname,lastname,street,city,state,zipcode,country,mc_gross,mc_fee,itemnumber,itemname,os0,on0,os1,on1,quantity,memo,paymenttype,paymentdate,txnid,pendingreason,reasoncode,tax,datecreation,custom) values (’".$payment_status."’,'".$payer_email."’,'".$first_name."’,'".$last_name."’,'".$address_street."’,'".$address_city."’,'".$address_state."’,'".$address_zip."’,'".$address_country."’,'".$mc_gross."’,'".$mc_fee."’,'".$item_number."’,'".$item_name."’,'".$option_name1."’,'".$option_selection1."’,'".$option_name2."’,'".$option_selection2."’,'".$quantity."’,'".$memo."’,'".$payment_type."’,'".$payment_date."’,'".$txn_id."’,'".$pending_reason."’,'".$reason_code."’,'".$tax."’,'".$fecha."’,'".$custom."’)";
-
-
-
// ajoute dans la table créer le récapitulatif du paiement paypal
-
-
// ensuite on réalise notre propre traitement par exemple ajout de crédit à un utilisateur etc etc
-
-
//traitement propre à votre site
-
$Member_ID=$tableau[0];
-
$Object_ID=$tableau[1];
-
-
requete sql etc
-
….
-
-
…
-
-
…
-
-
….
-
-
}
-
-
// envoie un email de resultat
-
-
echo "Verified";
-
-
mail($notify_email, "VERIFIED IPN", "$res\n $req\n $strQuery\n $struery\n $strQuery2","From: vente@votresite.com");
-
-
}
-
-
else {
-
-
// send an email
-
-
mail($notify_email, "VERIFIED DUPLICATED TRANSACTION", "$res\n $req \n $strQuery\n $struery\n $strQuery2");
-
-
}
-
-
//subscription handling branch
-
-
if ( $txn_type == "subscr_signup" || $txn_type == "subscr_payment" ) {
-
-
// insert subscriber payment info into paypal_payment_info table
-
-
$strQuery = "insert into paypal_payment_info(paymentstatus,buyer_email,firstname,lastname,street,city,state,zipcode,country,mc_gross,mc_fee,memo,paymenttype,paymentdate,txnid,pendingreason,reasoncode,tax,datecreation,custom) values (’".$payment_status."’,'".$payer_email."’,'".$first_name."’,'".$last_name."’,'".$address_street."’,'".$address_city."’,'".$address_state."’,'".$address_zip."’,'".$address_country."’,'".$mc_gross."’,'".$mc_fee."’,'".$memo."’,'".$payment_type."’,'".$payment_date."’,'".$txn_id."’,'".$pending_reason."’,'".$reason_code."’,'".$tax."’,'".$fecha."’,'".$custom."’)";
-
-
-
// insert subscriber info into paypal_subscription_info table
-
-
$strQuery2 = "insert into paypal_subscription_info(subscr_id , sub_event, subscr_date ,subscr_effective,period1,period2, period3, amount1 ,amount2 ,amount3, mc_amount1, mc_amount2, mc_amount3, recurring, reattempt,retry_at, recur_times, username ,password, payment_txn_id, subscriber_emailaddress, datecreation) values (’".$subscr_id."’, ‘".$txn_type."’,'".$subscr_date."’,'".$subscr_effective."’,'".$period1."’,'".$period2."’,'".$period3."’,'".$amount1."’,'".$amount2."’,'".$amount3."’,'".$mc_amount1."’,'".$mc_amount2."’,'".$mc_amount3."’,'".$recurring."’,'".$reattempt."’,'".$retry_at."’,'".$recur_times."’,'".$username."’,'".$password."’, ‘".$txn_id."’,'".$payer_email."’,'".$fecha."’)";
-
-
-
-
}
-
-
}
-
-
// si le paiement n’est pas valide
-
-
-
// log for manual investigation
-
-
-
}
-
-
}
-
-
-
}
-
-
?>
Une fois les test effectués en version virtuelle il ne vous restera plus qu’a modifier l’url www.sandbox.paypal.com présente dans les scripts par www.paypal.com et à donner votre vrai email paypal de vendeur
Dans une deuxième partie nous verrons comment crypter le bouton pour que les variables n’apparaissent pas dans le code source et pour éviter les fraudes
Si vous avez trouvez ce tutorial utile n’hésitez pas à laisser un commentaire ou à
[...] Etape 3 : La récupération des données par IPN [...]
[...] Contact « Tutorial Paypal : La récupération des données par IPN [...]
Hello
Merci beaucoup pour le tuto.
Qui clarifie encore plus ce que qu’avait déjà bien clarifié celui-ci :
http://www.wikistuce.info/doku.php/articles/mise_en_place_d_un_paiement_paypal_sur_site_marchand?#%5B1%5D
Ce qui m’interresse beaucoup, c’est justement le cryptage.
Je reprend mon post sur le site évoqué plus haut (auquel Emile m’a répondu) :
——————
“Je travaille sur la Sandbox. Comme tu le conseilles, j’obtiens certif et clé par le biais du site : http://www.stellarwebsolutions.com/certificates/stellar_cert_builder.php Et je télécharge le certif paypal sans oublier de copier le cert_id obtenu.
bien.
J’ai bien tout checké, dans mon certif perso, j’ai bien la même adresse email que celle du compte vendeur confirmé sur la Sandbox. Mais je tombe en permanence sur cette erreur lors du test :
Nous ne sommes pas en mesure de traiter cette transaction en raison d’un problème concernant l’adresse email PayPal fournie par le vendeur. Veuillez contacter le vendeur afin de résoudre ce problème. Si ce paiement (…)
Aurais-tu des indices de résolution concernant ce message d’erreur ?? J’ai tout bien respecté, et je dois passer en prod réelle le plus rapidement possible, je craque… (Note : j’avais installé openssl sur mon apache pour créer les clé et certif au nom de mon client, et je les garde sous le coude pour réaliser l’opération en réel dés que tout sera ok)”
——————
Merci d’avance pour l’entraide
joss
Intéressant, vos explication vont me faire gagner du temps.
Pouvez vous fournir le fichier contenant la structure de la table sql ?
(Le copier/coller provoque une erreur au moment de la creation)
il est disponible ici http://paypaltech.com/SG2/PHPDBSQL_code.php
pourriez vous m expliquer pourquoi nous avons besoin de nous connecter au serveur de paypal via fsockopen.
on se connecte sur le serveur pour ouvrir un fichier ???
on lit dans le fichier le resultat ?
et en fonction du resultat ou mets a jour la base ?
c ca ?
je ne comprends pas trop la methode..
merci pour vos explications.
j ai fait quelques recherche .. je crois qu il faur renvoyer a paypal via fsockopen les post recu pour qu il verifie l exactitute
des infos.
c ca ?
j ai créé un les comptes business et acheteur.
j ai créé mon fichier NIP.PHP
quand je simule un achat mon fichier php est bien appelé ….
j ouvre la connection →$fp = fsockopen (’www.sandbox.paypal.com’, 80, $errno, $errstr, 30);
j envoie la requette : fputs ($fp, $header . $req);
mai la reponse de paypal n est jamais validate…. j ai alors decide d enregister la reponse de paypal pour comprendre
j ai enregsitre dans une base la reponse: $res —> $res = fgets ($fp, 1024);
voila ce que j ai :
HTTP/1.1 307 Temporary Redirect
Server: NS8.0.45.4
Location: https://www.sandbox.paypal.com/cgi-bin/webscr
Content Type: text/html
Cache Control: private
Connection: close
This object may be found here
pourriez m expliquer pour quoi j ai cette reponse et pas un VALIDATE
merci merci a celui qui pourra m aider
Voici une citation d’un mec de PayPal qui date d’hier:
Bonjour,
Nous avons un probleme avec les IPNs Sandbox pour le moment.
En fait, nos techniciens font des mises a jour pour que IPN passe par le port 80(sécurisé maintenant et cela n’est pas encore au point (pas de problemes a noter en production par contre pour le moment).
Ce qu’il faut que vous fassiez est remplacer le port 80 par le port 443 ($fp = fsockopen (’www.sandbox.paypal.com’, 443, $errno, $errstr, 30); et cela devrait fonctionner.
Merci
Cordialement,
Florian
bonjour, j’ai le même problème qu’hubi.
J’ai testé la soluce de stefkiller malheureusement ça ne fonctionne pas.
Voici le résultat avec le port 443 :
…
400 Bad Request
Bad Request
Your browser sent a request that this server co…
Instead use the HTTPS scheme to access this URL, p…
solution : mettre le protocole ssl avec l’adresse de sandbox
$fp = fsockopen (’ssl://www.sandbox.paypal.com’, 443, $errno, $errstr, 30);
Attention le & ligne 45 ne passe pas, il faut le remplacer par &
Bonjour,
J’ai recopier le Script PHP pour mon IPN, creer la base de données. A un renvoi des informations par Sandbox de Paypal.
Le payement se réalise bien, mais je reçois toujours :
INVALID
cmd=_notify-validate
Quelqu’un aurait une idée du pourquoi ?
J’ai le même problème que constantine, à l’aide svp
Bonjour,
Super tuto, merci
Pour Constantine et fox7725, j’ai rencontré le même problème que vous et après de multiples tests, j’ai testé la solution proposée plus tôt : remplacer le & ligne 45 et ça fonctionne.
Attention aussi pendant vos tests si vous gardez toujours les même valeurs dans vos champs de formulaire, si votre compte marchand n’accepte pas la facturation multiple, la transaction ne sera valide qu’après validation du marchand dans son compte. Pour éviter celà, il faut modifier les préférences.
Bonne journée
slt, ce tutorial est fè pr testé des compte paypal ou directemnt pr des paiement par carte bancaire ?
de plus ma base de donné ne se rempli pa, meme kan j’arrive a simulé un paiement mè seulement par compte paypal, pourriez maidez svp, merci.
kelk1 peu m’expliker prk il faut remplacer a ligne 45 le & par un & ki est le meme symbole? en faite par kel symbole doit on remplacer le & ligne 45? merci de m’aider svp
Alors, j ‘ai moi aussi eu quelques difficultés à comprendre pourquoi en utilisant mes comptes de sandbox ma table ne se remplissait pas.
Après recherche, il s’avère que la valeur présente dans “$res” est vide pour un paiement par CB. Donc pour inscrire dans la DB le résultat d’un paiement, il faut lever (virer) le test “if (strcmp ($res, “VERIFIED”) == 0)) { //” (vers la ligne 100 chez moi)
Voilà pour ceux qui ça pourrait intéresser…
[...] Etape 3 : La récupération des données par IPN [...]
Bon je vous explique, je suis super nul pour tout ca mais je fais l’effort d’essayer comprendre.
j’ai bien compris les 2 premieres parties mais pas la deniere.
Je suis auteur/compositeur/interprete, je cherche désespérement a vendre ma musique via paypal sans passer par les sites spécialisés.
Mon idéal serait un bouton paypal sur myspace, qui permette l’achat et le telechargement d’une chanson.J’ecume les forums et je ne trouve rien sur la partie telechargement du fichier mp3 a moins que je regarde mal. vous pouvez m’orienter ?
pour ceux qui savent pas quoi remplacer a la ligne 45 c’est “& amp ;” qui affiche le symbole &
bon j’ai tout implanter correctement, il me semble, mais je ne réussi pas a recevoir les résultats apres que le paiement aie passé dans paypal.. faut-il que mon fichier php qui recoit les données soit dans une forme quelqu’onque???
bonjour
ça fait 3j que jje suis en train de créer un formulaire d’adhésion en ligne pour le site d’une asso et je galère comme une malade pour brancher le paiement paypal.
n’ayant jamais réussi à faire marcher la sandbox (je crois que les développeurs qui passent par free ont en majorité ce pb), je testais en live, avec ma cb sur le compte paypal de mon mari.. seulement volià, par mesure de “sécurité”, paypal bloque au bout de 10 tests.. bilan, je ne peux plus tester, j’ai le message “pour effectuer cette transaction vous devez créer un compte paypal ou utiliser une autre carte”… super pratique… je fais donc faire les transactions par un ami jusqu’à ce que lui aussi soit bloqué.. bref.
en attendant : il réussi bien à payer par cb, et reçoit bien la confimation paypal pour son paiement (qu’on annule ensuite évidemment). coté ipn, on a bien mentionné un retour ipn sur le compte de mon mari et en plus, je lui passe la variable “notify_url” .
j’ai voulu faire un module ipn tout simple:
- si l’adhérent a bien réglé on lui envoie un mail confirmant son adhésion et on envoie à l’asso un mail avec les coordonnées de l’adhérent.
et c’est là, qu’il ne se passe rien…
je copicolle en dessous mon retour_ipn qui est peut-être trop simpliste? en même temps c’est pas un site marchand avec possibilité d’arnaque et tout ça..
est-ce que vous voyez quelque chose qui cloche dans ce que j’ai fait?
merci de votre aide
donia qui galère….
<?php
session_start();
$payment_status = $_POST['payment_status'];
$date = $_POST['payment_date'];
if($payment_status==”Completed”) {
// paiement ok
$mail=$_SESSION['mail'];
/////////////////////////////////
// envoi d’un mail à l’adhérent
////////////////////////////////
$objet = “Votre adhésion à l\’AFPAEC”;
$nomexp = “AFPAEC”;
$adrexp = “afpaec@yahoo.fr”;
$message=’
Bonjour,
Votre adhésion a l\’AFPAEC a bien été prise en compte. Nous vous remercions de votre confiance et votre soutien.
Vous recevrez d\’ici quelques jours votre carte de membre qui sera valable un an à partir d\’aujourd\’hui.
Cordialement.
L\’équipe de l\’Association Française des Parents Adoptifs d\’Enfants de Chine (AFPAEC)
http://afpaec.org
‘;
$message = stripslashes($message); // traitement de la variable message pour virer les antislash
$messageHTML = $message;
$headers =”From: $nomexp”.”".”\n”;
$headers .=”Reply-To: $adrexp”.”\n”;
$headers .=’Content-Type: text/html; charset=”iso-8859-1″‘.”\n”;
$headers .=’Content-Transfer-Encoding: 8bit’;
mail($mail, $objet, $messageHTML, $headers)
////////////////////////////////
// envoi d’un mail chez nous
////////////////////////////////
$objet = “Adhésion AFPAEC”;
$nomexp = “AFPAEC”;
$adrexp = “afpaec@yahoo.fr”;
$message=’
nouvelle adhésion reçue:
date paiement : ‘.$_POST['payment_date'].’;
nom : ‘.$_SESSION['nom'].’
prenom : ‘.$_SESSION['prenom'].’
adresse1 : ‘.$_SESSION['adresse1'].’
adresse2 : ‘.$_SESSION['adresse2'].’
ville : ‘.$_SESSION['ville'].’
code postal : ‘.$_SESSION['codepostal'].’
tel1 : ‘.$_SESSION['tel1'].’
tel2 : ‘.$_SESSION['tel2'].’
mail : ‘.$_SESSION['mail'].’
typemembre : ‘.$_SESSION['typemembre'].’
montantversement : ‘.$_SESSION['montantversement'].’
Enfant de Chine : ‘.$_SESSION['enfantchine'].’
NbChine : ‘.$_SESSION['nbenfant'].’
adoption en cours : ‘.$_SESSION['encoursadoption'].’
organisme : ‘.$_SESSION['organisme'].’
date LID : ‘.$_SESSION['datedossier'].’
donner coordonnees : ‘.$_SESSION['donnercoordonnees'].’
donner fixe : ‘.$_SESSION['donnerfixe'].’
donner portable : ‘.$_SESSION['donnerportable'].’
donnermail : ‘.$_SESSION['donnermail'].’
commentaire : ‘.$_SESSION['commentaire'].’
‘;
$message = stripslashes($message); // traitement de la variable message pour virer les antislash
$messageHTML = $message;
$headers =”From: $nomexp”.”".”\n”;
$headers .=”Reply-To: $adrexp”.”\n”;
$headers .=’Content-Type: text/html; charset=”iso-8859-1″‘.”\n”;
$headers .=’Content-Transfer-Encoding: 8bit’;
mail($mail, $objet, $messageHTML, $headers)
}
else
{
// Paiement PAYPAL a échoué
////////////////////////////////
// envoi d’un mail chez nous
////////////////////////////////
$objet = “Adhésion AFPAEC ECHOUEE”;
$nomexp = “AFPAEC”;
$adrexp = “afpaec@yahoo.fr”;
$message=’
————Adhésion échouée————–:
date paiement : ‘.$_POST['payment_date'].’;
nom : ‘.$_SESSION['nom'].’
prenom : ‘.$_SESSION['prenom'].’
adresse1 : ‘.$_SESSION['adresse1'].’
adresse2 : ‘.$_SESSION['adresse2'].’
ville : ‘.$_SESSION['ville'].’
code postal : ‘.$_SESSION['codepostal'].’
tel1 : ‘.$_SESSION['tel1'].’
tel2 : ‘.$_SESSION['tel2'].’
mail : ‘.$_SESSION['mail'].’
typemembre : ‘.$_SESSION['typemembre'].’
montantversement : ‘.$_SESSION['montantversement'].’
Enfant de Chine : ‘.$_SESSION['enfantchine'].’
NbChine : ‘.$_SESSION['nbenfant'].’
adoption en cours : ‘.$_SESSION['encoursadoption'].’
organisme : ‘.$_SESSION['organisme'].’
date LID : ‘.$_SESSION['datedossier'].’
donner coordonnees : ‘.$_SESSION['donnercoordonnees'].’
donner fixe : ‘.$_SESSION['donnerfixe'].’
donner portable : ‘.$_SESSION['donnerportable'].’
donnermail : ‘.$_SESSION['donnermail'].’
commentaire : ‘.$_SESSION['commentaire'].’
‘;
$message = stripslashes($message); // traitement de la variable message pour virer les antislash
$messageHTML = $message;
$headers =”From: $nomexp”.”".”\n”;
$headers .=”Reply-To: $adrexp”.”\n”;
$headers .=’Content-Type: text/html; charset=”iso-8859-1″‘.”\n”;
$headers .=’Content-Transfer-Encoding: 8bit’;
mail($mail, $objet, $messageHTML, $headers)
}
?>
kelk1 pourrai me laissé un exmple concrè pr utiliser la variable $custom, sinon si kelk1 a réussi a faire fonctionné le tuto, pourè t il me laissé son adresse mail. merci
@jacksparo :
dans la variable custom tu mets ce que tu veux, exemple : l’ID de l’item vendu.
Ce sera utile lorsque PayPal va te réenvoyer les infos de paiements, tu pourras déterminer ce qui a été acheté.