laravel payment
3.0.0
? Omnipay-Dienstanbieter für Laravel.
$ composer require overtrue/laravel-payment -v
Wenn Sie nach der Aktualisierung des Composers eine Laravel-Version < 5.5 verwenden, müssen Sie den Dienstanbieter registrieren:
// config/app.php
' providers ' => [
//...
Overtrue LaravelPayment ServiceProvider::class,
],
Und veröffentlichen Sie die Konfigurationsdatei:
$ php artisan vendor:publish --provider=Overtrue \ LaravelPayment \ ServiceProvider
Wenn Sie den Fassadenmodus verwenden möchten, können Sie einen Fassadennamen registrieren, den Sie verwenden möchten, zum Beispiel 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
],
Sie müssen das Gateway installieren, das Sie verwenden möchten: omnipay#paid-gateways
Gateway-Instanz:
LaravelPayment:: gateway ( ' GATEWAY NAME ' ); // GATEWAY NAME is key name of `gateways` configuration.
LaravelPayment:: gateway ( ' alipay ' );
LaravelPayment:: gateway ( ' paypal ' );
Standard-Gateway verwenden:
LaravelPayment:: purchase (...);
Beispiel:
$ 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 ();
}
Weitere Informationen zu Omnipay finden Sie auf der offiziellen Homepage von Omnipay
想知道如何从零开始构建 PHP-Unterstützung
请关注我的实战课程,我会在此课程中分享一些扩展开发经验 —— 《PHP 扩展包实战教程 -从入门到发布》
MIT