2010-11-16 3 views
6

J'ai stocké l'adresse email des clients paypal dans la base de données et je veux leur envoyer de l'argent en utilisant cette adresse e-mail. J'utilise PHP.Comment envoyer de l'argent à paypal en utilisant php

Quelqu'un suggère s'il vous plaît comment faire cela.

+13

Il semble étrange que vous envoyiez de l'argent aux clients au lieu de collecter l'argent. Je veux être sur votre liste. – stillstanding

+0

Commençons par une liste de ce que vous avez essayé? Avez-vous google atleast? C'est mieux si vous pouvez donner un problème particulier où vous êtes coincé. Merci – pinaki

+0

@pinaki: Google n'est pas une réponse ni utile sur SO (la plupart des recherches ramènent à la question de toute façon). Mais je suis d'accord avec vous sur le fait que la question est trop large et qu'il devrait revenir avec un problème spécifique. – Bobby

Répondre

11

Je cherchais le même problème, voici ce qui fonctionne pour moi. Testé en mode «sandbox» et en utilisant NVP (au lieu de SOAP). Votre serveur doit prendre en charge CURL, afin de vérifier qu'il utilise:

<?php 
echo 'curl extension/module loaded/installed: '; 
echo (!extension_loaded('curl')) ? 'no' : 'yes'; 
echo "<br />\n"; 
phpinfo(INFO_MODULES); // just to be sure 
?> 

Si non chargé ou installé demanderas à votre hostmaster ou get it here, sinon allez-y:

<?php 
// code modified from source: https://cms.paypal.com/cms_content/US/en_US/files/developer/nvp_MassPay_php.txt 
// documentation: https://cms.paypal.com/us/cgi-bin/?cmd=_render-content&content_ID=developer/howto_api_masspay 
// sample code: https://cms.paypal.com/us/cgi-bin/?cmd=_render-content&content_ID=developer/library_code 

// eMail subject to receivers 
$vEmailSubject = 'PayPal payment'; 

/** MassPay NVP example. 
* 
* Pay one or more recipients. 
*/ 

// For testing environment: use 'sandbox' option. Otherwise, use 'live'. 
// Go to www.x.com (PayPal Integration center) for more information. 
$environment = 'sandbox'; // or 'beta-sandbox' or 'live'. 

/** 
* Send HTTP POST Request 
* 
* @param string The API method name 
* @param string The POST Message fields in &name=value pair format 
* @return array Parsed HTTP Response body 
*/ 
function PPHttpPost($methodName_, $nvpStr_) 
{ 
global $environment; 

// Set up your API credentials, PayPal end point, and API version. 
// How to obtain API credentials: 
// https://cms.paypal.com/us/cgi-bin/?cmd=_render-content&content_ID=developer/e_howto_api_NVPAPIBasics#id084E30I30RO 
$API_UserName = urlencode('my_api_username'); 
$API_Password = urlencode('my_api_password'); 
$API_Signature = urlencode('my_api_signature'); 
$API_Endpoint = "https://api-3t.paypal.com/nvp"; 
if("sandbox" === $environment || "beta-sandbox" === $environment) 
{ 
    $API_Endpoint = "https://api-3t.$environment.paypal.com/nvp"; 
} 
$version = urlencode('51.0'); 

// Set the curl parameters. 
$ch = curl_init(); 
curl_setopt($ch, CURLOPT_URL, $API_Endpoint); 
curl_setopt($ch, CURLOPT_VERBOSE, 1); 

// Turn off the server and peer verification (TrustManager Concept). 
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); 
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); 

curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
curl_setopt($ch, CURLOPT_POST, 1); 

// Set the API operation, version, and API signature in the request. 
$nvpreq = "METHOD=$methodName_&VERSION=$version&PWD=$API_Password&USER=$API_UserName&SIGNATURE=$API_Signature$nvpStr_"; 

// Set the request as a POST FIELD for curl. 
curl_setopt($ch, CURLOPT_POSTFIELDS, $nvpreq); 

// Get response from the server. 
$httpResponse = curl_exec($ch); 

if(!$httpResponse) 
{ 
    exit("$methodName_ failed: " . curl_error($ch) . '(' . curl_errno($ch) .')'); 
} 

