Filed under: paypal   by admin

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 :

  1.  
  2. # 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;
  3.  
  4. # Table structure for table `paypal_subscription_info` #
  5.  
  6. 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;
  7.  
  8. # Table structure for table `paypal_payment_info` #
  9.  
  10. 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

  1. $DB_Server = "localhost"; // Votre serveur de Base de donnée
  2.  
  3. $DB_Username = "toto"; //nom de l’utilisateur
  4.  
  5. $DB_Password = "pass"; // password
  6.  
  7. $DB_DBName = "nom_base"; // nom de la base
  8.  
  9. //create MySQL connection
  10.  
  11. $Connect = @mysql_connect($DB_Server, $DB_Username, $DB_Password)
  12.  
  13. or die("Couldn’t connect to MySQL:
  14. " . mysql_error() . "
  15. " . mysql_errno());
  16.  
  17. //select database
  18.  
  19. $Db = @mysql_select_db($DB_DBName, $Connect)
  20.  
  21. or die("Couldn’t select database:
  22. " . mysql_error(). "
  23. " . mysql_errno());
  24.  
  25. $notify_email =  "votremailréel@mail.com";         // Email ou vous allez recevoir le résultat du paiement
  26.  
  27. /////////////////////////////////////////////////
  28.  
  29. /////////////Begin Script below./////////////////
  30.  
  31. /////////////////////////////////////////////////
  32.  
  33. $paypal[’serveur’] = ‘www.sandbox.paypal.com’;      //mode test
  34.  
  35. //$paypal['serveur'] = ‘www.paypal.com’;             A activer quand on passera en mode réel
  36.  
  37. // read the post from PayPal system and add ‘cmd’
  38.  
  39. $req = ‘cmd=_notify-validate’;
  40.  
  41. foreach ($_POST as $key => $value) {
  42.  
  43. $value = urlencode(stripslashes($value));
  44.  
  45. $req .= "&$key=$value";
  46.  
  47. }
  48.  
  49. // post back to PayPal system to validate
  50.  
  51. $header = "POST /cgi-bin/webscr HTTP/1.0\r\n";
  52.  
  53. $header .= "Content-Type: application/x-www-form-urlencoded\r\n";
  54.  
  55. $header .= "Content-Length: " . strlen($req) . "\r\n\r\n";
  56.  
  57. $fp = fsockopen ($paypal[’serveur’], 80, $errno, $errstr, 30);
  58.  
  59. // assign posted variables to local variables
  60.  
  61. $item_name = $_POST[‘item_name’];
  62.  
  63. $business = $_POST[‘business’];
  64.  
  65. $item_number = $_POST[‘item_number’];
  66.  
  67. $payment_status = $_POST[‘payment_status’];
  68.  
  69. $mc_gross = $_POST[‘mc_gross’];
  70.  
  71. $payment_currency = $_POST[‘mc_currency’];
  72.  
  73. $txn_id = $_POST[‘txn_id’];
  74.  
  75. $receiver_email = $_POST[‘receiver_email’];
  76.  
  77. $receiver_id = $_POST[‘receiver_id’];
  78.  
  79. $quantity = $_POST[‘quantity’];
  80.  
  81. $num_cart_items = $_POST[‘num_cart_items’];
  82.  
  83. $payment_date = $_POST[‘payment_date’];
  84.  
  85. $first_name = $_POST[‘first_name’];
  86.  
  87. $last_name = $_POST[‘last_name’];
  88.  
  89. $payment_type = $_POST[‘payment_type’];
  90.  
  91. $payment_status = $_POST[‘payment_status’];
  92.  
  93. $payment_gross = $_POST[‘payment_gross’];
  94.  
  95. $payment_fee = $_POST[‘payment_fee’];
  96.  
  97. $settle_amount = $_POST[’settle_amount’];
  98.  
  99. $memo = $_POST[‘memo’];
  100.  
  101. $payer_email = $_POST[‘payer_email’];
  102.  
  103. $txn_type = $_POST[‘txn_type’];
  104.  
  105. $payer_status = $_POST[‘payer_status’];
  106.  
  107. $address_street = $_POST[‘address_street’];
  108.  
  109. $address_city = $_POST[‘address_city’];
  110.  
  111. $address_state = $_POST[‘address_state’];
  112.  
  113. $address_zip = $_POST[‘address_zip’];
  114.  
  115. $address_country = $_POST[‘address_country’];
  116.  
  117. $address_status = $_POST[‘address_status’];
  118.  
  119. $item_number = $_POST[‘item_number’];
  120.  
  121. $tax = $_POST[‘tax’];
  122.  
  123. $option_name1 = $_POST[‘option_name1′];
  124.  
  125. $option_selection1 = $_POST[‘option_selection1′];
  126.  
  127. $option_name2 = $_POST[‘option_name2′];
  128.  
  129. $option_selection2 = $_POST[‘option_selection2′];
  130.  
  131. $for_auction = $_POST[‘for_auction’];
  132.  
  133. $invoice = $_POST[‘invoice’];
  134.  
  135. $custom = $_POST[‘custom’];
  136.  
  137. $notify_version = $_POST[‘notify_version’];
  138.  
  139. $verify_sign = $_POST[‘verify_sign’];
  140.  
  141. $payer_business_name = $_POST[‘payer_business_name’];
  142.  
  143. $payer_id =$_POST[‘payer_id’];
  144.  
  145. $mc_currency = $_POST[‘mc_currency’];
  146.  
  147. $mc_fee = $_POST[‘mc_fee’];
  148.  
  149. $exchange_rate = $_POST[‘exchange_rate’];
  150.  
  151. $settle_currency  = $_POST[’settle_currency’];
  152.  
  153. $parent_txn_id  = $_POST[‘parent_txn_id’];
  154.  
  155. $pending_reason = $_POST[‘pending_reason’];
  156.  
  157. $reason_code = $_POST[‘reason_code’];
  158.  
  159. // subscription specific vars
  160.  
  161. $subscr_id = $_POST[’subscr_id’];
  162.  
  163. $subscr_date = $_POST[’subscr_date’];
  164.  
  165. $subscr_effective  = $_POST[’subscr_effective’];
  166.  
  167. $period1 = $_POST[‘period1′];
  168.  
  169. $period2 = $_POST[‘period2′];
  170.  
  171. $period3 = $_POST[‘period3′];
  172.  
  173. $amount1 = $_POST[‘amount1′];
  174.  
  175. $amount2 = $_POST[‘amount2′];
  176.  
  177. $amount3 = $_POST[‘amount3′];
  178.  
  179. $mc_amount1 = $_POST[‘mc_amount1′];
  180.  
  181. $mc_amount2 = $_POST[‘mc_amount2′];
  182.  
  183. $mc_amount3 = $_POST[‘mcamount3′];
  184.  
  185. $recurring = $_POST[‘recurring’];
  186.  
  187. $reattempt = $_POST[‘reattempt’];
  188.  
  189. $retry_at = $_POST[‘retry_at’];
  190.  
  191. $recur_times = $_POST[‘recur_times’];
  192.  
  193. $username = $_POST[‘username’];
  194.  
  195. $password = $_POST[‘password’];
  196.  
  197. //auction specific vars
  198.  
  199. $for_auction = $_POST[‘for_auction’];
  200.  
  201. $auction_closing_date  = $_POST[‘auction_closing_date’];
  202.  
  203. $auction_multi_item  = $_POST[‘auction_multi_item’];
  204.  
  205. $auction_buyer_id  = $_POST[‘auction_buyer_id’];
  206.  
  207. if (!$fp) {
  208.  
  209. // HTTP ERROR
  210.  
  211. } else {
  212.  
  213. fputs ($fp, $header . $req);
  214.  
  215. while (!feof($fp)) {
  216.  
  217. $res = fgets ($fp, 1024);
  218.  
  219. if (strcmp ($res, "VERIFIED") == 0) {
  220.  
  221. $fecha = date("m")."/".date("d")."/".date("Y");
  222.  
  223. $fecha = date("Y").date("m").date("d");
  224.  
  225. //check if transaction ID has been processed before
  226.  
  227. $checkquery = "select txnid from paypal_payment_info where txnid=’".$txn_id."’";
  228.  
  229. $sihay = mysql_query($checkquery) or die("Duplicate txn id check query failed:
  230. " . mysql_error() . "
  231. " . mysql_errno());
  232.  
  233. $nm = mysql_num_rows($sihay);
  234.  
  235. if ($nm == 0){
  236.  
  237. //execute query
  238.  
  239. if ($txn_type == "cart"){ //cas du panier (non évoqué dans ce tuto
  240.  
  241.     $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."’)";
  242.  
  243. $result = mysql_query($strQuery) or die("Cart - paypal_payment_info, Query failed:
  244. " . mysql_error() . "
  245. " . mysql_errno());
  246.  
  247.      for ($i = 1; $i <= $num_cart_items; $i++) {
  248.  
  249.          $itemname = "item_name".$i;
  250.  
  251.          $itemnumber = "item_number".$i;
  252.  
  253.          $on0 = "option_name1_".$i;
  254.  
  255.          $os0 = "option_selection1_".$i;
  256.  
  257.          $on1 = "option_name2_".$i;
  258.  
  259.          $os1 = "option_selection2_".$i;
  260.  
  261.          $quantity = "quantity".$i;
  262.  
  263. $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."’)";
  264.  
  265.          $result = mysql_query($struery) or die("Cart - paypal_cart_info, Query failed:
  266. " . mysql_error() . "
  267. " . mysql_errno());
  268.  
  269. }
  270.  
  271.     }
  272.  
  273. else{  // notre cas celui du bouton à achat immédiat
  274.  
  275.      $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."’)";
  276.  
  277.      $result = mysql_query($strQuery) or die("Default - paypal_payment_info, Query failed:
  278. " . mysql_error() . "
  279. " . mysql_errno());
  280.  
  281.   // ajoute dans la table créer le récapitulatif du paiement paypal
  282.  
  283. // ensuite on réalise notre propre traitement  par exemple ajout de crédit à un utilisateur etc etc
  284.  
  285. //traitement propre à votre site
  286. $tableau = explode("/",$custom);
  287.          $Member_ID=$tableau[0];
  288.          $Object_ID=$tableau[1];
  289.  
  290. requete sql etc
  291.   ….
  292.  
  293.   …
  294.  
  295.   …
  296.  
  297.   ….
  298.  
  299. }
  300.  
  301. // envoie un email de resultat
  302.  
  303.  echo "Verified";
  304.  
  305.      mail($notify_email, "VERIFIED IPN", "$res\n $req\n $strQuery\n $struery\n  $strQuery2","From: vente@votresite.com");
  306.  
  307. }
  308.  
  309. else {
  310.  
  311. // send an email
  312.  
  313. mail($notify_email, "VERIFIED DUPLICATED TRANSACTION", "$res\n $req \n $strQuery\n $struery\n  $strQuery2");
  314.  
  315. }
  316.  
  317. //subscription handling branch
  318.  
  319.     if ( $txn_type == "subscr_signup"  ||  $txn_type == "subscr_payment"  ) {
  320.  
  321. // insert subscriber payment info into paypal_payment_info table
  322.  
  323.       $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."’)";
  324.  
  325.       $result = mysql_query($strQuery) or die("Subscription - paypal_payment_info, Query failed:
  326. " . mysql_error() . "
  327. " . mysql_errno());
  328.  
  329. // insert subscriber info into paypal_subscription_info table
  330.  
  331.         $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."’)";
  332.  
  333.         $result = mysql_query($strQuery2) or die("Subscription - paypal_subscription_info, Query failed:
  334. " . mysql_error() . "
  335. " . mysql_errno());
  336.  
  337. mail($notify_email, "VERIFIED IPN", "$res\n $req\n $strQuery\n $struery\n  $strQuery2");
  338.  
  339. }
  340.  
  341. }
  342.  
  343. // si le paiement n’est pas valide
  344.  
  345. else if (strcmp ($res, "INVALID") == 0) {
  346.  
  347. // log for manual investigation
  348.  
  349. mail($notify_email, "INVALID IPN", "$res\n $req","From: vente@votresite.com");
  350.  
  351. }
  352.  
  353. }
  354.  
  355. fclose ($fp);
  356.  
  357. }
  358.  
  359. ?>

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 à



Add to: Digg Add to: Del.icio.us Add to: Reddit Add to: StumbleUpon Add to: Netscape Add to: Furl Add to: Google Add to: Technorati Add to: Newsvine

26 Comments to “Tutorial Paypal : La récupération des données par IPN”

  1. Tutorial Paypal : Présentation -on 20 fév 2008 at 20:01
    mygif

    [...] Etape 3 : La récupération des données par IPN [...]

  2. mygif

    [...] Contact « Tutorial Paypal : La récupération des données par IPN [...]

  3. josson 21 fév 2008 at 10:57
    mygif

    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

  4. zilogon 09 mar 2008 at 21:18
    mygif

    Intéressant, vos explication vont me faire gagner du temps.

  5. zilogon 11 mar 2008 at 23:13
    mygif

    Pouvez vous fournir le fichier contenant la structure de la table sql ?

    (Le copier/coller provoque une erreur au moment de la creation)

  6. emileon 12 mar 2008 at 8:35
    mygif

    il est disponible ici http://paypaltech.com/SG2/PHPDBSQL_code.php

  7. hubion 02 juin 2008 at 23:07
    mygif

    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.

  8. hubion 03 juin 2008 at 11:12
    mygif

    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 ?

  9. hubion 03 juin 2008 at 16:10
    mygif

    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

  10. stefkilleron 07 juin 2008 at 15:03
    mygif

    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

  11. didion 11 juin 2008 at 19:33
    mygif

    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…

    Hint: <a href=”https://www.sandbox.pay…

  12. didion 12 juin 2008 at 15:49
    mygif

    solution : mettre le protocole ssl avec l’adresse de sandbox
    $fp = fsockopen (’ssl://www.sandbox.paypal.com’, 443, $errno, $errstr, 30);

  13. Dagnanon 18 juin 2008 at 15:05
    mygif

    Attention le & ligne 45 ne passe pas, il faut le remplacer par &

  14. Constantineon 07 août 2008 at 23:12
    mygif

    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 ?

  15. fox7725on 13 août 2008 at 13:14
    mygif

    J’ai le même problème que constantine, à l’aide svp

  16. Siren667on 30 août 2008 at 12:52
    mygif

    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

  17. ayanaion 01 sept 2008 at 4:47
    mygif

    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.

  18. jacksparoon 10 sept 2008 at 17:54
    mygif

    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

  19. Titeufon 24 sept 2008 at 14:57
    mygif

    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…

  20. mygif

    [...] Etape 3 : La récupération des données par IPN [...]

  21. Kyjaon 07 oct 2008 at 4:38
    mygif

    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 ?

  22. Chuckon 18 nov 2008 at 22:12
    mygif

    pour ceux qui savent pas quoi remplacer a la ligne 45 c’est “& amp ;” qui affiche le symbole &

  23. Chuckon 18 nov 2008 at 23:53
    mygif

    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???

  24. doniaon 06 fév 2009 at 6:30
    mygif

    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)

    }
    ?>

  25. jacksparoon 10 fév 2009 at 18:18
    mygif

    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

  26. Chuckon 12 mar 2009 at 15:48
    mygif

    @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é.

Trackback URI | Comments RSS

Leave a Comment