laravel payment
3.0.0
? Fournisseur de services Omnipay pour Laravel.
$ composer require overtrue/laravel-payment -v
Après la mise à jour du compositeur, si vous utilisez la version de Laravel <5.5, vous devez enregistrer le fournisseur de services :
// config/app.php
' providers ' => [
//...
Overtrue LaravelPayment ServiceProvider::class,
],
Et publiez le fichier de configuration :
$ php artisan vendor:publish --provider=Overtrue \ LaravelPayment \ ServiceProvider
si vous souhaitez utiliser le mode façade, vous pouvez enregistrer un nom de façade que vous souhaitez utiliser, par exemple LaravelPayment
:
// config/app.php
' aliases ' => [
' LaravelPayment ' => Overtrue LaravelPayment Facade::class, // This is default in laravel 5.5
],
// config/payments.php
// The default gateway name which configured in `gateways` section.
' default_gateway ' => ' paypal ' ,
// The default options for every gateways.
' default_options ' => [
' test_mode ' => true ,
// ...
],
/*
* The gateways, you can config option by camel case or snake_case name.
*
* the option name is followed from gateway class, for example:
*
* $gateway->setMchId('overtrue');
*
* you can configured as:
* 'mch_id' => 'overtrue',
* or:
* 'mchId' => 'overtrue',
*/
' gateways ' => [
' paypal ' => [
' driver ' => ' PayPal_Express ' ,
' options ' => [
' username ' => env ( ' PAYPAL_USERNAME ' ),
' password ' => env ( ' PAYPAL_PASSWORD ' ),
' signature ' => env ( ' PAYPAL_SIGNATURE ' ),
' test_mode ' => env ( ' PAYPAL_TEST_MODE ' ),
],
],
// other gateways
],
Vous devez installer la passerelle que vous souhaitez utiliser : omnipay#payment-gateways
Instance de passerelle :
LaravelPayment:: gateway ( ' GATEWAY NAME ' ); // GATEWAY NAME is key name of `gateways` configuration.
LaravelPayment:: gateway ( ' alipay ' );
LaravelPayment:: gateway ( ' paypal ' );
Utilisation de la passerelle par défaut :
LaravelPayment:: purchase (...);
Exemple:
$ formData = [
' number ' => ' 4242424242424242 ' ,
' expiryMonth ' => ' 6 ' ,
' expiryYear ' => ' 2030 ' ,
' cvv ' => ' 123 '
];
$ response = LaravelPayment::purchase([
' amount ' => ' 10.00 ' ,
' currency ' => ' USD ' ,
' card ' => $ formData ,
))-> send ();
if ( $ response -> isRedirect ()) {
// redirect to offsite payment gateway
$ response -> redirect ();
} elseif ( $ response -> isSuccessful ()) {
// payment was successful: update database
print_r ( $ response );
} else {
// payment failed: display message to customer
echo $ response -> getMessage ();
}
Pour en savoir plus sur Omnipay, veuillez vous référer à la page d'accueil officielle d'Omnipay.
Comment fonctionne PHP ?
-从入门到发布》
MIT