// Extract the response details. 
$httpResponseAr = explode("&", $httpResponse); 

$httpParsedResponseAr = array(); 
foreach ($httpResponseAr as $i => $value) 
{ 
    $tmpAr = explode("=", $value); 
    if(sizeof($tmpAr) > 1) 
    { 
    $httpParsedResponseAr[$tmpAr[0]] = $tmpAr[1]; 
    } 
} 

if((0 == sizeof($httpParsedResponseAr)) || !array_key_exists('ACK', $httpParsedResponseAr)) 
{ 
    exit("Invalid HTTP Response for POST request($nvpreq) to $API_Endpoint."); 
} 

return $httpParsedResponseAr; 
} 

// Set request-specific fields. 
$emailSubject = urlencode($vEmailSubject); 
$receiverType = urlencode('EmailAddress'); 
$currency = urlencode('USD'); // or other currency ('GBP', 'EUR', 'JPY', 'CAD', 'AUD') 

// Receivers 
// Use '0' for a single receiver. In order to add new ones: (0, 1, 2, 3...) 
// Here you can modify to obtain array data from database. 
$receivers = array(
    0 => array(
    'receiverEmail' => "[email protected]", 
    'amount' => "20.00", 
    'uniqueID' => "id_001", // 13 chars max 
    'note' => " payment of commissions"), // I recommend use of space at beginning of string. 
    1 => array(
    'receiverEmail' => "[email protected]", 
    'amount' => "162.38", 
    'uniqueID' => "A47-92w", // 13 chars max, available in 'My Account/Overview/Transaction details' when the transaction is made 
    'note' => " payoff of what I owed you" // space again at beginning. 
) 
); 
$receiversLenght = count($receivers); 

// Add request-specific fields to the request string. 
$nvpStr="&EMAILSUBJECT=$emailSubject&RECEIVERTYPE=$receiverType&CURRENCYCODE=$currency"; 

$receiversArray = array(); 

for($i = 0; $i < $receiversLenght; $i++) 
{ 
$receiversArray[$i] = $receivers[$i]; 
} 

foreach($receiversArray as $i => $receiverData) 
{ 
$receiverEmail = urlencode($receiverData['receiverEmail']); 
$amount = urlencode($receiverData['amount']); 
$uniqueID = urlencode($receiverData['uniqueID']); 
$note = urlencode($receiverData['note']); 
$nvpStr .= "&L_EMAIL$i=$receiverEmail&L_Amt$i=$amount&L_UNIQUEID$i=$uniqueID&L_NOTE$i=$note"; 
} 

// Execute the API operation; see the PPHttpPost function above. 
$httpParsedResponseAr = PPHttpPost('MassPay', $nvpStr); 

if("SUCCESS" == strtoupper($httpParsedResponseAr["ACK"]) || "SUCCESSWITHWARNING" == strtoupper($httpParsedResponseAr["ACK"])) 
{ 
exit('MassPay Completed Successfully: ' . print_r($httpParsedResponseAr, true)); 
} 
else 
{ 
exit('MassPay failed: ' . print_r($httpParsedResponseAr, true)); 
} 

?> 

Bonne chance!

+1

Pourquoi, sur la Terre, utiliser un exemple boiteux d'origine inconnue du tableau d'affichage anonyme, au lieu du ** code de la documentation officielle ** ?! –

+6

Peut-être que j'ai oublié de mentionner que je l'ai fait à partir de l'exemple de code PayPal, ou peut-être la première ligne commentée a les mots: «code modifié à partir de la source». Je ne voulais pas donner à Deepak ou à d'autres un simple lien vers la documentation officielle, je lui ai donné un code utile. En passant, j'ai modifié l'exemple de code officiel parce que le processus de paiement initial est fait trois fois, cela signifie: vous voulez envoyer 10 dollars et que le code dépense 30, sans avertissements. – quantme

+4

quantme 1 Col. Shrapnel 0 –

1

Qu'est-ce que vous cherchez est DoMassPay à partir des échantillons de code officiel PayPal, pas facile de deviner ce nom: P

Questions connexes