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 :

  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 à



23 commentaires à “Tutorial Paypal : La récupération des données par IPN”


  1. 1 joss

    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

  2. 2 zilog

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

  3. 3 zilog

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

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

  4. 4 emile
  5. 5 hubi

    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.

  6. 6 hubi

    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 ?

  7. 7 hubi

    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

  8. 8 stefkiller

    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

  9. 9 didi

    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…

  10. 10 didi

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

  11. 11 Dagnan

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

  12. 12 Constantine

    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 ?

  13. 13 fox7725

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

  14. 14 Siren667

    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

  15. 15 ayanai

    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.

  16. 16 jacksparo

    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

  17. 17 Titeuf

    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…

  18. 18 Kyja

    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 ?

  19. 19 Chuck

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

  20. 20 Chuck

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

  1. 1 Tutorial Paypal : Présentation -
  2. 2 Tutorial Paypal : Création du Bouton HTML “Acheter Maintenant” -
  3. 3 Tutorial Paypal : Présentation - Informatique Rodez

Laisser un commentaire