Laravel開發:如何使用Laravel Cashier和Authorize.net處理訂閱付款?
隨著電子商務的不斷發展,訂閱付款模式越來越受歡迎。 Laravel Cashier是一個基於Laravel框架的付款工具,它使得管理訂閱和收取付款變得非常簡單。本文將介紹如何在Laravel應用程式中使用Laravel Cashier以及Authorize.net來處理訂閱付款。
- 安裝Laravel Cashier
在開始之前,需要確保你已經安裝了Laravel框架和Composer套件管理器。在終端機輸入以下指令來安裝Laravel Cashier:
composer require laravel/cashier
一旦它安裝成功,你需要為Cashier產生遷移表。可以在終端機執行以下命令:
php artisan migrate
這將為付款相關的Cashier表產生所需的資料庫遷移檔案。
- 設定Authorize.net API
在使用Authorize.net處理付款之前,需要安裝服務並取得API憑證(API Login ID和Transaction Key)。
可以透過以下步驟執行這些操作:
- 前往https://www.authorize.net/註冊一個帳號
- 登入後,在左側選單中選擇“Account”,再選擇“Settings”
- 在“Security Settings”中,選擇“API Credentials & Keys”
- 點擊“New Transaction Key”,輸入需要的資訊,再點選「Submit」
- 在彈出視窗中會顯示API Login ID和Transaction Key。請務必複製並妥善保管。
- 設定Laravel Cashier
在開始之前,需要先設定cashier.php檔案中的參數。可以透過以下命令在config資料夾中建立該檔案:
php artisan vendor:publish --tag="cashier-config"
接下來,需要在.env檔案中設定Authorize.net API相關參數:
CASHIER_ENV=production CASHIER_CURRENCY=usd AUTHORIZE_API_LOGIN_ID=YOUR_API_LOGIN_ID AUTHORIZE_TRANSACTION_KEY=YOUR_TRANSACTION_KEY
- 建立訂閱計劃
在使用Laravel Cashier和Authorize.net處理訂閱付款之前,需要建立訂閱方案。可以透過以下指令來建立訂閱計畫:
php artisan make:model Plan -m
該指令將在app資料夾中建立一個Plan模型,並為其產生遷移表。現在可以開啟遷移檔案進行編輯,並新增必要的欄位。以下是一個可以參考的範例:
Schema::create('plans', function (Blueprint $table) { $table->bigIncrements('id'); $table->string('name'); $table->string('stripe_id'); $table->string('authorizenet_id'); $table->integer('price'); $table->string('interval'); $table->integer('interval_count'); $table->integer('trial_period_days')->nullable(); $table->timestamps(); });
執行完遷移檔案後,需要在資料庫中建立該表。在終端機中執行以下命令:
php artisan migrate
接下來,需要在Plan模型中定義必要的屬性和方法。以下是一個範例:
use LaravelCashierSubscription; class Plan extends Model { public function subscriptions() { return $this->hasMany(Subscription::class); } public function getPrice() { return $this->price / 100; } public function getFormattedPrice() { return number_format($this->getPrice(), 2); } public function authorizeNetPlan() { return AuthorizeNet_Subscription::create([ 'name' => $this->name, 'intervalLength' => $this->interval_count, 'intervalUnit' => $this->interval, 'startDate' => date('Y-m-d'), 'totalOccurrences' => '9999', 'trialOccurrences' => '0', 'amount' => $this->price, 'trialAmount' => '0.00', 'creditCardCardNumber' => '', 'creditCardExpirationDate' => '', 'creditCardCardCode' => '' ]); } }
authorizeNetPlan
方法將建立Authorize.net訂閱計畫並傳回相關的資訊。
- 處理訂閱付款
一旦訂閱計畫已經創建,現在就可以向訂閱者發送訂閱連結。接下來,訂閱者可以使用Link點擊連結進行訂閱付款。
在建立訂閱時,需要設定訂閱方案和使用者相關資訊。
以下是一個範例控制器方法:
public function subscribe(Request $request, Plan $plan) { $user = $request->user(); $subscription = $user->newSubscription('default', $plan->stripe_id)->create($request->stripeToken); $authorizeSubscription = $plan->authorizeNetPlan(); $subscription->authorize_net_id = $authorizeSubscription->getSubscriptionId(); $subscription->save(); return redirect()->route('home')->with('success', 'Subscription successful'); }
在這個範例中,我們使用newSubscription
方法為使用者建立新的訂閱。注意,$request->stripeToken
是使用Stripe Checkout產生的令牌。 getUserPlan
方法在Plan模型中定義,用於取得目前使用者的訂閱計畫。
在建立訂閱後,我們將建立的Authorize.net訂閱計畫的ID儲存到Subscription模型中。
- 處理取消訂閱
當使用者想要取消訂閱時,需要執行以下操作:
public function cancel(Request $request) { $user = $request->user(); $subscription = $user->subscription('default'); $authorizeSubscription = AuthorizeNet_Subscription::cancel($subscription->authorize_net_id); $subscription->cancel(); return redirect()->route('home')->with('success', 'Subscription cancelled.'); }
在該範例中,我們使用cancel
方法取消使用者的Laravel Cashier訂閱計劃,並使用Authorize.net中提供的方法取消訂閱計劃。
總結
使用Laravel Cashier和Authorize.net處理訂閱付款非常簡單。僅需按照上述步驟即可快速設定和實現。 Laravel Cashier提供了便利的付款工具,何不實現這樣一種新模式,以滿足日益變化的市場需求呢?
以上是Laravel開發:如何使用Laravel Cashier和Authorize.net處理訂閱付款?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Laravel 是一款 PHP 框架,用於輕鬆構建 Web 應用程序。它提供一系列強大的功能,包括:安裝: 使用 Composer 全局安裝 Laravel CLI,並在項目目錄中創建應用程序。路由: 在 routes/web.php 中定義 URL 和處理函數之間的關係。視圖: 在 resources/views 中創建視圖以呈現應用程序的界面。數據庫集成: 提供與 MySQL 等數據庫的開箱即用集成,並使用遷移來創建和修改表。模型和控制器: 模型表示數據庫實體,控制器處理 HTTP 請求。

