laravel支付宝支付、php app支付宝支付接口

2024-12-03 0 164

Image

Laravel支付宝支付、PHP App支付宝支付接口

在现代Web开发中,集成支付功能是许多应用程序的必要需求之一。Laravel作为一个流行的PHP框架,提供了丰富的工具和库来简化开发过程。介绍如何在Laravel应用中集成支付宝支付功能,并提供几种不同的实现思路。

解决方案

介绍两种主要的实现方式:使用官方SDK和自定义实现。我们将详细讲解每种方法的步骤,并提供相应的代码示例。

使用官方SDK实现支付宝支付

安装SDK

我们需要安装支付宝的官方PHP SDK。可以通过Composer来安装:

bash
composer require alipay/easysdk

配置环境

.env文件中添加支付宝的相关配置:

env
ALIPAY_APP_ID=your_app_id
ALIPAY_PRIVATE_KEY=your_private_key
ALIPAY_PUBLIC_KEY=your_public_key
ALIPAY_MODE=sandbox # 生产环境改为 'online'

创建支付服务类

app/Services目录下创建一个支付服务类AlipayService.php

php
<?php</p>

<p>namespace AppServices;</p>

<p>use AlipayEasySDKKernelFactory;
use AlipayEasySDKKernelConfig;</p>

<p>class AlipayService
{
    public function <em>_construct()
    {
        $config = new Config();
        $config->protocol = 'https';
        $config->gatewayHost = 'openapi.alipay.com';
        $config->signType = 'RSA2';
        $config->appId = env('ALIPAY</em>APP<em>ID');
        $config->merchantPrivateKey = env('ALIPAY</em>PRIVATE<em>KEY');
        $config->alipayPublicKey = env('ALIPAY</em>PUBLIC<em>KEY');
        $config->notifyUrl = env('ALIPAY</em>NOTIFY<em>URL');
        $config->returnUrl = env('ALIPAY</em>RETURN<em>URL');
        $config->merchantId = env('ALIPAY</em>MERCHANT_ID');</p>

<pre><code>    Factory::setOptions($config);
}

public function createOrder($outTradeNo, $totalAmount, $subject)
{
    return Factory::payment()->web()->pageExecute([
        'out_trade_no' => $outTradeNo,
        'total_amount' => $totalAmount,
        'subject' => $subject,
        'product_code' => 'FAST_INSTANT_TRADE_PAY'
    ]);
}

}

创建支付控制器

app/Http/Controllers目录下创建一个支付控制器PaymentController.php

php
<?php</p>

<p>namespace AppHttpControllers;</p>

<p>use AppServicesAlipayService;
use IlluminateHttpRequest;</p>

<p>class PaymentController extends Controller
{
    protected $alipayService;</p>

<pre><code>public function __construct(AlipayService $alipayService)
{
    $this->alipayService = $alipayService;
}

public function pay(Request $request)
{
    $outTradeNo = time(); // 订单号
    $totalAmount = 0.01; // 订单金额
    $subject = '测试订单'; // 订单标题

    $result = $this->alipayService->createOrder($outTradeNo, $totalAmount, $subject);

    if ($result) {
        return redirect($result);
    } else {
        return back()->with('error', '支付请求失败');
    }
}

public function notify()
{
    // 处理支付宝异步通知
    // 请根据实际业务逻辑处理
}

public function return()
{
    // 处理支付宝同步返回
    // 请根据实际业务逻辑处理
}

}

路由配置

routes/web.php中添加路由:

php
use AppHttpControllersPaymentController;</p>

<p>Route::get('/pay', [PaymentController::class, 'pay']);
Route::post('/alipay/notify', [PaymentController::class, 'notify']);
Route::get('/alipay/return', [PaymentController::class, 'return']);

自定义实现支付宝支付

获取支付宝API文档

访问支付宝开放平台获取API文档,了解各个接口的参数和返回值。

创建支付服务类

app/Services目录下创建一个支付服务类CustomAlipayService.php

php
<?php</p>

<p>namespace AppServices;</p>

