Laravel5.5 支付宝支付

本文档详细介绍了如何在安卓设备上使用沙箱环境进行蚂蚁金服的应用实名认证和配置,包括私钥和公钥的生成与转换,以及在PHP环境中配置支付宝支付接口,涵盖手机网页、APP和扫码支付的实现,并提供了退款接口的示例代码。
摘要由CSDN通过智能技术生成

配置

商家账号服务申请很麻烦,为了快速测试 可以用 沙箱测试版 app, 不过目前 只支持 安卓手机

测试的服务,也要实名认证和身份扩展后才可以,也就填写一些个人信息,很简单,这里不做详细介绍

蚂蚁金服开放平台
蚂蚁金服沙箱测试版

说明

private_key 私钥

private_key 是商家应用私钥,获取方法说明,我是下载 Mac 版的(RSA 签名工具下载地址),生成秘钥的格式应该选 PKCS1 (非 JAVA 使用) , 但我这里一直生成失败,不知道 是不是因为黑苹果的原因 T_T,所以这里我是这样处理的:

  1. 秘钥格式 先选,PKCS8 (JAVA 适用),点击生成秘钥
  2. 复制 商户应用私钥,点击标签栏的格式装换,粘贴,点击 转 PKCS1 (非 JAVA 使用) 私钥,生成内容则为 下方配置中 private_key 的值

在这里插入图片描述
在这里插入图片描述

ali_public_key 公钥

千万要注意 ali_public_key 不是 RSA 签名工具 生成的公钥,而是 支付宝后台应用中的 RSA2 (SHA256) 密钥支付宝公钥

获取方法:

  1. RSA 签名验签工具格式转换中 点击生成公钥文件 复制内容 在这里插入图片描述
  2. 进入后台,设置 RSA2 (SHS256) 秘钥应用公钥,粘贴上刚才复制的内容

在这里插入图片描述

在这里插入图片描述

  1. 保存成功后, 点击查看支付宝公钥, 就能获取到支付宝公钥了

在这里插入图片描述
在这里插入图片描述
秘钥调试工具

配置文件

config 目录下新建 alipay.php 文件 配置以下内容

<?php
return [
    'pay' => [
        // APPID
        'app_id' => '************',
        // 支付宝 支付成功后 主动通知商户服务器地址  注意 是post请求
        'notify_url' => 'http://192.168.0.110:9555/api/home/ali_pay_ntify',
        // 支付宝 支付成功后 回调页面 get
        'return_url' => 'http://192.168.0.110:9528/#/pay_success',
        // 公钥(注意是支付宝的公钥,不是商家应用公钥)
        'ali_public_key' => '********',
        // 加密方式: **RSA2** 私钥 商家应用私钥
        'private_key' => '********',
        'log' => [ // optional
            'file' => '../storage/logs/alipay.log',
            'level' => 'info', // 建议生产环境等级调整为 info,开发环境为 debug
            'type' => 'single', // optional, 可选 daily.
            'max_file' => 30, // optional, 当 type 为 daily 时有效,默认 30 天
        ],
        'http' => [
            'timeout' => 5.0,
            'connect_timeout' => 5.0,
            // 更多配置项请参考 [Guzzle](https://guzzle-cn.readthedocs.io/zh_CN/latest/request-options.html)
        ],
        'mode' => 'dev', // optional,设置此参数,将进入沙箱模式
    ]
];
支付组件
composer require yansongda/pay
二维码生成器
composer require simplesoftwareio/simple-qrcode
控制器

本例 中只简单介绍常用的,手机网站支付、app 支付、扫码支付、退款,更多功能请参考

官方文档

use Yansongda\Pay\Pay;
use App\Services\OrderService;
use SimpleSoftwareIO\QrCode\Facades\QrCode;
class AliPayController extends Controller
{
    // 手机网页支付接口
    public function aliPay(Request $request)
    {
        $aliPayOrder = [
            'out_trade_no' => time(),
            'total_amount' => $order->total_amount, // 支付金额
            'subject'      => $request->subject ?? '支付宝手机网页支付' // 备注
        ];

        $config = config('alipay.pay');

        $config['return_url'] = $config['return_url'].'?id='.$request->id;

        $config['notify_url'] = $config['notify_url'].'?id='.$request->id;

        return Pay::alipay($config)->wap($aliPayOrder);
    }

    // app支付接口
    public function aliPayApp(Request $request)
    {
        $aliPayOrder = [
            'out_trade_no' => time(),
            'total_amount' => $order->total_amount, // 支付金额
            'subject'      => $request->subject ?? '默认' // 备注
        ];

        $config = config('alipay.pay');

        $config['return_url'] = $config['return_url'].'?id='.$request->id;

        return Pay::alipay($config)->app($aliPayOrder);
    }

    // 支付宝扫码 支付
    public function aliPayScan(Request $request)
    {
        $aliPayOrder = [
            'out_trade_no' => time(),
            'total_amount' => $order->total_amount, // 支付金额
            'subject'      => $request->subject ?? '扫码支付' // 备注
        ];

        $config = config('alipay.pay');

        $config['return_url'] = $config['return_url'].'?order_guid='.$request->order_guid;

        $scan = Pay::alipay($config)->scan($aliPayOrder);

        if(empty($scan->code) || $scan->code !== '10000') return false;

        $url = $scan->code.'?order_guid='.$request->order_guid;
        // 生成二维码
        return  QrCode::encoding('UTF-8')->size(300)->generate($url);

    }

    // 支付成功后 支付宝服务通知本项目服务器
    // post 请求
    // 这里只是大概写一下逻辑,具体的安全防护 自己再去做限制
    public function aliPayNtify(Request $request, OrderService $orderService)
    {
        $order = Order::find($request->id);
        // 更新自己项目 订单状态
        if(!empty($order))  $orderService->payOrder($order);
    }

    // 支付宝退款
    public function aliPayRefund(Request $request)
    {
        try {
            $payOrder = [
                'out_trade_no' => $order->out_trade_no, // 商家订单号
                'refund_amount' => $order->total_amount, // 退款金额  不得超过该订单总金额
                 'out_request_no' => Common::getUuid() // 同一笔交易多次退款标识(部分退款标识)
            ];

            $config = config('alipay.pay');

            // 返回状态码 code 10000 成功
            $result = Pay::alipay($config)->refund($payOrder);
            if (empty($result->code) || $result->code !== '10000') throw new \Exception('请求支付宝退款接口失败');
            // 订单改为 已退款状态
            // ~~自己商城的订单状态修改逻辑
        } catch (\Exception $exception) {
            \Log::error($exception->getMessage());
            return false;
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值