在使用CraftCMS開發網站時,常常會遇到資源文件緩存的問題,特別是當你頻繁更新CSS和JavaScript文件時,舊版本的文件可能仍然被瀏覽器緩存,導致用戶無法及時看到最新的更改。這個問題不僅影響用戶體驗,還會增加開發和調試的難度。最近,我在項目中遇到了類似的困擾,經過一番探索,我找到了wiejeben/craft-laravel-mix這個插件,它完美地解決了我的緩存問題。

想要學習 Laravel 框架,但苦於沒有資源或經濟壓力?本文為你提供了免費學習 Laravel 的途徑,教你如何利用網絡平台、文檔和社區論壇等資源,從入門到掌握,為你的 PHP 開發之旅奠定堅實基礎。

Laravel 提供了一個全面的 Auth 框架,用於實現用戶登錄功能,包括:定義用戶模型(Eloquent 模型)創建登錄表單(Blade 模板引擎)編寫登錄控制器(繼承 Auth\LoginController)驗證登錄請求(Auth::attempt)登錄成功後重定向(redirect)考慮安全因素:哈希密碼、防 CSRF 保護、速率限制和安全標頭。此外,Auth 框架還提供重置密碼、註冊和驗證電子郵件等功能。詳情請參閱 Laravel 文檔:https://laravel.com/doc

文章摘要:本文提供了詳細分步說明,指導讀者如何輕鬆安裝 Laravel 框架。 Laravel 是一個功能強大的 PHP 框架,它 упростил 和加快了 web 應用程序的開發過程。本教程涵蓋了從系統要求到配置數據庫和設置路由等各個方面的安裝過程。通過遵循這些步驟,讀者可以快速高效地為他們的 Laravel 項目打下堅實的基礎。

在面向初学者的 Laravel 框架版本选择指南中,本文深入探討了 Laravel 的版本差異,旨在協助初學者在眾多版本之間做出明智的選擇。我們將重點介紹每個版本的關鍵特徵、比較它們的優缺點,並提供有用的建議,幫助新手根據他們的技能水準和項目需求挑選最合適的 Laravel 版本。對於初學者來說,選擇一個合適的 Laravel 版本至關重要,因為它可以顯著影響他們的學習曲線和整體開發體驗。

Laravel框架內置了多種方法來方便地查看其版本號,滿足開發者的不同需求。本文將探討這些方法,包括使用Composer命令行工具、訪問.env文件或通過PHP代碼獲取版本信息。這些方法對於維護和管理Laravel應用程序的版本控制至關重要。

Laravel 和 ThinkPHP 都是流行的 PHP 框架,在開發中各有優缺點。本文將深入比較這兩者,重點介紹它們的架構、特性和性能差異,以幫助開發者根據其特定項目需求做出明智的選擇。