<p>class CustomAlipayService
{
    private $app<em>id;
    private $private</em>key;
    private $public<em>key;
    private $gateway</em>url;</p>

<pre><code>public function __construct()
{
    $this->app_id = env('ALIPAY_APP_ID');
    $this->private_key = env('ALIPAY_PRIVATE_KEY');
    $this->public_key = env('ALIPAY_PUBLIC_KEY');
    $this->gateway_url = 'https://openapi.alipay.com/gateway.do';
}

public function createOrder($outTradeNo, $totalAmount, $subject)
{
    $params = [
        'app_id' => $this->app_id,
        'method' => 'alipay.trade.page.pay',
        'format' => 'JSON',
        'charset' => 'utf-8',
        'sign_type' => 'RSA2',
        'timestamp' => date('Y-m-d H:i:s'),
        'version' => '1.0',
        'notify_url' => env('ALIPAY_NOTIFY_URL'),
        'return_url' => env('ALIPAY_RETURN_URL'),
        'biz_content' => json_encode([
            'out_trade_no' => $outTradeNo,
            'total_amount' => $totalAmount,
            'subject' => $subject,
            'product_code' => 'FAST_INSTANT_TRADE_PAY'
        ])
    ];

    $params['sign'] = $this->sign($params);

    $url = $this->gateway_url . '?' . http_build_query($params);

    return $url;
}

private function sign($params)
{
    ksort($params);
    $stringToBeSigned = '';
    foreach ($params as $k => $v) {
        if ('sign' != $k && '' !== $v && 'null' !== $v) {
            $stringToBeSigned .= "$k=$v&";
        }
    }
    $stringToBeSigned = rtrim($stringToBeSigned, '&');

    return $this->rsaSign($stringToBeSigned, $this->private_key);
}

private function rsaSign($data, $privateKey)
{
    $res = "-----BEGIN RSA PRIVATE KEY-----n" .
        wordwrap($privateKey, 64, "n", true) .
        "n-----END RSA PRIVATE KEY-----";

    openssl_sign($data, $sign, $res, OPENSSL_ALGO_SHA256);

    return base64_encode($sign);
}

}

创建支付控制器

app/Http/Controllers目录下创建一个支付控制器CustomPaymentController.php

php
<?php</p>

<p>namespace AppHttpControllers;</p>

<p>use AppServicesCustomAlipayService;
use IlluminateHttpRequest;</p>

<p>class CustomPaymentController extends Controller
{
    protected $alipayService;</p>

<pre><code>public function __construct(CustomAlipayService $alipayService)
{
    $this->alipayService = $alipayService;
}

public function pay(Request $request)
{
    $outTradeNo = time(); // 订单号
    $totalAmount = 0.01; // 订单金额
    $subject = '测试订单'; // 订单标题

    $result = $this->alipayService->createOrder($outTradeNo, $totalAmount, $subject);

    if ($result) {
        return redirect($result);
    } else {
        return back()->with('error', '支付请求失败');
    }
}

public function notify()
{
    // 处理支付宝异步通知
    // 请根据实际业务逻辑处理
}

public function return()
{
    // 处理支付宝同步返回
    // 请根据实际业务逻辑处理
}

}

路由配置

routes/web.php中添加路由:

php
use AppHttpControllersCustomPaymentController;</p>

<p>Route::get('/custom-pay', [CustomPaymentController::class, 'pay']);
Route::post('/custom-alipay/notify', [CustomPaymentController::class, 'notify']);
Route::get('/custom-alipay/return', [CustomPaymentController::class, 'return']);

两种在Laravel应用中集成支付宝支付的方法:使用官方SDK和自定义实现。通过这两种方法,开发者可以根据自己的需求选择合适的实现方式。希望能对大家在实际开发中有所帮助。

1. 本站所有资源来源于用户上传和网络,因此不包含技术服务请大家谅解!如有侵权请邮件联系客服!cheeksyu@vip.qq.com
2. 本站不保证所提供下载的资源的准确性、安全性和完整性,资源仅供下载学习之用!如有链接无法下载、失效或广告,请联系客服处理!
3. 您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容资源!如用于商业或者非法用途,与本站无关,一切后果请用户自负!
4. 如果您也有好的资源或教程,您可以投稿发布,成功分享后有积分奖励和额外收入!
5.严禁将资源用于任何违法犯罪行为,不得违反国家法律,否则责任自负,一切法律责任与本站无关

源码下载